/* ===========================================================
   Casino Montreal - main.css
   Mobile-first, premium dark + gold casino theme
   =========================================================== */

:root{
  --bg:#0a0b0d;
  --bg-soft:#101216;
  --surface:#16181d;
  --surface-2:#1c1f26;
  --line:rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.16);

  --light:#dfe3e9;
  --light-2:#eef1f4;
  --card:#ffffff;
  --ink:#14161a;
  --ink-soft:#565c66;

  --cream:#ece1cf;
  --cream-2:#f4ecdd;
  --cream-ink:#23180a;

  --text:#f2f3f5;
  --muted:#9aa1ab;
  --muted-2:#cfd3da;

  --gold:#c8a24c;
  --gold-bright:#e9cd7e;
  --gold-grad:linear-gradient(180deg,#f0d792 0%,#d3a948 52%,#b9893a 100%);
  --gold-grad-hover:linear-gradient(180deg,#f6e0a3 0%,#dcb456 52%,#c5953f 100%);

  --green:#0b5e4e;
  --green-2:#0a4d40;

  --radius:14px;
  --radius-lg:20px;
  --radius-sm:9px;
  --shadow:0 18px 40px -22px rgba(0,0,0,.7);
  --shadow-soft:0 10px 30px -18px rgba(0,0,0,.55);
  --container:1200px;
  --header-h:72px;

  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  font-size:16px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
ul,ol{margin:0;padding:0}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}

/* eyebrow + styled (non-heading) section titles */
.eyebrow{
  display:inline-block;
  font-size:.74rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;
}
.section-title{
  font-weight:800;line-height:1.12;letter-spacing:-.01em;
  font-size:clamp(1.7rem,4.2vw,2.7rem);margin:0;
}
.section-sub{color:var(--muted);max-width:60ch;margin:14px auto 0;font-size:1.02rem}
.center{text-align:center}
.section{padding:clamp(54px,8vw,96px) 0}

/* ---------- Buttons ---------- */
.btn{
  --pad-y:14px;--pad-x:26px;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:var(--pad-y) var(--pad-x);
  border-radius:999px;border:0;cursor:pointer;
  font-weight:700;font-size:.98rem;letter-spacing:.01em;
  transition:transform .18s ease,box-shadow .25s ease,background .25s ease,color .2s ease;
  text-align:center;line-height:1;
}
.btn-gold{
  background:var(--gold-grad);color:#22180a;
  box-shadow:0 10px 26px -12px rgba(211,169,72,.7), inset 0 1px 0 rgba(255,255,255,.45);
}
.btn-gold:hover{background:var(--gold-grad-hover);transform:translateY(-2px);
  box-shadow:0 16px 32px -12px rgba(211,169,72,.8), inset 0 1px 0 rgba(255,255,255,.5)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-bright);transform:translateY(-2px)}
.btn-light{background:#fff;color:#15171b}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}
.btn-lg{--pad-y:17px;--pad-x:38px;font-size:1.06rem}
.btn-block{display:flex;width:100%}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(10,11,13,.86);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease,background .25s ease;
}
.site-header.scrolled{background:rgba(8,9,11,.96);box-shadow:0 12px 34px -22px rgba(0,0,0,.85)}
.header-inner{
  height:var(--header-h);display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.brand{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.brand img{height:42px;width:auto;filter:brightness(0) invert(1)}
.brand .brand-tag{display:none}

.main-nav{display:none}
.main-nav ul{display:flex;align-items:center;gap:6px;list-style:none}
.main-nav a{
  display:block;padding:9px 13px;border-radius:8px;
  font-size:.92rem;font-weight:600;color:var(--muted-2);
  transition:color .18s ease,background .18s ease;
}
.main-nav a:hover,.main-nav a.active{color:#fff;background:rgba(255,255,255,.06)}
.main-nav a.active{color:var(--gold-bright)}

.header-actions{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.header-cta{--pad-y:11px;--pad-x:20px;font-size:.9rem}

.burger{
  display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
  width:46px;height:42px;padding:0 11px;border-radius:10px;
  background:rgba(255,255,255,.06);border:1px solid var(--line);cursor:pointer;
}
.burger span{display:block;height:2px;width:100%;background:#fff;border-radius:2px;transition:transform .3s ease,opacity .2s ease}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.mobile-nav{
  position:fixed;inset:var(--header-h) 0 auto 0;z-index:55;
  background:#0c0e11;border-bottom:1px solid var(--line);
  max-height:0;overflow:hidden;transition:max-height .35s ease;
}
.mobile-nav.open{max-height:80vh;overflow:auto}
.mobile-nav ul{list-style:none;padding:10px 20px 22px}
.mobile-nav a{
  display:block;padding:14px 8px;font-size:1.02rem;font-weight:600;
  color:var(--muted-2);border-bottom:1px solid var(--line);
}
.mobile-nav a:hover,.mobile-nav a.active{color:var(--gold-bright)}
.mobile-nav .mn-cta{margin-top:18px}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  background-color:#0a0b0d;background-size:cover;background-position:center;background-repeat:no-repeat;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(90deg,rgba(8,8,9,.93) 0%,rgba(8,8,9,.6) 45%,rgba(8,8,9,.18) 100%);
}
.hero-inner{position:relative;z-index:1;display:grid;gap:30px;padding-block:clamp(48px,8vw,96px);align-items:center}
.hero-card{
  background:linear-gradient(165deg,var(--cream-2),var(--cream));
  color:var(--cream-ink);border-radius:var(--radius-lg);
  padding:clamp(26px,4.5vw,44px);box-shadow:var(--shadow);
  max-width:560px;border:1px solid rgba(0,0,0,.06);
}
.hero-card .eyebrow{color:#9a6b1e}
.hero-offer{
  font-weight:900;line-height:.95;letter-spacing:-.02em;
  font-size:clamp(2.7rem,9vw,4.6rem);margin:.1em 0 .12em;
  background:linear-gradient(180deg,#15110a,#5a431d);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-kicker{font-weight:800;font-size:clamp(1.15rem,3.4vw,1.6rem);line-height:1.15;margin:0 0 10px;color:#1c1407}
.hero-desc{font-size:1rem;color:#4a3a22;margin:0 0 22px}
.hero-card .btn{width:100%}
.hero-fine{font-size:.76rem;margin-top:14px;color:#7a6647}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.hero-badge{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;font-weight:600;color:#5b4827}

/* ---------- Steps ---------- */
.steps{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.steps-grid{display:grid;gap:18px;margin-top:40px}
.step{
  position:relative;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:26px 22px;transition:border-color .2s ease,transform .2s ease;
}
.step:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.step-num{
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  font-weight:800;font-size:1.1rem;color:#22180a;background:var(--gold-grad);margin-bottom:16px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4);
}
.step h3,.step .step-t{font-size:1.06rem;font-weight:700;margin:0 0 7px}
.step p{margin:0;color:var(--muted);font-size:.94rem}

/* ---------- Slots showcase ---------- */
.slots{background:var(--bg);position:relative}
.slots-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:38px;
}
.slot-card{
  position:relative;display:block;border-radius:var(--radius);overflow:hidden;
  background:var(--surface-2);border:1px solid var(--line);
  aspect-ratio:4/5;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;
}
.slot-card img{width:100%;height:100%;object-fit:cover}
.slot-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 45%,rgba(0,0,0,.82));opacity:.9;
}
.slot-meta{
  position:absolute;left:0;right:0;bottom:0;z-index:2;padding:12px 13px;
  transform:translateY(4px);transition:transform .22s ease;
}
.slot-name{font-weight:700;font-size:.86rem;line-height:1.2;margin:0;color:#fff;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.slot-prov{font-size:.7rem;color:var(--gold-bright);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.slot-play{
  position:absolute;z-index:3;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .22s ease;
}
.slot-play span{
  background:var(--gold-grad);color:#22180a;font-weight:700;font-size:.84rem;
  padding:9px 18px;border-radius:999px;box-shadow:var(--shadow-soft);
}
.slot-card:hover{transform:translateY(-5px);border-color:var(--gold);box-shadow:0 22px 40px -24px rgba(0,0,0,.9)}
.slot-card:hover .slot-play{opacity:1}
.slot-card:hover .slot-meta{transform:translateY(0)}
.slots-cta{margin-top:34px;text-align:center}

/* ---------- Play band ---------- */
.playband{
  position:relative;text-align:center;
  background:radial-gradient(120% 130% at 50% -10%,#1a1c22 0%,#0a0b0d 60%);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:clamp(40px,6vw,68px) 0;
}
.playband .pb-title{font-weight:800;font-size:clamp(1.4rem,4vw,2.1rem);margin:0 0 8px}
.playband p{color:var(--muted);margin:0 auto 24px;max-width:54ch}

/* ---------- Why choose (light) ---------- */
.why{background:linear-gradient(180deg,var(--light-2),var(--light));color:var(--ink)}
.why .section-title{color:var(--ink)}
.why .eyebrow{color:#a67c22}
.feature-grid{display:grid;gap:16px;margin-top:42px}
.feature-card{
  background:var(--card);border-radius:var(--radius);padding:24px 22px;
  box-shadow:0 14px 30px -24px rgba(20,30,50,.5);border:1px solid rgba(20,30,50,.06);
  display:flex;gap:16px;align-items:flex-start;transition:transform .2s ease,box-shadow .2s ease;
}
.feature-card:hover{transform:translateY(-4px);box-shadow:0 22px 40px -26px rgba(20,30,50,.55)}
.fc-icon{
  flex:0 0 auto;width:50px;height:50px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(180deg,#1b1d22,#0d0e11);color:var(--gold-bright);
}
.fc-icon svg{width:24px;height:24px}
.fc-title{font-weight:700;font-size:1.06rem;margin:0 0 5px;color:var(--ink)}
.fc-text{margin:0;color:var(--ink-soft);font-size:.94rem}

/* ---------- Highlights (3 dark cards) ---------- */
.highlights{background:var(--bg);border-top:1px solid var(--line)}
.hl-head{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:14px}
.hl-head img{height:34px;width:auto;flex:0 0 auto;filter:brightness(0) invert(1)}
.hl-head .hl-sep{width:1px;height:30px;background:var(--line-strong)}
.hl-head .hl-word{font-weight:800;letter-spacing:.18em;text-transform:uppercase;font-size:1rem;color:var(--gold-bright)}
.hl-grid{display:grid;gap:16px;margin-top:40px}
.hl-card{
  background:linear-gradient(180deg,var(--surface),#101217);
  border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;
  transition:transform .2s ease,border-color .2s ease;
}
.hl-card:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.hl-icon{width:54px;height:54px;border-radius:12px;display:grid;place-items:center;margin-bottom:18px;
  background:rgba(200,162,76,.12);color:var(--gold-bright)}
.hl-icon svg{width:26px;height:26px}
.hl-card h3,.hl-card .hl-t{font-size:1.18rem;font-weight:700;margin:0 0 9px}
.hl-card p{margin:0 0 16px;color:var(--muted);font-size:.95rem}
.hl-link{color:var(--gold-bright);font-weight:700;font-size:.9rem;display:inline-flex;gap:6px;align-items:center}
.hl-link:hover{color:#fff}
.hl-link svg{width:16px;height:16px}
.hl-foot{margin-top:34px;text-align:center}
.hl-foot a{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:4px;text-decoration-color:var(--gold)}

/* ---------- SEO content / prose ---------- */
.content{background:var(--bg-soft);border-top:1px solid var(--line)}
.prose{max-width:880px;margin:0 auto}
.prose h1{
  font-size:clamp(1.9rem,5vw,2.9rem);font-weight:800;line-height:1.12;letter-spacing:-.015em;
  margin:0 0 24px;
}
.prose h2{
  font-size:clamp(1.4rem,3.6vw,2rem);font-weight:800;line-height:1.2;
  margin:48px 0 16px;padding-top:22px;border-top:1px solid var(--line);
}
.prose h3{font-size:clamp(1.12rem,2.6vw,1.35rem);font-weight:700;margin:30px 0 12px;color:#fff}
.prose h1,.prose h2,.prose h3{scroll-margin-top:96px}
.prose p{margin:0 0 18px;color:var(--muted-2);font-size:1.02rem}
.prose strong{color:#fff;font-weight:700}
.prose a{color:var(--gold-bright);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(233,205,126,.4)}
.prose a:hover{text-decoration-color:var(--gold-bright)}
.prose ul,.prose ol{margin:0 0 20px;padding-left:0;list-style:none;display:grid;gap:10px}
.prose ul li{position:relative;padding-left:30px;color:var(--muted-2)}
.prose ul li::before{
  content:"";position:absolute;left:6px;top:.62em;width:8px;height:8px;border-radius:50%;
  background:var(--gold-grad);box-shadow:0 0 0 4px rgba(200,162,76,.12);
}
.prose ol{counter-reset:li}
.prose ol li{position:relative;padding-left:42px;counter-increment:li;color:var(--muted-2)}
.prose ol li::before{
  content:counter(li);position:absolute;left:0;top:.05em;width:28px;height:28px;border-radius:50%;
  display:grid;place-items:center;font-size:.82rem;font-weight:700;color:#22180a;background:var(--gold-grad);
}
.prose blockquote{
  margin:0 0 22px;padding:18px 22px;border-left:3px solid var(--gold);
  background:rgba(200,162,76,.07);border-radius:0 12px 12px 0;color:var(--muted-2);
}
.prose blockquote p:last-child{margin:0}

/* tables with horizontal scroll */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 0 24px;
  border:1px solid var(--line);border-radius:12px;background:var(--surface)}
.prose table{width:100%;border-collapse:collapse;min-width:560px;font-size:.92rem}
.prose thead th{
  background:var(--surface-2);color:#fff;font-weight:700;text-align:left;
  padding:13px 15px;border-bottom:1px solid var(--line-strong);white-space:nowrap;
}
.prose tbody td{padding:12px 15px;border-bottom:1px solid var(--line);color:var(--muted-2);vertical-align:top}
.prose tbody tr:last-child td{border-bottom:0}
.prose tbody tr:nth-child(even){background:rgba(255,255,255,.02)}

/* internal links row after content */
.related{margin-top:46px;padding-top:26px;border-top:1px solid var(--line)}
.related .eyebrow{display:block}
.related-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.related-grid a{
  padding:9px 16px;border-radius:999px;border:1px solid var(--line-strong);
  font-size:.88rem;font-weight:600;color:var(--muted-2);transition:.18s
}
.related-grid a:hover{color:var(--gold-bright);border-color:var(--gold)}

/* ---------- Footer ---------- */
.site-footer{background:#070809;border-top:1px solid var(--line);padding-top:clamp(48px,7vw,72px)}
.foot-cols{display:grid;gap:30px;grid-template-columns:repeat(2,1fr)}
.foot-col h4{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin:0 0 14px;font-weight:700}
.foot-col ul{list-style:none;display:grid;gap:10px}
.foot-col a{color:var(--muted);font-size:.9rem}
.foot-col a:hover{color:#fff}
.foot-brandrow{display:flex;flex-wrap:wrap;align-items:center;gap:20px;justify-content:space-between;
  margin-top:42px;padding-top:28px;border-top:1px solid var(--line)}
.foot-brand img{height:40px;width:auto;flex:0 0 auto;filter:brightness(0) invert(1)}
.socials{display:flex;gap:12px}
.socials a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.06);border:1px solid var(--line);color:#fff;transition:.2s}
.socials a:hover{background:var(--gold-grad);color:#22180a;border-color:transparent;transform:translateY(-2px)}
.socials svg{width:18px;height:18px}
.foot-legal{margin-top:26px;color:#7e858f;font-size:.82rem;line-height:1.7}
.foot-legal p{margin:0 0 12px}
.foot-badges{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-top:18px}
.badge-19{width:48px;height:48px;border-radius:50%;border:2px solid var(--gold);color:var(--gold-bright);
  display:grid;place-items:center;font-weight:800;font-size:.92rem;flex:0 0 auto}
.badge-pill{border:1px solid var(--line-strong);border-radius:8px;padding:8px 12px;font-size:.74rem;font-weight:600;color:var(--muted-2)}

/* responsible-gaming green bar */
.rg-bar{background:linear-gradient(90deg,var(--green),var(--green-2));color:#eafaf4}
.rg-inner{display:flex;flex-wrap:wrap;align-items:center;gap:10px 18px;padding-block:16px;font-size:.86rem;font-weight:500}
.rg-inner strong{font-weight:800;letter-spacing:.02em}
.rg-inner .rg-logo{display:inline-flex;align-items:center;gap:8px;font-weight:800}
.rg-inner .rg-logo svg{width:18px;height:18px}

/* ---------- 404 ---------- */
.notfound{min-height:62vh;display:grid;place-items:center;text-align:center;padding:80px 0}
.notfound .nf-code{font-size:clamp(5rem,18vw,9rem);font-weight:900;line-height:1;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.notfound h1{font-size:clamp(1.4rem,4vw,2rem);margin:6px 0 12px}
.notfound p{color:var(--muted);max-width:46ch;margin:0 auto 26px}
.nf-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---------- Responsive ---------- */
@media(min-width:560px){
  .steps-grid{grid-template-columns:repeat(2,1fr)}
  .slots-grid{grid-template-columns:repeat(3,1fr)}
  .hero-card .btn{width:auto}
}
@media(min-width:768px){
  :root{--header-h:78px}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .hl-grid{grid-template-columns:repeat(3,1fr)}
  .foot-cols{grid-template-columns:repeat(4,1fr)}
  .brand img{height:46px}
  .hero-inner{padding-block:clamp(64px,8vw,110px)}
}
@media(min-width:1000px){
  .main-nav{display:block}
  .burger{display:none}
  .steps-grid{grid-template-columns:repeat(4,1fr)}
  .slots-grid{grid-template-columns:repeat(6,1fr);gap:16px}
  .hero-inner{grid-template-columns:1.05fr .95fr}
  .hero-card{margin:0}
  .foot-cols{grid-template-columns:1.4fr 1fr 1fr 1fr}
}
@media(min-width:1200px){
  .slots-grid{grid-template-columns:repeat(6,1fr)}
}

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