/* =====================================================================
   North Casino Canada — style.css
   Brand: "Midnight Aurora" — night-sky navy, northern-lights teal/violet,
   gold value accent. North-star compass motif.
   ===================================================================== */

:root{
  --midnight:   #0B1020;
  --midnight-2: #111A33;
  --panel:      #15203F;
  --panel-2:    #1B2950;
  --line:       #27345C;
  --teal:       #2DE2C5;
  --teal-deep:  #16B79E;
  --violet:     #7C5CFF;
  --gold:       #F5C451;
  --gold-deep:  #D9A02E;
  --ink:        #EAF0FB;
  --muted:      #9AA6C4;
  --good:       #54E08B;
  --bad:        #FF7A85;
  --radius:     16px;
  --radius-sm:  10px;
  --wrap:       1140px;
  --shadow:     0 18px 48px rgba(0,0,0,.45);
  --display:    "Trebuchet MS", "Segoe UI", system-ui, -apple-system, sans-serif;
  --body:       "Segoe UI", system-ui, -apple-system, Roboto, Helvetica, Arial, sans-serif;
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  line-height:1.65;
  background:
    radial-gradient(1100px 520px at 80% -10%, rgba(124,92,255,.20), transparent 60%),
    radial-gradient(900px 480px at 5% 5%, rgba(45,226,197,.16), transparent 55%),
    var(--midnight);
  -webkit-font-smoothing:antialiased;
}

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

a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}

/* ----------------------- Typography ----------------------- */
h1,h2,h3{font-family:var(--display);line-height:1.15;letter-spacing:.2px;margin:0 0 .5em}
h1{font-size:clamp(28px,5vw,46px);font-weight:800}
h2{font-size:clamp(23px,3.4vw,34px);font-weight:800;margin-top:0}
h3{font-size:clamp(18px,2.2vw,22px);font-weight:700}
p{margin:0 0 1em}
.eyebrow{
  display:inline-block;font-family:var(--display);font-weight:700;
  text-transform:uppercase;letter-spacing:2.5px;font-size:12px;
  color:var(--teal);margin-bottom:14px;
}
.lede{font-size:clamp(16px,1.9vw,19px);color:#cdd6ec}

/* ----------------------- Buttons ----------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--display);font-weight:800;letter-spacing:.4px;
  border:0;cursor:pointer;border-radius:999px;padding:15px 30px;
  font-size:16px;line-height:1;color:#1a1205;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));
  box-shadow:0 12px 26px rgba(245,196,81,.32);
  transition:transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(245,196,81,.45);filter:brightness(1.04);text-decoration:none}
.btn:active{transform:translateY(0)}
.btn--ghost{
  background:transparent;color:var(--teal);
  border:1.5px solid var(--teal);box-shadow:none;
}
.btn--ghost:hover{background:rgba(45,226,197,.10);color:var(--ink)}
.btn--teal{
  color:#062019;
  background:linear-gradient(135deg,var(--teal),var(--teal-deep));
  box-shadow:0 12px 26px rgba(45,226,197,.30);
}
.btn--sm{padding:11px 20px;font-size:14px}
.btn:focus-visible{outline:3px solid var(--violet);outline-offset:3px}

/* ----------------------- Top ribbon bonus banner (above all) ----------------------- */
.ribbon{
  background:linear-gradient(90deg, rgba(124,92,255,.28), rgba(45,226,197,.20));
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(4px);
}
.ribbon__inner{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  gap:10px 18px;padding:11px 20px;text-align:center;
}
.ribbon p{margin:0;font-size:14.5px;color:#eef2ff}
.ribbon .flash{color:var(--gold);font-weight:800;letter-spacing:.4px}
.ribbon .btn{padding:10px 22px;font-size:14px}

/* ----------------------- Header ----------------------- */
.site-head{
  position:sticky;top:0;z-index:30;
  background:rgba(11,16,32,.78);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-head__row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand__mark{width:42px;height:42px;flex:0 0 auto;filter:drop-shadow(0 0 10px rgba(45,226,197,.5))}
.brand__name{font-family:var(--display);font-weight:800;letter-spacing:1.5px;line-height:1;text-transform:uppercase}
.brand__name b{display:block;font-size:18px;color:var(--ink)}
.brand__name span{display:block;font-size:11px;letter-spacing:3px;color:var(--teal)}
.nav{display:flex;gap:24px;align-items:center}
.nav a{color:var(--muted);font-weight:600;font-size:14.5px;letter-spacing:.3px}
.nav a:hover{color:var(--ink);text-decoration:none}
@media(max-width:860px){.nav{display:none}}

/* ----------------------- Hero ----------------------- */
.hero{position:relative;overflow:hidden;padding:54px 0 30px}
.hero::before{
  content:"";position:absolute;inset:auto 0 -40% 0;height:80%;
  background:radial-gradient(60% 100% at 50% 0%, rgba(45,226,197,.18), transparent 70%);
  pointer-events:none;
}
.hero__grid{display:grid;grid-template-columns:1.25fr .95fr;gap:34px;align-items:center}
.hero h1 b{color:var(--teal)}
.stat-row{display:flex;flex-wrap:wrap;gap:12px;margin:22px 0 26px}
.stat{
  background:rgba(21,32,63,.7);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:12px 16px;min-width:120px;
}
.stat b{display:block;font-family:var(--display);font-size:20px;color:var(--gold)}
.stat span{font-size:12.5px;color:var(--muted);letter-spacing:.4px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

/* Hero offer card */
.offer-card{
  position:relative;border-radius:var(--radius);padding:30px 26px;
  background:linear-gradient(160deg, var(--panel-2), var(--panel));
  border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden;
}
.offer-card::after{
  content:"";position:absolute;inset:-2px;border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg,var(--teal),var(--violet),transparent);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.8;
}
.offer-card .tag{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--teal);font-weight:700}
.offer-card .big{font-family:var(--display);font-weight:800;font-size:clamp(34px,6vw,52px);color:var(--gold);line-height:1;margin:8px 0 4px}
.offer-card .sub{color:#cdd6ec;margin-bottom:18px;font-size:15px}
.offer-card ul{list-style:none;margin:0 0 20px;padding:0}
.offer-card li{padding:6px 0 6px 26px;position:relative;font-size:14.5px;color:#dde4f5}
.offer-card li::before{content:"";position:absolute;left:0;top:11px;width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--teal),var(--teal-deep))}
.offer-card .btn{width:100%}
.offer-card .terms{margin:12px 0 0;font-size:11.5px;color:var(--muted);text-align:center}

@media(max-width:860px){.hero__grid{grid-template-columns:1fr;gap:26px}}

/* ----------------------- Sections ----------------------- */
section{padding:40px 0;border-top:1px solid rgba(39,52,92,.6)}
section.first{border-top:0}
.section-head{max-width:760px;margin-bottom:26px}

/* prose */
.prose p{color:#d4dcf0}
.prose h3{margin-top:1.3em;color:var(--ink)}

/* ----------------------- Cards grid ----------------------- */
.grid{display:grid;gap:18px}
.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:linear-gradient(160deg,var(--panel),var(--midnight-2));
  border:1px solid var(--line);border-radius:var(--radius);padding:22px 20px;
  transition:transform .18s ease,border-color .18s ease;
}
.card:hover{transform:translateY(-3px);border-color:var(--teal-deep)}
.card h3{margin-top:0;display:flex;align-items:center;gap:10px}
.card p{font-size:14.5px;color:#c8d2ea;margin-bottom:0}
.card .ic{width:34px;height:34px;flex:0 0 auto}
@media(max-width:920px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* ----------------------- CSS / SVG icon helpers ----------------------- */
.ic-circle{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:11px;flex:0 0 auto;
  background:rgba(45,226,197,.12);border:1px solid rgba(45,226,197,.3);
}

/* ----------------------- Strip bonus banner (mid content) ----------------------- */
.strip{
  margin:6px 0 0;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(100deg, rgba(124,92,255,.30), rgba(45,226,197,.22)), var(--panel);
  border:1px solid var(--line);box-shadow:var(--shadow);
}
.strip__inner{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  flex-wrap:wrap;padding:22px 26px;
}
.strip .copy b{font-family:var(--display);font-size:clamp(18px,2.6vw,24px);color:var(--gold);display:block}
.strip .copy span{color:#e7ecfb;font-size:14.5px}

/* ----------------------- Tables (responsive scroll) ----------------------- */
.table-scroll{
  width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;
  border:1px solid var(--line);border-radius:var(--radius);
  background:var(--midnight-2);
}
table{width:100%;border-collapse:collapse;min-width:560px}
caption{caption-side:bottom;text-align:left;color:var(--muted);font-size:12.5px;padding:10px 14px}
th,td{padding:13px 16px;text-align:left;font-size:14.5px;border-bottom:1px solid var(--line);vertical-align:top}
thead th{
  background:var(--panel-2);color:var(--teal);font-family:var(--display);
  font-size:13px;letter-spacing:1px;text-transform:uppercase;position:sticky;top:0;
}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:rgba(45,226,197,.05)}
td b{color:var(--gold)}
.scroll-hint{display:none;color:var(--muted);font-size:12.5px;margin:8px 2px 0}
@media(max-width:640px){.scroll-hint{display:block}}

/* ----------------------- Pros / Cons ----------------------- */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.pc{grid-template-columns:1fr}}
.pc .card ul{list-style:none;margin:0;padding:0}
.pc .card li{padding:7px 0 7px 28px;position:relative;font-size:14.5px;color:#d4dcf0}
.pc .pro li::before{content:"+";position:absolute;left:0;top:6px;color:var(--good);font-weight:900;font-size:17px}
.pc .con li::before{content:"–";position:absolute;left:2px;top:6px;color:var(--bad);font-weight:900;font-size:17px}

/* ----------------------- Steps ----------------------- */
.steps{counter-reset:step;display:grid;gap:14px}
.step{
  display:flex;gap:16px;align-items:flex-start;
  background:var(--midnight-2);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:16px 18px;
}
.step::before{
  counter-increment:step;content:counter(step);
  font-family:var(--display);font-weight:800;color:#062019;
  width:34px;height:34px;flex:0 0 auto;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--teal),var(--teal-deep));
}
.step h3{margin:0 0 3px;font-size:17px}
.step p{margin:0;font-size:14.5px;color:#c8d2ea}

/* ----------------------- FAQ accordion ----------------------- */
.faq details{
  border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--midnight-2);margin-bottom:12px;overflow:hidden;
}
.faq summary{
  list-style:none;cursor:pointer;padding:17px 52px 17px 20px;position:relative;
  font-family:var(--display);font-weight:700;font-size:16px;color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);
  font-size:24px;color:var(--teal);transition:transform .2s ease;line-height:1;
}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{color:var(--teal)}
.faq .answer{padding:0 20px 18px;color:#cfd8ee;font-size:14.8px}
.faq .answer p{margin:0}
.faq summary:focus-visible{outline:3px solid var(--violet);outline-offset:-3px}

/* ----------------------- Footer ----------------------- */
.site-foot{border-top:1px solid var(--line);background:var(--midnight-2);padding:40px 0 28px;margin-top:10px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:26px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:22px}}
.site-foot h4{font-family:var(--display);font-size:14px;letter-spacing:1.4px;text-transform:uppercase;color:var(--teal);margin:0 0 12px}
.site-foot a{color:var(--muted);display:block;padding:4px 0;font-size:14px}
.site-foot a:hover{color:var(--ink)}
.rg{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  border:1px solid var(--line);background:var(--panel);border-radius:var(--radius-sm);
  padding:14px 18px;margin-top:18px;
}
.rg .age{
  font-family:var(--display);font-weight:800;font-size:15px;color:#062019;
  background:var(--gold);border-radius:8px;padding:6px 10px;flex:0 0 auto;
}
.rg p{margin:0;font-size:13px;color:var(--muted)}
.legal{margin-top:24px;padding-top:18px;border-top:1px solid var(--line);font-size:12.5px;color:var(--muted)}
.legal p{margin:0 0 8px}

/* ----------------------- Accessibility / motion ----------------------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
:focus-visible{outline:3px solid var(--violet);outline-offset:2px}
