/* ============================================================
   Canplay Casino — canplaycasinocanadaplay.com
   Stylesheet (separated from HTML). Gold on charcoal.
   ============================================================ */

:root{
  --bg:#0d1117;
  --bg-2:#141b23;
  --panel:#171f29;
  --panel-2:#1d2732;
  --line:#28323d;
  --gold:#f5b921;
  --gold-2:#ffd24a;
  --gold-soft:#ffe27a;
  --gold-deep:#c8901a;
  --text:#eef2f6;
  --muted:#9fadba;
  --good:#46c285;
  --warn:#ff8a5c;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 18px 40px -22px rgba(0,0,0,.85);
  --maxw:1140px;
  --font:"Segoe UI",Roboto,"Helvetica Neue",Arial,system-ui,sans-serif;
  --font-display:"Segoe UI",Roboto,Georgia,system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(245,185,33,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(245,185,33,.06), transparent 55%),
    var(--bg);
  color:var(--text);
  font-family:var(--font);
  font-size:17px;
  line-height:1.68;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
a{color:var(--gold-2)}

/* ---------- headings ---------- */
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.18;color:var(--text);font-weight:800;letter-spacing:.2px}
h1{font-size:clamp(2rem,5.4vw,3.3rem);margin:.2em 0 .35em}
h2{font-size:clamp(1.5rem,3.2vw,2.15rem);margin:1.9em 0 .5em;position:relative;padding-left:18px}
h2::before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:6px;border-radius:4px;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold-deep))}
h3{font-size:clamp(1.15rem,2.2vw,1.4rem);margin:1.5em 0 .4em;color:var(--gold-2)}
p{margin:0 0 1.05em}
.lead{font-size:1.12rem;color:#dde4ec}
.muted{color:var(--muted)}
section{scroll-margin-top:84px}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(13,17,23,.82);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text)}
.brand .logo-svg{flex:0 0 auto}
.brand .brand-text{display:flex;flex-direction:column;line-height:1}
.brand .brand-text b{font-size:1.18rem;font-weight:800;letter-spacing:.3px}
.brand .brand-text span{font-size:.72rem;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-top:3px}
.nav{display:flex;gap:22px;align-items:center}
.nav a{color:var(--muted);text-decoration:none;font-size:.95rem;font-weight:600}
.nav a:hover{color:var(--gold-2)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border:0;cursor:pointer;font-family:inherit;font-weight:800;
  padding:14px 26px;border-radius:999px;font-size:1.02rem;
  color:#241a02;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold) 55%,var(--gold-deep));
  box-shadow:0 12px 26px -12px rgba(245,185,33,.8), inset 0 1px 0 rgba(255,255,255,.5);
  text-decoration:none;transition:transform .12s ease, box-shadow .12s ease, filter .12s ease;
  letter-spacing:.3px;
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.05);box-shadow:0 16px 30px -12px rgba(245,185,33,.95)}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:3px solid var(--gold-2);outline-offset:3px}
.btn.ghost{background:transparent;color:var(--gold-2);border:2px solid var(--gold-deep);box-shadow:none;padding:12px 24px}
.btn.ghost:hover{background:rgba(245,185,33,.08)}
.btn.sm{padding:10px 18px;font-size:.92rem}
.btn.big{padding:17px 38px;font-size:1.12rem}
.nav .btn{color:#241a02}

/* ---------- hero ---------- */
.hero{padding:46px 0 8px}
/* top bonus banner — above everything */
.hero-bonus{
  position:relative;overflow:hidden;border-radius:var(--radius);
  background:
    radial-gradient(700px 240px at 90% 0%, rgba(255,210,74,.18), transparent 60%),
    linear-gradient(135deg,#1c130a,#241a08 45%,#15110a);
  border:1px solid #4a3a14;
  box-shadow:var(--shadow);
  padding:30px clamp(20px,4vw,46px);
}
.hero-bonus .ribbon{
  display:inline-block;font-size:.74rem;letter-spacing:2.5px;text-transform:uppercase;
  color:#241a02;background:linear-gradient(90deg,var(--gold-soft),var(--gold));
  padding:5px 14px;border-radius:999px;font-weight:800;margin-bottom:14px;
}
.hero-bonus h1{margin-top:.1em}
.hero-bonus .offer{
  display:flex;flex-wrap:wrap;align-items:center;gap:14px 26px;margin:14px 0 6px;
}
.offer .amt{font-size:clamp(1.6rem,4.4vw,2.6rem);font-weight:900;color:var(--gold-2);text-shadow:0 2px 0 rgba(0,0,0,.4)}
.offer .plus{font-size:1.1rem;color:var(--muted)}
.offer .spins{font-size:clamp(1.2rem,3vw,1.7rem);font-weight:800;color:var(--gold-soft)}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:18px}
.hero-cta .terms{font-size:.82rem;color:var(--muted);max-width:420px}
.trust-row{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:22px;color:var(--muted);font-size:.9rem}
.trust-row span{display:inline-flex;align-items:center;gap:8px}
.tick{width:18px;height:18px;flex:0 0 auto}

/* ---------- generic panels ---------- */
.panel{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:var(--radius);padding:24px clamp(18px,3vw,30px);box-shadow:var(--shadow)}
.section-intro{max-width:760px}

/* ---------- quick facts table / tables ---------- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:var(--radius);margin:8px 0 4px;box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse;min-width:560px;background:var(--panel)}
caption{caption-side:top;text-align:left;color:var(--muted);font-size:.86rem;padding:10px 14px}
th,td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
thead th{background:var(--panel-2);color:var(--gold-2);font-size:.82rem;letter-spacing:1px;text-transform:uppercase}
tbody tr:hover{background:rgba(245,185,33,.04)}
td:first-child,th:first-child{font-weight:700;color:#dfe6ee}
.scroll-hint{font-size:.8rem;color:var(--muted);margin:6px 2px 0}

/* ---------- step cards ---------- */
.steps{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:8px}
.step{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px 18px 20px;position:relative}
.step .n{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;font-weight:900;color:#241a02;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold-deep));margin-bottom:10px}
.step h3{margin:.1em 0 .3em;font-size:1.08rem}
.step p{margin:0;font-size:.96rem;color:var(--muted)}

/* ---------- feature cards row (>2 per row, kept small) ---------- */
.cards{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));margin-top:10px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:20px;transition:transform .12s ease,border-color .12s ease}
.card:hover{transform:translateY(-3px);border-color:var(--gold-deep)}
.card .ic{width:42px;height:42px;margin-bottom:10px}
.card h3{margin:.1em 0 .35em;font-size:1.1rem}
.card p{margin:0;font-size:.95rem;color:var(--muted)}

/* ---------- mid bonus strip ---------- */
.bonus-strip{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;
  border-radius:var(--radius);padding:22px clamp(18px,3vw,30px);margin:26px 0;
  background:
    radial-gradient(500px 200px at 100% 0%, rgba(255,210,74,.16), transparent 60%),
    linear-gradient(120deg,#2a1d08,#3a2a0c 60%,#22180a);
  border:1px solid #5a4516;box-shadow:var(--shadow);
}
.bonus-strip .txt b{display:block;font-size:1.25rem;color:var(--gold-2)}
.bonus-strip .txt span{color:#e6decb;font-size:.96rem}

/* ---------- two-column compare ---------- */
.two-col{display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-top:8px}
.col{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:20px 22px}
.col.good{border-top:3px solid var(--good)}
.col.note{border-top:3px solid var(--warn)}
.col h3{margin-top:0}
.col ul{margin:0;padding-left:0;list-style:none}
.col li{position:relative;padding:7px 0 7px 28px;border-bottom:1px dashed var(--line);font-size:.97rem}
.col li:last-child{border-bottom:0}
.col li::before{position:absolute;left:0;top:7px;font-weight:900}
.col.good li::before{content:"✓";color:var(--good)}
.col.note li::before{content:"!";color:var(--warn)}

/* ---------- FAQ accordion (no JS, native details) ---------- */
.faq{display:grid;gap:12px;margin-top:8px}
details.faq-item{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
details.faq-item summary{
  cursor:pointer;list-style:none;padding:17px 52px 17px 20px;font-weight:700;position:relative;font-size:1.04rem;color:#eaf0f6;
}
details.faq-item summary::-webkit-details-marker{display:none}
details.faq-item summary::after{
  content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);
  font-size:1.5rem;color:var(--gold);font-weight:800;transition:transform .2s ease;line-height:1;
}
details.faq-item[open] summary::after{content:"–"}
details.faq-item[open] summary{color:var(--gold-2)}
.faq-body{padding:0 20px 18px;color:var(--muted);border-top:1px solid var(--line)}
.faq-body p{margin:14px 0 0}

/* ---------- ratings ---------- */
.ratings{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:8px}
.rate{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px}
.rate .label{font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.rate .bar{height:9px;border-radius:6px;background:#222c37;margin:9px 0 6px;overflow:hidden}
.rate .bar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--gold-deep),var(--gold-soft))}
.rate .score{font-weight:900;color:var(--gold-2);font-size:1.05rem}

/* ---------- footer ---------- */
.site-footer{margin-top:48px;border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(0,0,0,.25))}
.footer-inner{display:grid;gap:26px;grid-template-columns:1.4fr 1fr 1fr;padding:38px 20px;max-width:var(--maxw);margin:0 auto}
.site-footer h4{color:var(--gold-2);font-size:.95rem;letter-spacing:1px;text-transform:uppercase;margin:0 0 12px}
.site-footer p{color:var(--muted);font-size:.92rem}
.foot-links{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.foot-links button{
  background:none;border:0;color:var(--muted);font:inherit;font-size:.92rem;cursor:pointer;padding:0;text-align:left;
}
.foot-links button:hover{color:var(--gold-2)}
.age{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:50%;border:2px solid var(--warn);color:var(--warn);font-weight:900;font-size:.95rem;flex:0 0 auto}
.rg-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.legal{border-top:1px solid var(--line);padding:18px 20px;text-align:center;color:var(--muted);font-size:.84rem}

/* ---------- helpers ---------- */
.eyebrow{display:inline-block;font-size:.74rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:800;margin-bottom:6px}
.spacer{height:6px}
.icon-gold{color:var(--gold)}

/* ---------- responsive ---------- */
@media (max-width:880px){
  .nav{display:none}
  .two-col{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  body{font-size:16px}
  .footer-inner{grid-template-columns:1fr}
  .bonus-strip{flex-direction:column;align-items:flex-start}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%}
  .offer{gap:10px 16px}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto;transition:none!important}
}
