/* =========================================================
   BitStarz Casino Canada — styles.css
   Dark premium theme · responsive · no images
   ========================================================= */

:root{
  --bg:        #080c17;
  --bg-2:      #0c1222;
  --surface:   #121a2d;
  --surface-2: #18223c;
  --line:      #243250;
  --line-soft: #1c294480;

  --text:      #eaf0fb;
  --muted:     #97a6c4;
  --muted-2:   #6f7e9e;

  --blue:      #2ea6ff;
  --blue-2:    #58c0ff;
  --blue-deep: #155fce;
  --gold:      #ffc24b;
  --gold-2:    #ffd887;
  --gold-deep: #f2a516;
  --green:     #36d399;
  --red:       #ff6f6f;

  --glow-blue: 0 0 0 1px #2ea6ff33, 0 18px 50px -18px #2ea6ff66;
  --glow-gold: 0 10px 34px -10px #f2a51688;

  --radius:    16px;
  --radius-sm: 10px;
  --wrap:      1120px;

  --ff-display: "Sora", system-ui, -apple-system, "Segoe UI", sans-serif;
  --ff-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--text);
  background:
    radial-gradient(1100px 520px at 78% -8%, #16306a4d, transparent 60%),
    radial-gradient(900px 480px at 6% 4%, #0e2a5540, transparent 55%),
    var(--bg);
  line-height:1.7;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
}

.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:20px; }

a{ color:var(--blue-2); text-decoration:none; }
a:hover{ color:#fff; }

h1,h2,h3,h4{ font-family:var(--ff-display); line-height:1.18; color:#fff; letter-spacing:-.01em; }
h2{ font-size:clamp(1.5rem,3.6vw,2.15rem); margin:2.6em 0 .6em; }
h3{ font-size:clamp(1.15rem,2.6vw,1.4rem); margin:1.9em 0 .5em; }
p{ margin:0 0 1.05em; }
main p, main li{ color:#d8e1f2; }

:focus-visible{ outline:3px solid var(--gold); outline-offset:3px; border-radius:6px; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--ff-display); font-weight:700; font-size:1rem;
  border:0; cursor:pointer; border-radius:999px; padding:.85em 1.6em;
  color:#1a1305; text-decoration:none; line-height:1;
  background:linear-gradient(180deg,var(--gold-2),var(--gold) 40%,var(--gold-deep));
  box-shadow:var(--glow-gold); transition:transform .15s ease, box-shadow .15s ease, filter .15s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); filter:brightness(1.05); color:#1a1305;
  box-shadow:0 16px 40px -10px #f2a516aa; }
.btn:active{ transform:translateY(0); }
.btn--lg{ font-size:1.12rem; padding:1.05em 2.1em; }
.btn--ghost{
  background:transparent; color:var(--text);
  border:1px solid var(--line); box-shadow:none;
}
.btn--ghost:hover{ border-color:var(--blue); color:#fff; background:#0f1830; }
.btn--blue{
  background:linear-gradient(180deg,var(--blue-2),var(--blue) 45%,var(--blue-deep));
  color:#04101f; box-shadow:0 12px 34px -10px #155fceaa;
}
.btn--blue:hover{ color:#04101f; }

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:#080c17e6; backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-soft);
}
.header-inner{ display:flex; align-items:center; gap:18px; min-height:66px; }
.brand{ display:flex; align-items:center; gap:11px; flex:0 0 auto; }
.brand__mark{ width:34px; height:34px; flex:0 0 auto; filter:drop-shadow(0 0 10px #2ea6ff66); }
.brand__name{ font-family:var(--ff-display); font-weight:800; font-size:1.28rem; color:#fff; letter-spacing:-.02em; }
.brand__name b{ color:var(--gold); font-weight:800; }

.nav{ display:flex; gap:6px; margin-left:8px; flex-wrap:wrap; }
.nav a{
  color:var(--muted); font-weight:600; font-size:.95rem;
  padding:.45em .7em; border-radius:8px;
}
.nav a:hover{ color:#fff; background:#13203b; }
.header-cta{ margin-left:auto; flex:0 0 auto; }

/* ---------- hero / top bonus banner ---------- */
.hero{
  position:relative; overflow:hidden;
  border-bottom:1px solid var(--line-soft);
  background:
    radial-gradient(620px 320px at 85% 18%, #1d4fb340, transparent 62%),
    linear-gradient(180deg,#0b1326,#080c17);
}
.hero::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    repeating-linear-gradient(115deg, #ffffff05 0 2px, transparent 2px 9px);
  opacity:.5;
}
.hero-inner{ position:relative; z-index:1; padding:46px 0 52px;
  display:grid; grid-template-columns:1.25fr .85fr; gap:34px; align-items:center; }
.bonus-card{
  background:linear-gradient(165deg,#16223f,#0e1729);
  border:1px solid var(--line); border-radius:22px;
  padding:30px 30px 28px; box-shadow:var(--glow-blue);
}
.eyebrow{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--ff-display); font-weight:700; font-size:.78rem;
  letter-spacing:.12em; text-transform:uppercase; color:var(--gold);
  background:#3a2c0833; border:1px solid #f2a51640; padding:.4em .8em; border-radius:999px;
}
.bonus-card__head{
  font-family:var(--ff-display); font-weight:800; color:#fff;
  font-size:clamp(1.9rem,5.2vw,3rem); line-height:1.05; margin:.5em 0 .15em; letter-spacing:-.02em;
}
.bonus-card__head .amt{
  background:linear-gradient(180deg,var(--gold-2),var(--gold-deep));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.bonus-card__sub{ color:var(--muted); font-size:1.02rem; margin:.2em 0 1.1em; max-width:46ch; }
.bonus-card__row{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.bonus-card__fine{ color:var(--muted-2); font-size:.8rem; margin-top:1em; }

.hero-badges{ display:grid; gap:12px; }
.hbadge{
  display:flex; align-items:center; gap:14px;
  background:#0f1830; border:1px solid var(--line); border-radius:14px; padding:14px 16px;
}
.hbadge .ic{ width:38px; height:38px; flex:0 0 auto; color:var(--blue); }
.hbadge b{ display:block; font-family:var(--ff-display); color:#fff; font-size:1.02rem; }
.hbadge span{ color:var(--muted); font-size:.88rem; }

/* ---------- providers chips ---------- */
.providers{ border-bottom:1px solid var(--line-soft); background:#0a1020; }
.providers .wrap{ padding-block:20px; }
.providers__label{ color:var(--muted-2); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:10px; font-weight:700; }
.chips{ display:flex; flex-wrap:wrap; gap:9px; }
.chip{
  font-size:.85rem; color:var(--muted); font-weight:600;
  border:1px solid var(--line); background:#0f1830; padding:.42em .9em; border-radius:999px;
}

/* ---------- layout ---------- */
.layout{ display:grid; grid-template-columns:260px 1fr; gap:40px; align-items:start; padding:40px 0 20px; }
.toc{ position:sticky; top:84px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:18px 18px 14px; }
.toc__title{ font-family:var(--ff-display); font-weight:700; font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.toc ol{ margin:0; padding:0; list-style:none; counter-reset:toc; }
.toc li{ counter-increment:toc; margin:.15em 0; }
.toc a{ display:block; color:var(--muted); font-size:.92rem; padding:.32em .2em; border-radius:6px; }
.toc a::before{ content:counter(toc,decimal-leading-zero) " · "; color:var(--blue); font-weight:700; }
.toc a:hover{ color:#fff; }

.article{ min-width:0; max-width:780px; }
.article h1{
  font-size:clamp(2rem,6vw,3.1rem); margin:0 0 .25em; letter-spacing:-.025em;
}
.article h1 .star{ color:var(--gold); }
.lede{ font-size:1.18rem; color:#cdd9ef; margin-bottom:1.2em; }

.rating{ display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:14px 18px; margin:0 0 1.6em; }
.rating__score{ font-family:var(--ff-display); font-weight:800; font-size:1.7rem; color:#fff; }
.rating__score b{ color:var(--gold); }
.stars{ color:var(--gold); letter-spacing:2px; font-size:1.1rem; }
.rating__txt{ color:var(--muted); font-size:.9rem; }

/* ---------- tables ---------- */
.table-wrap{ overflow-x:auto; -webkit-overflow-scrolling:touch; border:1px solid var(--line);
  border-radius:var(--radius); margin:1.2em 0 1.6em; background:var(--surface); }
table{ width:100%; border-collapse:collapse; min-width:560px; font-size:.95rem; }
caption{ caption-side:top; text-align:left; color:var(--muted-2); font-size:.82rem; padding:10px 14px 0; }
th,td{ padding:12px 16px; text-align:left; border-bottom:1px solid var(--line); vertical-align:top; }
thead th{ background:#0f1830; color:#fff; font-family:var(--ff-display); font-weight:700; font-size:.86rem;
  letter-spacing:.02em; position:sticky; top:0; }
tbody tr:last-child td{ border-bottom:0; }
tbody tr:hover td{ background:#0f18301a; }
td b, th b{ color:#fff; }
.scroll-hint{ display:none; color:var(--muted-2); font-size:.78rem; margin:-.6em 0 1.4em; }

/* ---------- pros / cons ---------- */
.pc-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:1.2em 0 1.6em; }
.pc{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:18px 20px; }
.pc--pro{ border-top:3px solid var(--green); }
.pc--con{ border-top:3px solid var(--red); }
.pc h3{ margin:.1em 0 .6em; font-size:1.05rem; }
.pc ul{ margin:0; padding:0; list-style:none; }
.pc li{ position:relative; padding-left:26px; margin:.45em 0; font-size:.95rem; color:#d8e1f2; }
.pc--pro li::before{ content:"✓"; position:absolute; left:0; color:var(--green); font-weight:800; }
.pc--con li::before{ content:"✕"; position:absolute; left:0; color:var(--red); font-weight:800; }

/* ---------- generic card grids (small, capped) ---------- */
.cards{ display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:16px; margin:1.2em 0 1.6em; }
.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:18px; }
.card__ic{ width:40px; height:40px; color:var(--blue); margin-bottom:10px; }
.card__title{ font-family:var(--ff-display); font-weight:700; color:#fff; font-size:1.05rem; margin:0 0 .35em; }
.card p{ margin:0; font-size:.92rem; color:var(--muted); }

/* game tiles (no images, text + css) */
.games{ display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:14px; margin:1.2em 0 1.6em; }
.game{
  position:relative; border-radius:14px; padding:16px 16px 14px; overflow:hidden;
  background:linear-gradient(160deg,#1b2949,#101a30);
  border:1px solid var(--line);
}
.game::before{ content:""; position:absolute; right:-26px; top:-26px; width:90px; height:90px; border-radius:50%;
  background:radial-gradient(circle,#2ea6ff55,transparent 70%); }
.game__tag{ font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); font-weight:700; }
.game__name{ font-family:var(--ff-display); font-weight:700; color:#fff; font-size:1.02rem; margin:.3em 0 .2em; position:relative; }
.game__meta{ font-size:.82rem; color:var(--muted); position:relative; }

/* ---------- mid bonus strip ---------- */
.strip{
  display:flex; align-items:center; gap:22px; flex-wrap:wrap;
  background:linear-gradient(100deg,#1a3a78,#0f2350 60%,#142a55);
  border:1px solid #2c63c0; border-radius:18px; padding:22px 26px; margin:2em 0;
  box-shadow:var(--glow-blue); position:relative; overflow:hidden;
}
.strip::after{ content:"★"; position:absolute; right:-6px; bottom:-26px; font-size:120px; color:#ffffff0d; line-height:1; }
.strip__txt{ flex:1 1 320px; position:relative; }
.strip__txt b{ font-family:var(--ff-display); font-size:1.35rem; color:#fff; display:block; }
.strip__txt span{ color:#cbd9f2; font-size:.95rem; }
.strip .btn{ position:relative; }

/* ---------- step list ---------- */
.steps{ counter-reset:step; list-style:none; margin:1.2em 0 1.6em; padding:0; }
.steps li{ counter-increment:step; position:relative; padding:0 0 16px 56px; }
.steps li::before{
  content:counter(step); position:absolute; left:0; top:-2px;
  width:38px; height:38px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--ff-display); font-weight:800; color:#04101f;
  background:linear-gradient(180deg,var(--blue-2),var(--blue-deep)); box-shadow:0 6px 18px -6px #155fce;
}
.steps li::after{ content:""; position:absolute; left:18px; top:38px; bottom:6px; width:2px; background:var(--line); }
.steps li:last-child::after{ display:none; }
.steps b{ color:#fff; font-family:var(--ff-display); }

/* ---------- callout ---------- */
.note{ background:#0f1830; border-left:3px solid var(--gold); border-radius:0 12px 12px 0; padding:14px 18px; margin:1.2em 0; color:#d8e1f2; font-size:.95rem; }

/* ---------- FAQ accordion (no JS) ---------- */
.faq{ margin:1em 0 1.4em; }
.faq details{ border:1px solid var(--line); border-radius:12px; background:var(--surface); margin-bottom:10px; overflow:hidden; }
.faq summary{
  list-style:none; cursor:pointer; padding:16px 50px 16px 18px; position:relative;
  font-family:var(--ff-display); font-weight:600; color:#fff; font-size:1.02rem;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:"+"; position:absolute; right:18px; top:50%; transform:translateY(-50%);
  width:26px; height:26px; border:1px solid var(--line); border-radius:50%;
  display:grid; place-items:center; color:var(--gold); font-size:1.2rem; transition:transform .2s;
}
.faq details[open] summary::after{ content:"–"; }
.faq summary:hover{ color:var(--gold-2); }
.faq__body{ padding:0 18px 16px; color:#cdd9ef; font-size:.95rem; }

/* ---------- footer ---------- */
.site-footer{ background:#070a13; border-top:1px solid var(--line-soft); margin-top:50px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:30px; padding:44px 0 26px; }
.footer-col .ftitle{ font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); margin:0 0 14px; }
.footer-col a{ display:block; color:var(--muted); font-size:.93rem; padding:.22em 0; }
.footer-col a:hover{ color:#fff; }
.footer-about p{ color:var(--muted); font-size:.92rem; max-width:40ch; }
.foot-badges{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.foot-badge{ font-size:.72rem; font-weight:700; color:var(--muted); border:1px solid var(--line); border-radius:8px; padding:.4em .7em; }
.footer-bottom{ border-top:1px solid var(--line-soft); padding:18px 0 30px; color:var(--muted-2); font-size:.84rem; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; }

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; }
  .hero-badges{ grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); }
  .layout{ grid-template-columns:1fr; }
  .toc{ position:static; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .nav{ display:none; }
  .header-cta .btn{ padding:.7em 1.1em; font-size:.9rem; }
  .pc-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .scroll-hint{ display:block; }
  .hero-inner{ padding:32px 0 38px; }
  .bonus-card{ padding:24px 20px; }
  .strip{ padding:20px; }
}
@media (prefers-reduced-motion:reduce){
  *{ scroll-behavior:auto; transition:none !important; }
}
