/* ──────────────────────────────────────────────────────────
   Casino Atlas — base reset + tokens + 3 themes
   themes: editorial | dark | brutalist
   ────────────────────────────────────────────────────────── */

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
img,svg{display:block;max-width:100%}
a{color:inherit}
button{font:inherit;cursor:pointer}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}

/* ── default theme: EDITORIAL LIGHT ─────────────────────── */
:root, body[data-theme="editorial"]{
  --bg:        #f4efe6;
  --bg-elev:   #fbf7ef;
  --bg-card:   #ffffff;
  --ink:       #1c1a16;
  --ink-2:     #3a3530;
  --ink-3:     #6b645a;
  --rule:      #d9d2c4;
  --rule-2:    #ece6d8;
  --accent:    #2a4d3e;        /* deep forest */
  --accent-ink:#ffffff;
  --warn:      #8a3a2a;
  --star:      #2a4d3e;
  --pill-bg:   #f6f1e6;
  --pill-bd:   #d9d2c4;
  --shadow:    0 1px 0 rgba(0,0,0,.04), 0 24px 60px -28px rgba(28,26,22,.18);

  --font-display: "Instrument Serif", "Iowan Old Style", "Apple Garamond", Georgia, serif;
  --font-body:    "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono:    "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --radius:        14px;
  --radius-sm:     8px;
  --container:     1180px;
  --container-pad: clamp(16px, 4vw, 36px);
}

/* ── theme: MODERN DARK ─────────────────────────────────── */
body[data-theme="dark"]{
  --bg:        #0e0f12;
  --bg-elev:   #15171c;
  --bg-card:   #181b22;
  --ink:       #f1ede4;
  --ink-2:     #c8c3b7;
  --ink-3:     #8a8478;
  --rule:      #262932;
  --rule-2:    #1d2027;
  --accent:    #c9ff5e;        /* sharp lime */
  --accent-ink:#0e0f12;
  --warn:      #ff9a7a;
  --star:      #c9ff5e;
  --pill-bg:   #1c1f27;
  --pill-bd:   #2a2d36;
  --shadow:    0 0 0 1px rgba(255,255,255,.02), 0 30px 60px -30px rgba(0,0,0,.6);

  --font-display: "Space Grotesk", -apple-system, system-ui, sans-serif;
  --font-body:    "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* ── theme: BRUTALIST MONO ──────────────────────────────── */
body[data-theme="brutalist"]{
  --bg:        #f6f4ef;
  --bg-elev:   #ffffff;
  --bg-card:   #ffffff;
  --ink:       #0a0a0a;
  --ink-2:     #1f1f1f;
  --ink-3:     #6b6b6b;
  --rule:      #0a0a0a;
  --rule-2:    #d8d6d0;
  --accent:    #ff5b1f;        /* sharp orange */
  --accent-ink:#0a0a0a;
  --warn:      #b73a1a;
  --star:      #0a0a0a;
  --pill-bg:   #ffffff;
  --pill-bd:   #0a0a0a;
  --shadow:    4px 4px 0 0 #0a0a0a;

  --font-display: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --font-body:    "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --radius:      0;
  --radius-sm:   0;
}

/* ── base typography ────────────────────────────────────── */
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--container-pad);
}
h1,h2,h3,h4{font-family:var(--font-display); font-weight:500; letter-spacing:-.01em; color:var(--ink); margin:0;}
h2{font-size:clamp(28px, 3.4vw, 44px); line-height:1.1; text-wrap:balance}
h3{font-size:clamp(22px, 2.2vw, 28px); line-height:1.15; text-wrap:balance}
p{margin:0 0 .8em}
em{font-style:italic}
body[data-theme="brutalist"] h1, body[data-theme="brutalist"] h2, body[data-theme="brutalist"] h3{
  font-weight:600; letter-spacing:-.02em; text-transform:none;
}
body[data-theme="dark"] h1, body[data-theme="dark"] h2, body[data-theme="dark"] h3{
  letter-spacing:-.02em;
}

/* ───────── HEADER ───────── */
.site-header{
  position:sticky; top:0; z-index:50;
  background:color-mix(in oklab, var(--bg) 88%, transparent);
  backdrop-filter: saturate(150%) blur(10px);
  -webkit-backdrop-filter: saturate(150%) blur(10px);
  border-bottom:1px solid var(--rule-2);
}
body[data-theme="brutalist"] .site-header{
  background:var(--bg); backdrop-filter:none; -webkit-backdrop-filter:none;
  border-bottom:1.5px solid var(--ink);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; min-height:68px;
}
.brand{
  display:inline-flex; align-items:center; gap:10px;
  text-decoration:none; color:var(--ink);
}
.brand-mark{
  display:inline-grid; place-items:center;
  width:34px; height:34px; border-radius:50%;
  background:var(--accent); color:var(--accent-ink);
}
body[data-theme="brutalist"] .brand-mark{border-radius:0; border:1.5px solid var(--ink); background:var(--bg-elev); color:var(--ink)}
.brand-word{font-family:var(--font-display); font-size:22px; letter-spacing:-.01em}
.brand-word em{font-style:italic; color:var(--ink-2)}
body[data-theme="brutalist"] .brand-word em{font-style:normal; text-decoration:underline; text-underline-offset:3px}

.primary-nav{display:flex; gap:6px}
.primary-nav a{
  text-decoration:none; color:var(--ink-2);
  padding:8px 12px; border-radius:999px; font-size:14.5px; font-weight:500;
  transition: background .15s, color .15s;
}
.primary-nav a:hover{background:var(--rule-2); color:var(--ink)}
body[data-theme="brutalist"] .primary-nav a{border-radius:0; padding:6px 10px}
body[data-theme="brutalist"] .primary-nav a:hover{background:var(--ink); color:var(--bg-elev)}

.burger{
  display:none; appearance:none; border:0; background:transparent;
  width:44px; height:44px; padding:0; position:relative;
}
.burger span{
  position:absolute; left:10px; right:10px; height:1.5px; background:var(--ink);
  transition: transform .2s, opacity .2s, top .2s;
}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:21px}
.burger span:nth-child(3){top:26px}
.burger[aria-expanded="true"] span:nth-child(1){top:21px; transform:rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){top:21px; transform:rotate(-45deg)}

/* mobile menu — slides from top */
.mobile-menu{
  position:fixed; top:68px; left:0; right:0;
  background:var(--bg-elev);
  border-bottom:1px solid var(--rule);
  transform: translateY(-105%);
  transition: transform .28s ease;
  z-index:49;
  max-height:calc(100vh - 68px); overflow:auto;
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu-inner{
  display:flex; flex-direction:column;
  padding:14px var(--container-pad) 28px;
  max-width:var(--container); margin:0 auto;
}
.mobile-menu-inner a{
  text-decoration:none; color:var(--ink);
  padding:14px 4px; border-bottom:1px solid var(--rule-2);
  font-size:18px; font-family:var(--font-display);
}
.mobile-menu-inner a:last-child{border-bottom:0}
.mobile-menu-inner hr{border:0; border-top:1px solid var(--rule); margin:14px 0 0}

/* ───────── HERO ───────── */
.hero{padding:clamp(40px, 7vw, 96px) 0 clamp(32px, 5vw, 64px)}
.hero-grid{
  display:grid; grid-template-columns: minmax(0,1.5fr) minmax(0,1fr);
  gap: clamp(28px, 5vw, 64px); align-items:end;
}
.hero-cta{
  display:inline-flex; align-items:center; gap:8px;
  margin-top:24px; padding:14px 24px;
  background:var(--accent); color:var(--accent-ink);
  border-radius:999px; text-decoration:none; font-weight:600; font-size:15px;
  border:0; transition: transform .12s, filter .12s;
}
.hero-cta:hover{filter:brightness(1.05); transform: translateY(-1px)}
.hero-cta svg{width:14px; height:14px}
body[data-theme="brutalist"] .hero-cta{border-radius:0; border:1.5px solid var(--ink); box-shadow:3px 3px 0 var(--ink)}
.hero-cta-row{display:flex; gap:12px; flex-wrap:wrap; align-items:center; margin-top:24px}
.hero-cta-row .hero-cta{margin-top:0}
.hero-cta-row .hero-cta.secondary{
  background:transparent; color:var(--ink);
  border:1px solid var(--rule);
}
.hero-cta-row .hero-cta.secondary:hover{border-color:var(--accent); color:var(--ink)}
body[data-theme="brutalist"] .hero-cta-row .hero-cta.secondary{border-width:1.5px; box-shadow:none}
.eyebrow{
  font-size:13px; color:var(--ink-3); margin-bottom:18px;
  display:inline-flex; align-items:center; gap:8px;
  letter-spacing:.02em;
}
.eyebrow .dot{
  width:7px; height:7px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 4px color-mix(in oklab, var(--accent) 18%, transparent);
}
body[data-theme="brutalist"] .eyebrow{text-transform:uppercase; letter-spacing:.08em}
body[data-theme="brutalist"] .eyebrow .dot{border-radius:0}

.display{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(40px, 6.5vw, 76px);
  line-height:1.02; letter-spacing:-.02em;
  margin:0 0 22px; text-wrap:balance;
}
.display em{color:var(--accent); font-style:italic}
body[data-theme="brutalist"] .display{
  font-weight:600; line-height:.98; letter-spacing:-.04em;
}
body[data-theme="brutalist"] .display em{font-style:normal; background:var(--accent); padding:0 .15em; color:var(--accent-ink)}

.lede{
  font-size:clamp(16px, 1.4vw, 19px); color:var(--ink-2);
  max-width:62ch; margin-bottom:24px;
}
.hero-pills{display:flex; flex-wrap:wrap; gap:8px}
.pill{
  display:inline-flex; align-items:center; gap:7px;
  font-size:13px; padding:7px 12px;
  background:var(--pill-bg); border:1px solid var(--pill-bd);
  border-radius:999px; color:var(--ink-2);
}
body[data-theme="brutalist"] .pill{border-radius:0; border-width:1.5px}

.hero-aside{align-self:stretch}
.hero-figure{
  margin:0; position:relative;
  border-radius:var(--radius); overflow:hidden;
  background:var(--bg-elev); box-shadow:var(--shadow);
  aspect-ratio: 4/5;
}
.hero-figure img{width:100%; height:100%; object-fit:cover; filter:saturate(.8) brightness(.92)}
body[data-theme="brutalist"] .hero-figure{
  border:1.5px solid var(--ink); box-shadow:var(--shadow);
}
.hero-figure figcaption{
  position:absolute; left:14px; right:14px; bottom:14px;
  display:flex; flex-direction:column; gap:6px;
  background:color-mix(in oklab, var(--bg) 92%, transparent);
  border:1px solid var(--rule);
  padding:14px 16px; border-radius:var(--radius-sm);
  backdrop-filter: blur(6px);
}
body[data-theme="brutalist"] .hero-figure figcaption{background:var(--bg-elev); border-width:1.5px}
.figcap-k{font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3)}
.figcap-v{font-size:13.5px; color:var(--ink-2); line-height:1.5}

/* ───────── LIST SECTION ───────── */
.list-section{padding: clamp(32px, 5vw, 64px) 0}
.section-head{
  display:flex; align-items:end; justify-content:space-between; gap:24px;
  margin-bottom: clamp(24px, 3vw, 36px);
  padding-bottom:18px; border-bottom:1px solid var(--rule-2);
}
.section-eyebrow{
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-3); margin:0 0 6px;
}
.section-note{
  font-size:13.5px; color:var(--ink-3); max-width:34ch; margin:0;
  text-align:right;
}

.casino-list{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:14px;
  counter-reset: casino;
}

/* ───── compact casino card — desktop ───── */
.casino-card{
  background:var(--bg-card);
  border:1px solid var(--rule-2);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  counter-increment: casino;
  overflow:hidden;
  transition: border-color .15s;
}
.casino-card:hover{border-color:var(--rule)}
body[data-theme="brutalist"] .casino-card{border:1.5px solid var(--ink)}

.card-main{
  display:grid;
  grid-template-columns: 44px 88px minmax(200px, 1fr) 130px 64px 150px;
  align-items:center;
  gap:18px;
  padding:18px 20px;
}
.card-num{
  font-family:var(--font-mono);
  font-size:13px; color:var(--ink-3);
}
body[data-theme="brutalist"] .card-num{font-size:14px; color:var(--ink)}
.card-num::before{content:counter(casino, decimal-leading-zero)}

/* brand logo tile — white background by default so transparent-bg logos
   render cleanly across themes; per-brand logoBg override via inline style */
.card-logo{
  display:flex; align-items:center; justify-content:center;
  width:88px; height:64px;
  background:#ffffff;
  border:1px solid var(--rule-2);
  border-radius:var(--radius-sm);
  overflow:hidden;
  padding:8px 10px;
  flex-shrink:0;
  transition: transform .15s, border-color .15s;
}
.card-logo:hover{transform: translateY(-1px); border-color:var(--rule)}
.card-logo img{
  max-width:100%; max-height:100%;
  width:auto; height:auto;
  object-fit:contain;
}
body[data-theme="brutalist"] .card-logo{border:1.5px solid var(--ink); border-radius:0}
.card-logo-fallback{
  background:var(--bg-elev);
  border:1px solid var(--rule);
  font-family:var(--font-display);
  font-size:22px; color:var(--ink);
  letter-spacing:-.02em;
}
body[data-theme="dark"] .card-logo-fallback{background:var(--bg-elev); color:var(--ink)}
body[data-theme="brutalist"] .card-logo-fallback{background:var(--bg-elev); border:1.5px solid var(--ink)}

.card-id{display:flex; flex-direction:column; gap:6px; min-width:0}
.card-name{
  font-family:var(--font-display);
  font-size:clamp(20px, 1.8vw, 24px);
  line-height:1.1; color:var(--ink);
  margin:0;
}
.card-desc{
  font-size:13.5px; color:var(--ink-3);
  line-height:1.45; margin:0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden;
}

/* reserved bonus slot — empty by default; show small bonus line below name when populated */
.card-bonus{
  display:none;
  font-size:12.5px; color:var(--accent);
  font-weight:600;
  margin-top:2px;
}
.casino-card[data-has-bonus] .card-bonus{display:block}

.card-rating{display:flex; flex-direction:column; align-items:center; gap:2px}
.stars{
  display:inline-flex; gap:2px; color:var(--star);
  font-size:14px; line-height:1;
}
.stars .s{position:relative; width:14px; height:14px}
.stars .s svg{position:absolute; inset:0}
.stars .s.empty{color:var(--rule)}
.rating-label{font-size:11px; color:var(--ink-3); letter-spacing:.04em}

.card-score{
  font-family:var(--font-display);
  font-size:32px; line-height:1; color:var(--ink);
  text-align:center;
}
body[data-theme="brutalist"] .card-score{font-weight:600}
.card-score small{display:block; font-size:11px; color:var(--ink-3); letter-spacing:.06em; margin-top:4px; font-family:var(--font-body)}

.card-cta{display:flex; justify-content:flex-end}
.btn-visit{
  display:inline-flex; align-items:center; gap:6px;
  background:var(--accent); color:var(--accent-ink);
  border:0; border-radius:999px;
  padding:12px 20px; font-weight:600; font-size:14px;
  text-decoration:none;
  transition: transform .12s, filter .12s;
  white-space:nowrap;
}
.btn-visit:hover{filter:brightness(1.05); transform: translateY(-1px)}
.btn-visit svg{width:13px; height:13px}
body[data-theme="brutalist"] .btn-visit{
  border-radius:0; border:1.5px solid var(--ink);
  box-shadow:3px 3px 0 var(--ink);
}
body[data-theme="brutalist"] .btn-visit:hover{transform: translate(-1px,-1px); box-shadow:4px 4px 0 var(--ink)}

.card-disclaim{
  padding:10px 20px 14px;
  border-top:1px dashed var(--rule-2);
  font-size:11.5px; color:var(--ink-3);
  line-height:1.5;
}
body[data-theme="brutalist"] .card-disclaim{border-top-style:solid; border-top-width:1px}

/* ───── casino card — mobile ───── */
@media (max-width: 800px){
  .card-main{
    grid-template-columns: 64px 1fr;
    grid-template-areas:
      "logo  id"
      "stars score"
      "cta   cta";
    gap:14px; padding:16px;
  }
  .card-num{display:none}
  .card-logo{
    grid-area:logo;
    width:64px; height:64px;
    padding:6px 8px;
  }
  .card-id{grid-area:id}
  .card-id::before{
    content:counter(casino, decimal-leading-zero);
    display:block;
    font-family:var(--font-mono);
    font-size:11px; color:var(--ink-3);
    letter-spacing:.04em; margin-bottom:2px;
  }
  .card-name{font-size:19px}
  .card-desc{-webkit-line-clamp:3}
  .card-rating{grid-area:stars; flex-direction:row; gap:8px; align-items:center; justify-self:start}
  .rating-label{display:none}
  .card-score{grid-area:score; text-align:right; font-size:28px; display:flex; align-items:baseline; gap:6px; justify-content:flex-end}
  .card-score small{display:inline; margin:0}
  .card-cta{grid-area:cta}
  .btn-visit{width:100%; justify-content:center; padding:14px 18px}
  .card-disclaim{padding:12px 18px 16px}
}

/* ───────── EDITORIAL ───────── */
.editorial{
  padding: clamp(40px, 6vw, 88px) 0;
  background:var(--bg-elev);
  border-top:1px solid var(--rule-2);
  border-bottom:1px solid var(--rule-2);
}
.editorial-grid{
  display:grid;
  grid-template-columns: 220px minmax(0,1fr);
  gap: clamp(28px, 5vw, 80px);
}
.toc{
  position:sticky; top:88px; align-self:start;
  font-size:13.5px;
}
.toc-label{
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-3); margin:0 0 12px;
}
.toc ol{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:4px;
  counter-reset: toc;
}
.toc ol li{counter-increment: toc; position:relative; padding-left:28px}
.toc ol li::before{
  content:counter(toc, decimal-leading-zero);
  position:absolute; left:0; top:6px;
  font-family:var(--font-mono); font-size:11px; color:var(--ink-3);
}
.toc a{
  text-decoration:none; color:var(--ink-2);
  display:block; padding:6px 0; line-height:1.3;
  border-bottom:1px solid var(--rule-2);
}
.toc a:hover{color:var(--ink)}

.editorial-body article{
  padding: 0 0 clamp(28px, 3.5vw, 44px);
  margin-bottom: clamp(28px, 3.5vw, 44px);
  border-bottom:1px solid var(--rule-2);
}
.editorial-body article:last-child{border-bottom:0; margin-bottom:0}
.editorial-body h3{margin:0 0 14px}
.editorial-body p{font-size:16.5px; line-height:1.65; color:var(--ink-2); max-width:68ch}
.criteria{margin:0; display:grid; gap:14px}
.criteria > div{
  display:grid; grid-template-columns: 220px 1fr; gap:24px;
  padding:14px 0; border-top:1px solid var(--rule-2);
}
.criteria > div:first-child{border-top:0; padding-top:0}
.criteria dt{font-family:var(--font-display); font-size:18px; color:var(--ink); margin:0}
.criteria dd{margin:0; color:var(--ink-2); font-size:15.5px; line-height:1.55}

@media (max-width: 900px){
  .editorial-grid{grid-template-columns:1fr}
  .toc{position:static}
  .toc ol{flex-direction:row; flex-wrap:wrap; gap:8px}
  .toc ol li{padding-left:0; border:1px solid var(--rule-2); border-radius:999px; padding:6px 12px; background:var(--bg)}
  .toc ol li::before{display:none}
  .toc a{border:0; padding:0; font-size:13px}
  body[data-theme="brutalist"] .toc ol li{border-radius:0; border-width:1.5px}
  .criteria > div{grid-template-columns:1fr; gap:6px}
}

/* ───────── FAQ ───────── */
.faq{padding: clamp(40px, 6vw, 80px) 0}
.faq-list{display:flex; flex-direction:column; gap:0; border-top:1px solid var(--rule-2)}
.faq-list details{
  border-bottom:1px solid var(--rule-2);
}
.faq-list summary{
  list-style:none; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding: 22px 4px; font-family:var(--font-display);
  font-size:clamp(18px, 1.5vw, 22px); color:var(--ink);
}
.faq-list summary::-webkit-details-marker{display:none}
.chev{
  width:22px; height:22px; flex-shrink:0; position:relative;
}
.chev::before, .chev::after{
  content:""; position:absolute; left:50%; top:50%; width:12px; height:1.5px;
  background:var(--ink-2); transform-origin:center;
  transition: transform .2s;
}
.chev::before{transform: translate(-50%,-50%)}
.chev::after{transform: translate(-50%,-50%) rotate(90deg)}
details[open] .chev::after{transform: translate(-50%,-50%) rotate(0deg)}
.faq-body{padding: 0 4px 22px; max-width:68ch}
.faq-body p{margin:0; color:var(--ink-2); font-size:15.5px; line-height:1.6}

/* ───────── CONTACT ───────── */
.contact{padding: clamp(40px, 6vw, 80px) 0; border-top:1px solid var(--rule-2)}
.contact-grid{
  display:grid; grid-template-columns: minmax(0,1fr) minmax(0,1.1fr);
  gap: clamp(28px, 5vw, 64px);
}
.contact-text h2{margin:6px 0 14px}
.contact-text p{font-size:16px; color:var(--ink-2); max-width:42ch}
.contact-email{
  margin-top:24px;
  display:flex; flex-direction:column; gap:4px;
  padding:18px 20px; background:var(--bg-elev); border:1px solid var(--rule-2);
  border-radius:var(--radius);
}
.contact-email span{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3)}
.contact-email a{font-family:var(--font-display); font-size:24px; color:var(--ink); text-decoration:none}
body[data-theme="brutalist"] .contact-email{border-width:1.5px; border-color:var(--ink)}

.contact-form{
  display:flex; flex-direction:column; gap:14px;
  background:var(--bg-elev); padding:clamp(20px, 3vw, 32px);
  border:1px solid var(--rule-2); border-radius:var(--radius);
}
body[data-theme="brutalist"] .contact-form{border-width:1.5px; border-color:var(--ink)}
.contact-form .form-row{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.contact-form label{
  display:flex; flex-direction:column; gap:6px;
  font-size:12px; color:var(--ink-3); letter-spacing:.04em; text-transform:uppercase;
}
.contact-form input, .contact-form textarea{
  font:inherit; font-size:15px; text-transform:none; letter-spacing:0;
  padding:12px 14px;
  background:var(--bg-card); color:var(--ink);
  border:1px solid var(--rule); border-radius:var(--radius-sm);
  width:100%;
}
.contact-form input:focus, .contact-form textarea:focus{
  outline:none; border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 20%, transparent);
}
.contact-form textarea{resize:vertical; min-height:120px}
.contact-form .form-foot{display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:4px}
.contact-form button{
  background:var(--accent); color:var(--accent-ink); border:0;
  padding:13px 24px; border-radius:999px; font-weight:600;
  transition:filter .15s, transform .12s;
}
.contact-form button:hover{filter:brightness(1.05); transform:translateY(-1px)}
body[data-theme="brutalist"] .contact-form button{border-radius:0; border:1.5px solid var(--ink); box-shadow:3px 3px 0 var(--ink)}
.thanks{font-size:14px; color:var(--accent); margin:0}

@media (max-width: 800px){
  .contact-grid{grid-template-columns:1fr}
  .contact-form .form-row{grid-template-columns:1fr}
}

/* ───────── FOOTER ───────── */
.site-footer{
  padding: clamp(40px, 5vw, 72px) 0 clamp(28px, 4vw, 44px);
  border-top:1px solid var(--rule);
  background:var(--bg-elev);
}
body[data-theme="brutalist"] .site-footer{border-top-width:1.5px; border-top-color:var(--ink)}
.footer-top{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; flex-wrap:wrap; padding-bottom:28px; border-bottom:1px solid var(--rule-2);
}
.brand-footer .brand-mark{width:30px; height:30px}
.brand-footer .brand-word{font-size:20px}
.footer-nav{display:flex; flex-wrap:wrap; gap:6px 4px}
.footer-nav a{
  text-decoration:none; color:var(--ink-2);
  padding:6px 10px; font-size:13.5px; border-radius:999px;
}
.footer-nav a:hover{background:var(--rule-2); color:var(--ink)}
body[data-theme="brutalist"] .footer-nav a{border-radius:0}
body[data-theme="brutalist"] .footer-nav a:hover{background:var(--ink); color:var(--bg-elev)}

.footer-disclosure{padding:28px 0; border-bottom:1px solid var(--rule-2)}
.footer-disclosure h3{font-size:18px; margin:0 0 12px}
.footer-disclosure p{font-size:13.5px; color:var(--ink-3); line-height:1.6; max-width:84ch}

.footer-partners{
  display:flex; flex-wrap:wrap; gap:14px; align-items:center;
  padding: 28px 0;
  border-bottom:1px solid var(--rule-2);
}
.footer-partner-logo{
  display:flex; align-items:center; justify-content:center;
  height:60px; min-width:90px;
  padding: 10px 18px;
  background:#ffffff;
  border-radius:var(--radius-sm);
  border:1px solid var(--rule-2);
}
.footer-partner-logo img{max-height:38px; width:auto; display:block}
.footer-partner-logo a{display:inline-flex; align-items:center; height:100%}
/* 18+ badge is colourful on its own, doesn't need the white tile */
.footer-partner-logo:has(img[src*="18plus"]){background:transparent; border:0; padding:0; min-width:60px}
.footer-partner-logo:has(img[src*="18plus"]) img{max-height:60px}
body[data-theme="brutalist"] .footer-partner-logo{border:1.5px solid var(--ink); border-radius:0}

/* per-partner branded tiles: transparent + brand-colour border */
.footer-partner-logo:has(img[src*="gambleaware"]){
  background:transparent; border:1.5px solid #ff6a13;
}
.footer-partner-logo:has(img[src*="gamcare"]){
  background:transparent; border:1.5px solid #1aa3d9;
}
.partner-fallback{
  display:inline-flex; align-items:center; height:38px; padding:0 14px;
  font-family:var(--font-mono); font-size:12px; color:#444;
  letter-spacing:.04em;
}

.footer-base{
  display:flex; justify-content:space-between; gap:16px;
  flex-wrap:wrap; padding-top:24px;
}
.footer-base p{margin:0; font-size:12.5px; color:var(--ink-3); letter-spacing:.02em}
.footer-base-r{color:var(--ink-3)}

/* ── responsive: tablet & mobile ────────────────────────── */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr; align-items:start}
  .hero-figure{aspect-ratio: 16/10}
  .hero-figure img{height:100%}
}
@media (max-width: 760px){
  .primary-nav{display:none}
  .burger{display:inline-flex; align-items:center; justify-content:center}
  .section-head{flex-direction:column; align-items:flex-start; gap:8px}
  .section-note{text-align:left; max-width:none}
  .footer-top{flex-direction:column; align-items:flex-start; gap:18px}
  .footer-nav{gap:2px}

  /* compact hero on phones — keep the casino list close to the fold */
  .hero{padding:18px 0 22px}
  .hero-grid{gap:18px}
  .hero-text .eyebrow{margin-bottom:10px; font-size:12px}
  .display{font-size:32px; line-height:1.05; margin-bottom:12px}
  .lede{font-size:14.5px; line-height:1.5; margin-bottom:14px}
  .hero-pills{gap:6px}
  .hero-pills .pill{font-size:11.5px; padding:5px 9px}
  .hero-cta-row{margin-top:14px; gap:8px}
  .hero-cta{padding:11px 18px; font-size:14px}
  .hero-aside{display:none}

  /* compact section heads on phones */
  .list-section{padding:24px 0}
  .section-head{margin-bottom:16px; padding-bottom:12px}

  /* compact inner-page hero */
  .page-hero{padding:18px 0 16px}
  .page-hero h1{font-size:30px; line-height:1.06; margin-bottom:10px}
  .page-hero .lede{font-size:14.5px; margin-bottom:12px}
  .page-hero .crumbs{margin-bottom:12px; font-size:11px}
  .page-hero .meta{font-size:11px; gap:10px; padding-top:8px; margin-top:14px}
  .category-points{padding:20px 0}
}
@media (max-width: 480px){
  .header-inner{min-height:60px}
  .mobile-menu{top:60px; max-height: calc(100vh - 60px)}
  .hero{padding:14px 0 18px}
  .display{font-size:28px}
  .lede{font-size:14px}
  .page-hero h1{font-size:26px}
  .footer-partners{gap:14px 20px}
  .footer-partner-logo{height:52px; min-width:80px}
  .footer-partner-logo img{max-height:32px}
}

/* prevent body scroll when menu open */
body.menu-open{overflow:hidden}

/* ────────────────────────────────────────────────────────
   INNER PAGES — category & info / legal
   ──────────────────────────────────────────────────────── */

/* Page hero (smaller than home hero) */
.page-hero{
  padding: clamp(36px, 6vw, 72px) 0 clamp(24px, 4vw, 40px);
  border-bottom:1px solid var(--rule-2);
}
.page-hero .crumbs{
  font-family:var(--font-mono); font-size:12px; color:var(--ink-3);
  margin-bottom:18px; letter-spacing:.04em;
}
.page-hero .crumbs a{color:inherit; text-decoration:none}
.page-hero .crumbs a:hover{color:var(--ink-2)}
.page-hero .crumbs span{margin:0 6px; color:var(--ink-3); opacity:.6}
.page-hero h1{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(36px, 5.5vw, 64px); line-height:1.04; letter-spacing:-.02em;
  margin:0 0 16px; max-width:22ch; text-wrap:balance;
}
.page-hero h1 em{color:var(--accent); font-style:italic}
body[data-theme="brutalist"] .page-hero h1{font-weight:600}
body[data-theme="brutalist"] .page-hero h1 em{font-style:normal; background:var(--accent); padding:0 .15em; color:var(--accent-ink)}
.page-hero .lede{
  font-size:clamp(15.5px, 1.3vw, 18px); color:var(--ink-2);
  max-width:62ch; margin-bottom:20px;
}
.page-hero .meta{
  display:flex; gap:18px; flex-wrap:wrap;
  font-family:var(--font-mono); font-size:12px; color:var(--ink-3);
  letter-spacing:.04em; padding-top:8px;
  border-top:1px solid var(--rule-2); margin-top:24px;
}
.page-hero .meta span strong{color:var(--ink-2); font-weight:500; margin-right:6px}

/* Info / legal page layout — TOC + prose */
.info-page{padding: clamp(32px, 5vw, 64px) 0}
.info-grid{
  display:grid;
  grid-template-columns: 220px minmax(0,1fr);
  gap: clamp(28px, 5vw, 80px);
}
.info-prose h2{
  font-size:clamp(22px, 2vw, 28px);
  margin: clamp(28px, 3vw, 40px) 0 12px;
  scroll-margin-top: 90px;
}
.info-prose h2:first-child{margin-top:0}
.info-prose h3{font-size:18px; margin: 22px 0 8px}
.info-prose p, .info-prose li{
  font-size:16px; line-height:1.65; color:var(--ink-2); max-width:68ch;
}
.info-prose ul, .info-prose ol{padding-left:1.2em; margin: 0 0 1em}
.info-prose li{margin-bottom:.4em}
.info-prose strong{color:var(--ink)}
.info-prose a{color:var(--accent); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px}
body[data-theme="brutalist"] .info-prose a{color:var(--ink); background:var(--accent); padding:0 .2em; text-decoration:none}
.info-prose hr{border:0; border-top:1px solid var(--rule-2); margin:32px 0}
.info-prose .callout{
  background:var(--bg-elev); border:1px solid var(--rule-2);
  border-left:3px solid var(--accent);
  padding:16px 20px; border-radius:var(--radius-sm);
  margin: 18px 0;
}
body[data-theme="brutalist"] .info-prose .callout{border-width:1.5px; border-left-width:6px; border-radius:0}
.info-prose .callout p{margin:0; color:var(--ink-2); font-size:14.5px}

@media (max-width: 900px){
  .info-grid{grid-template-columns:1fr}
  .info-prose h2{scroll-margin-top: 70px}
}

/* Category page: "Why X" small grid before the casino list */
.category-points{
  padding: clamp(28px, 4vw, 48px) 0;
  border-bottom:1px solid var(--rule-2);
}
.points-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(14px, 2vw, 22px);
}
.point{
  padding:20px 22px;
  background:var(--bg-elev); border:1px solid var(--rule-2);
  border-radius:var(--radius);
}
body[data-theme="brutalist"] .point{border-width:1.5px; border-radius:0}
.point .point-k{
  font-family:var(--font-mono); font-size:11px; color:var(--ink-3);
  letter-spacing:.08em; text-transform:uppercase; margin:0 0 8px;
}
.point h3{
  font-size:18px; margin:0 0 6px; line-height:1.25;
}
.point p{margin:0; font-size:14px; color:var(--ink-3); line-height:1.55}

@media (max-width: 720px){
  .points-grid{grid-template-columns:1fr}
}

/* Contact page email card (large) */
.email-card{
  display:grid; grid-template-columns: 1fr auto; align-items:center; gap:24px;
  padding: clamp(24px, 3vw, 36px);
  background:var(--bg-elev); border:1px solid var(--rule-2);
  border-radius:var(--radius); margin-bottom: 36px;
}
body[data-theme="brutalist"] .email-card{border-width:1.5px; border-color:var(--ink); border-radius:0}
.email-card .k{
  font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3);
  margin:0 0 6px;
}
.email-card a{
  font-family:var(--font-display);
  font-size:clamp(22px, 2.4vw, 30px); color:var(--ink);
  text-decoration:none; word-break:break-all;
}
.email-card .copy-btn{
  appearance:none; border:1px solid var(--rule); background:var(--bg-card); color:var(--ink-2);
  padding:10px 16px; border-radius:999px; font-size:13px;
  cursor:pointer; white-space:nowrap;
}
.email-card .copy-btn:hover{border-color:var(--accent); color:var(--ink)}
body[data-theme="brutalist"] .email-card .copy-btn{border-radius:0; border-width:1.5px}
@media (max-width: 600px){
  .email-card{grid-template-columns:1fr}
  .email-card .copy-btn{justify-self:start}
}
