/* ============================================================
   Wild Vegas Casino Canada — stylesheet
   Self-contained. No external fonts, no external links.
   ============================================================ */

:root{
  --bg:        #160a1e;
  --bg-2:      #1f0e2b;
  --panel:     #25132f;
  --panel-2:   #2e1739;
  --line:      #3d2350;
  --gold:      #f5c542;
  --gold-soft: #ffd76a;
  --red:       #e23149;
  --red-hot:   #ff3b5c;
  --neon:      #27e0c4;
  --magenta:   #ff4fd8;
  --text:      #f4ecdd;
  --muted:     #b8a6c9;
  --radius:    14px;
  --maxw:      1180px;
  --shadow:    0 18px 40px rgba(0,0,0,.45);
  --font:      "Segoe UI", Roboto, "Helvetica Neue", Arial, system-ui, sans-serif;
  --font-head: "Trebuchet MS", "Segoe UI", Tahoma, Arial, sans-serif;
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  line-height:1.7;
  background:
    radial-gradient(1100px 520px at 12% -8%, rgba(245,197,66,.10), transparent 60%),
    radial-gradient(900px 500px at 100% 0%, rgba(255,79,216,.10), transparent 55%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}

a{color:var(--gold-soft);text-decoration:none}

h1,h2,h3{font-family:var(--font-head);line-height:1.2;margin:0 0 .5em}
h1{font-size:clamp(1.9rem,5vw,3.1rem);letter-spacing:.5px}
h2{font-size:clamp(1.4rem,3.4vw,2rem);margin-top:1.4em}
h3{font-size:clamp(1.1rem,2.4vw,1.35rem)}
p{margin:0 0 1em}

/* ---------- Top reference banner (above everything) ---------- */
.topbar{
  background:linear-gradient(90deg,var(--red) 0%,var(--red-hot) 45%,var(--magenta) 100%);
  color:#fff;
  text-align:center;
}
.topbar .wrap{
  display:flex;flex-wrap:wrap;gap:12px 22px;
  align-items:center;justify-content:center;
  padding:14px 18px;
}
.topbar strong{font-size:1.05rem;letter-spacing:.3px}
.topbar .tb-sub{font-size:.86rem;opacity:.92}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  border:none;cursor:pointer;
  font-family:var(--font-head);font-weight:700;font-size:1rem;
  padding:.8em 1.5em;border-radius:999px;
  color:#1a0c10;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));
  box-shadow:0 8px 22px rgba(245,197,66,.35);
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease;
  text-transform:uppercase;letter-spacing:.6px;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(245,197,66,.5)}
.btn:focus-visible{outline:3px solid var(--neon);outline-offset:3px}
.btn--ghost{
  background:transparent;color:var(--text);
  border:2px solid var(--gold);box-shadow:none;
}
.btn--ghost:hover{background:rgba(245,197,66,.12)}
.btn--wide{font-size:1.1rem;padding:.95em 2.1em}

/* ---------- Header / nav ---------- */
.site-head{
  position:sticky;top:0;z-index:30;
  background:rgba(22,10,30,.82);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.site-head .wrap{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:12px 18px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{flex:0 0 auto}
.brand .brand-txt{display:flex;flex-direction:column;line-height:1}
.brand .brand-txt b{
  font-family:var(--font-head);font-size:1.25rem;letter-spacing:1px;
  color:var(--gold-soft);
}
.brand .brand-txt span{font-size:.68rem;letter-spacing:3px;color:var(--muted);text-transform:uppercase}
.nav{display:flex;gap:6px;flex-wrap:wrap}
.nav a{
  color:var(--text);padding:.45em .8em;border-radius:8px;font-size:.92rem;
  transition:background .12s ease,color .12s ease;
}
.nav a:hover{background:var(--panel);color:var(--gold-soft)}

/* ---------- Hero ---------- */
.hero{padding:42px 0 8px;text-align:center}
.hero .eyebrow{
  display:inline-block;font-size:.78rem;letter-spacing:3px;text-transform:uppercase;
  color:var(--neon);border:1px solid var(--line);border-radius:999px;
  padding:.35em 1em;margin-bottom:1em;background:var(--panel);
}
.hero .lede{max-width:780px;margin:0 auto 1.4em;color:var(--muted);font-size:1.08rem}
.hero .rating{
  display:inline-flex;gap:10px;align-items:center;
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:.6em 1.1em;margin-top:6px;
}
.hero .rating .score{font-family:var(--font-head);font-size:1.8rem;color:var(--gold);font-weight:700}
.stars{color:var(--gold);letter-spacing:2px}

/* ---------- Generic content blocks ---------- */
.section{padding:8px 0 6px}
.lead-card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;margin:18px 0;box-shadow:var(--shadow);
}

/* ---------- Card grids (kept compact) ---------- */
.grid{display:grid;gap:16px;margin:16px 0}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px 20px;position:relative;overflow:hidden;
}
.card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--red-hot),var(--magenta));
}
.card h3{margin-top:.2em;color:var(--gold-soft)}
.card p{font-size:.95rem;color:var(--muted);margin-bottom:0}
.card .ic{
  width:46px;height:46px;display:grid;place-items:center;
  border-radius:12px;background:var(--bg-2);border:1px solid var(--line);
  margin-bottom:10px;
}
.card .ic svg{width:26px;height:26px}

/* ---------- Pros / cons ---------- */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}
.pc .box{border-radius:var(--radius);padding:20px;border:1px solid var(--line)}
.pc .pros{background:rgba(39,224,196,.07);border-color:rgba(39,224,196,.35)}
.pc .cons{background:rgba(255,59,92,.07);border-color:rgba(255,59,92,.35)}
.pc h3{margin-top:0}
.pc ul{margin:0;padding-left:1.2em}
.pc li{margin:.4em 0;color:var(--text)}

/* ---------- Steps ---------- */
.steps{counter-reset:step;list-style:none;margin:16px 0;padding:0}
.steps li{
  position:relative;padding:14px 16px 14px 58px;margin:10px 0;
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
}
.steps li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:30px;height:30px;border-radius:50%;
  display:grid;place-items:center;font-family:var(--font-head);font-weight:700;
  color:#1a0c10;background:linear-gradient(180deg,var(--gold-soft),var(--gold));
}

/* ---------- Mid strip bonus banner ---------- */
.strip{
  margin:26px 0;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);
  background:
    radial-gradient(600px 200px at 0% 0%, rgba(245,197,66,.18), transparent 60%),
    linear-gradient(90deg,var(--red) 0%, #7a1130 60%, var(--bg-2) 100%);
}
.strip .inner{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:22px 24px;flex-wrap:wrap;
}
.strip .txt b{font-family:var(--font-head);font-size:1.35rem;color:#fff;display:block}
.strip .txt span{color:#ffe9ec}

/* ---------- Table ---------- */
.table-scroll{
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  border:1px solid var(--line);border-radius:var(--radius);
  margin:16px 0;
}
table{border-collapse:collapse;width:100%;min-width:560px}
caption{caption-side:top;text-align:left;color:var(--muted);padding:10px 14px;font-size:.9rem}
th,td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line);font-size:.95rem}
thead th{
  background:var(--panel-2);color:var(--gold-soft);
  font-family:var(--font-head);letter-spacing:.4px;white-space:nowrap;
}
tbody tr:nth-child(even){background:rgba(255,255,255,.025)}
tbody tr:hover{background:rgba(245,197,66,.06)}

/* ---------- FAQ accordion (pure CSS, <details>) ---------- */
.faq{margin:16px 0}
.faq details{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  margin:10px 0;overflow:hidden;
}
.faq summary{
  cursor:pointer;list-style:none;
  padding:16px 50px 16px 18px;position:relative;
  font-family:var(--font-head);font-weight:700;color:var(--gold-soft);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);
  font-size:1.5rem;color:var(--neon);transition:transform .2s ease;
}
.faq details[open] summary::after{content:"\2013";transform:translateY(-50%) rotate(180deg)}
.faq .faq-body{padding:0 18px 16px;color:var(--muted)}
.faq summary:focus-visible{outline:3px solid var(--neon);outline-offset:-3px;border-radius:8px}

/* ---------- Callout / responsible play ---------- */
.note{
  border-left:4px solid var(--gold);background:var(--panel);
  padding:14px 18px;border-radius:0 12px 12px 0;margin:16px 0;color:var(--muted);
}

/* ---------- Footer ---------- */
.site-foot{
  margin-top:40px;border-top:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg-2),#11060f);
}
.site-foot .wrap{padding:30px 18px}
.foot-grid{display:flex;gap:18px;flex-wrap:wrap;justify-content:space-between}
.foot-grid .col{max-width:520px}
.foot-grid h3{color:var(--gold-soft)}
.rg{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;margin:14px 0;
}
.age{
  flex:0 0 auto;width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;font-family:var(--font-head);font-weight:800;
  color:#1a0c10;background:linear-gradient(180deg,var(--gold-soft),var(--gold));
}
.foot-legal{color:var(--muted);font-size:.85rem;margin-top:14px;border-top:1px solid var(--line);padding-top:14px}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .grid--3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:620px){
  .grid--2,.grid--3,.grid--4{grid-template-columns:1fr}
  .pc{grid-template-columns:1fr}
  .nav{display:none}
  .strip .inner{flex-direction:column;align-items:flex-start}
  .hero{padding-top:30px}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto;transition:none!important}
}
