/* =============================================================================
   WhaleLimits — site.css  (hand-written, no framework)
   Theme: "royal high-roller" — deep indigo + platinum + violet, serif display.
   DISTINCT from #01 (slate + cyan-green, all-sans) for footprint (§8).
   Same class names as 00-SHARED-partials (header/footer/rg/layout) + matrix tool.
   ============================================================================= */

:root {
  --ink-950:#080a1c; --ink-900:#0d1030; --ink-850:#141a3d; --ink-800:#1b2350;
  --ink-700:#2a3568; --ink-600:#3e4a80; --ink-500:#566392;
  --ink-400:#727fb0; --ink-300:#9aa6d4; --ink-200:#c6cdea; --ink-100:#e9ecf8; --ink-50:#f5f6fc;
  --violet-700:#5b46c9; --violet-600:#7a66e8; --violet-500:#9d8cff; --violet-400:#b6abff;
  --plat:#d8deec; --plat-dim:#aab3cf;
  --pos:#46d39a;  --pos-bg:#0d2a26;     /* no weekly cap / high — good */
  --cap:#f5b14a;  --cap-bg:#2a2110;     /* has cap — caution */
  --gold:#e7c873;                        /* premium accent for badges */
  --border:#26305c; --border-soft:#1a2148;
  --radius:14px; --radius-sm:9px;
  --shadow:0 1px 0 rgba(255,255,255,.04) inset, 0 14px 36px -16px rgba(0,0,0,.7);
  --maxw:1120px;
  --font-display:"Iowan Old Style","Palatino Linotype",Georgia,"Times New Roman",serif;
  --font-sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --font-mono:ui-monospace,"SFMono-Regular","Cascadia Code",Consolas,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;background:var(--ink-950);color:var(--ink-100)}
body{margin:0;font-family:var(--font-sans);font-size:17px;line-height:1.65;min-height:100vh;
  background:radial-gradient(1100px 560px at 78% -8%,rgba(157,140,255,.10),transparent 60%),
             radial-gradient(800px 500px at 10% 0%,rgba(70,211,154,.05),transparent 55%),var(--ink-950);
  text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--violet-400);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.18;font-weight:700;color:var(--ink-50);margin:0 0 .5em;letter-spacing:-.01em}
h1{font-size:clamp(1.9rem,4.6vw,2.85rem)}
h2{font-size:clamp(1.4rem,3vw,1.95rem);margin-top:1.4em}
h3{font-size:1.2rem;margin-top:1.3em;font-family:var(--font-sans);letter-spacing:-.01em}
p{margin:0 0 1rem}
strong{color:var(--ink-50)}
code,kbd,.mono,.num{font-family:var(--font-mono);font-size:.92em;font-variant-numeric:tabular-nums}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(16px,4vw,28px)}
:focus-visible{outline:2px solid var(--violet-500);outline-offset:2px;border-radius:4px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--violet-500);color:#0a0a1e;padding:.6rem 1rem;z-index:100;border-radius:0 0 8px 0;font-weight:700}
.skip-link:focus{left:0}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ---- header / nav ---- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(8,10,28,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;gap:1rem;min-height:62px}
.brand{display:flex;align-items:center;gap:.5rem;font-weight:800;color:var(--ink-50);letter-spacing:-.01em}
.brand:hover{text-decoration:none}
.brand-mark{color:var(--violet-500);font-size:1.05rem;filter:drop-shadow(0 0 7px rgba(157,140,255,.55))}
.brand-name{font-size:1.12rem;font-family:var(--font-display)}
.badge-18{display:inline-grid;place-items:center;min-width:34px;height:24px;padding:0 .4rem;border:1px solid var(--cap);color:var(--cap);
  border-radius:6px;font-size:.74rem;font-weight:800;letter-spacing:.02em;background:var(--cap-bg)}
.primary-nav{margin-left:auto;display:flex;align-items:center;gap:.3rem}
.nav-link,.nav-group>summary{display:inline-flex;align-items:center;gap:.3rem;padding:.5rem .65rem;border-radius:9px;color:var(--ink-200);
  font-size:.93rem;font-weight:600;cursor:pointer;white-space:nowrap}
.nav-link:hover,.nav-group>summary:hover{background:var(--ink-800);color:var(--ink-50);text-decoration:none}
.nav-link[aria-current],.nav-sub a[aria-current]{color:var(--violet-400)}
.nav-group{position:relative}
.nav-group>summary{list-style:none}
.nav-group>summary::-webkit-details-marker{display:none}
.nav-group>summary::after{content:"▾";font-size:.7rem;color:var(--ink-400)}
.nav-sub{list-style:none;margin:0;padding:.4rem;position:absolute;top:calc(100% + 6px);left:0;min-width:225px;
  background:var(--ink-850);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);display:none;z-index:60}
.nav-sub li{margin:0}
.nav-sub a{display:block;padding:.5rem .65rem;border-radius:8px;color:var(--ink-200);font-size:.92rem}
.nav-sub a:hover{background:var(--ink-800);color:var(--ink-50);text-decoration:none}
.nav-cta{display:inline-flex;align-items:center;padding:.55rem .95rem;border-radius:10px;font-weight:700;font-size:.93rem;
  background:linear-gradient(180deg,var(--violet-500),var(--violet-600));color:#0a0a1e;box-shadow:0 6px 18px -8px rgba(157,140,255,.7)}
.nav-cta:hover{text-decoration:none;filter:brightness(1.06)}
.burger,.nav-toggle{display:none}
@media (min-width:901px){.nav-group:hover>.nav-sub,.nav-group:focus-within>.nav-sub,.nav-group[open]>.nav-sub{display:block}}
@media (max-width:900px){
  .burger{appearance:none;-webkit-appearance:none;font:inherit;color:inherit;display:inline-flex;flex-direction:column;justify-content:center;gap:5px;margin-left:.5rem;width:42px;height:38px;
    border:1px solid var(--border);border-radius:9px;background:var(--ink-850);cursor:pointer}
  .burger span{height:2px;width:20px;margin-inline:auto;background:var(--ink-100);border-radius:2px}
  .badge-18{margin-left:auto}
  .primary-nav{display:none;position:fixed;inset:62px 0 0;z-index:60;flex-direction:column;align-items:stretch;gap:.15rem;
    background:var(--ink-900);border-top:1px solid var(--border);padding:1rem clamp(16px,4vw,28px) 2rem;overflow-y:auto}
  .nav-toggle[aria-expanded="true"]~.primary-nav{display:flex}
  .site-header{backdrop-filter:none;-webkit-backdrop-filter:none}
  .nav-link,.nav-group>summary{padding:.85rem .6rem;font-size:1.05rem;border-radius:10px}
  .nav-group{border-bottom:1px solid var(--border-soft)}
  .nav-sub{position:static;display:block;border:none;box-shadow:none;background:transparent;padding:.1rem 0 .6rem .6rem}
  .nav-group:not([open])>.nav-sub{display:none}
  .nav-cta{margin-top:.8rem;justify-content:center;padding:.85rem}
}

/* ---- sections / content ---- */
section{margin-block:clamp(2.4rem,6vw,4rem)}
.lead{font-size:1.16rem;color:var(--ink-200);max-width:64ch}
.eyebrow{text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;font-weight:700;color:var(--violet-400);margin:0 0 .6rem}
.prose{max-width:72ch}
.prose ul,.prose ol{padding-left:1.3rem;margin:0 0 1rem}
.prose li{margin:.3rem 0}
.muted{color:var(--ink-300)}
.center{text-align:center}
.hero{padding-top:clamp(2.4rem,7vw,4.4rem)}
.hero-grid{display:grid;gap:2rem;grid-template-columns:1.15fr .85fr;align-items:center}
@media (max-width:860px){.hero-grid{grid-template-columns:1fr}}
.hero .answer{background:var(--ink-850);border:1px solid var(--border);border-left:3px solid var(--violet-500);
  border-radius:var(--radius);padding:1.1rem 1.2rem;margin:1.2rem 0;font-size:1.02rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.3rem}
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.8rem 1.25rem;border-radius:11px;font-weight:700;border:1px solid transparent}
.btn-primary{background:linear-gradient(180deg,var(--violet-500),var(--violet-600));color:#0a0a1e;box-shadow:0 8px 22px -10px rgba(157,140,255,.7)}
.btn-primary:hover{text-decoration:none;filter:brightness(1.06)}
.btn-ghost{border-color:var(--border);color:var(--ink-100);background:var(--ink-850)}
.btn-ghost:hover{text-decoration:none;background:var(--ink-800)}

/* ---- cards ---- */
.card-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.card{background:var(--ink-850);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow)}
.card h3{margin-top:0}
.card.link-card{position:relative;transition:.18s}
.card.link-card:hover{border-color:var(--violet-600);transform:translateY(-2px)}
.link-card h3 a{color:var(--ink-50);text-decoration:none}
.link-card h3 a::after{content:"";position:absolute;inset:0}
.link-card:hover h3 a{color:var(--violet-400)}
.card .arrow{color:var(--violet-400);font-weight:700}
.tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--gold);
  border:1px solid #6a5a2a;border-radius:6px;padding:.12rem .45rem;background:#221c0e}

/* ---- tables / matrix ---- */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--ink-850)}
table{border-collapse:collapse;width:100%;min-width:560px;font-size:.94rem}
th,td{text-align:left;padding:.7rem .85rem;border-bottom:1px solid var(--border-soft);white-space:nowrap}
thead th{background:var(--ink-800);color:var(--ink-100);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;position:sticky;top:0}
tbody tr:hover{background:rgba(157,140,255,.05)}
td .num{color:var(--plat);font-variant-numeric:tabular-nums}
.verified{font-size:.78rem;color:var(--ink-300)}
/* sortable headers */
th.sortable{cursor:pointer;user-select:none}
th.sortable::after{content:"⇅";opacity:.4;margin-left:.35rem;font-size:.85em}
th.sort-asc::after{content:"↑";opacity:.9}
th.sort-desc::after{content:"↓";opacity:.9}
/* cap badges */
.cap-no,.cap-yes{display:inline-flex;align-items:center;gap:.35rem;padding:.18rem .55rem;border-radius:999px;font-weight:700;font-size:.82rem;border:1px solid}
.cap-no{color:var(--pos);background:var(--pos-bg);border-color:#1d5a47}
.cap-yes{color:var(--cap);background:var(--cap-bg);border-color:#6a5320}
.data-pending{color:var(--ink-400);font-style:italic;font-size:.86rem}
.src-link{display:inline-block;margin-top:.25rem;font-size:.72rem;font-weight:400;color:var(--ink-400);text-decoration:none;white-space:nowrap}
.src-link:hover{color:var(--violet-400);text-decoration:underline}
.matrix-table{table-layout:fixed;width:100%;min-width:0}
.matrix-table th,.matrix-table td{white-space:normal;overflow-wrap:anywhere;vertical-align:middle}
.matrix-table th:first-child,.matrix-table td:first-child{width:16%}
.matrix-table th:last-child,.matrix-table td:last-child{width:160px}
.matrix-visit{padding:.5rem .5rem;font-size:.82rem;width:100%;justify-content:center;min-width:0;box-sizing:border-box;white-space:nowrap}
@media (max-width:760px){
  .matrix-table thead{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
  .matrix-table,.matrix-table tbody,.matrix-table tr,.matrix-table td{display:block;width:auto}
  .matrix-table tr{border:1px solid var(--border);border-radius:var(--radius);margin:0 0 .8rem;padding:.3rem .1rem;background:var(--ink-850)}
  .matrix-table td{display:flex;justify-content:space-between;align-items:center;gap:1rem;border:none;padding:.45rem .9rem;text-align:right}
  .matrix-table td::before{content:attr(data-label);font-weight:700;color:var(--ink-300);font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;text-align:left}
  .matrix-table td:first-child{font-size:1.05rem;border-bottom:1px solid var(--border-soft);margin-bottom:.25rem;padding-bottom:.6rem}
  .matrix-table td:first-child::before,.matrix-table td.visit-cell::before{content:none}
  .matrix-table td.visit-cell{padding-top:.7rem}
  .table-wrap{overflow:visible;border:none;background:transparent}
}
tr.top-pick{background:linear-gradient(90deg,rgba(157,140,255,.12),transparent 70%)}
tr.top-pick td:first-child{box-shadow:inset 3px 0 0 var(--violet-500)}
tr.top-pick .matrix-visit{box-shadow:0 6px 18px -8px rgba(157,140,255,.85)}

/* ---- matrix tool (filter/sort) ---- */
.matrix{background:var(--ink-850);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow)}
.matrix-controls{display:flex;flex-wrap:wrap;gap:.8rem 1.1rem;align-items:end;margin-bottom:1rem}
.field{display:flex;flex-direction:column;gap:.35rem}
.field label{font-size:.82rem;font-weight:600;color:var(--ink-200)}
.field select,.field input[type=search]{appearance:none;background:var(--ink-900);border:1px solid var(--border);color:var(--ink-100);
  padding:.6rem .7rem;border-radius:10px;font:inherit;font-size:.92rem;min-width:150px}
.field select:focus,.field input:focus{border-color:var(--violet-500);outline:none}
.field-check{flex-direction:row;align-items:center;gap:.5rem}
.matrix-count{font-size:.85rem;color:var(--ink-300);margin-left:auto}
.noscript-note{background:var(--cap-bg);border:1px solid #6a5320;border-radius:10px;padding:.8rem 1rem;color:var(--ink-100)}

/* ---- CTA card (affiliate + FTC disclosure) ---- */
.cta-card{background:linear-gradient(180deg,var(--ink-850),var(--ink-800));border:1px solid var(--violet-700);
  border-radius:var(--radius);padding:1.1rem 1.2rem;margin:1.6rem 0;box-shadow:var(--shadow)}
.cta-disclosure{font-size:.82rem;color:var(--ink-300);margin:0 0 .8rem;display:flex;gap:.5rem;align-items:flex-start}
.cta-ad{flex:none;font-size:.68rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-300);
  border:1px solid var(--border);border-radius:5px;padding:.1rem .35rem}
.cta-heading{font-weight:800;font-size:1.1rem;color:var(--ink-50);margin:0 0 .25rem;font-family:var(--font-display)}
.cta-angle{margin:0 0 .9rem;color:var(--ink-200);font-size:.95rem}
.cta-btn{display:inline-flex;align-items:center;gap:.45rem;padding:.8rem 1.3rem;border-radius:11px;font-weight:800;
  background:linear-gradient(180deg,var(--violet-500),var(--violet-600));color:#0a0a1e;box-shadow:0 8px 22px -10px rgba(157,140,255,.7)}
.cta-btn:hover{text-decoration:none;filter:brightness(1.06)}

/* ---- callouts ---- */
.callout{border-radius:var(--radius);padding:1rem 1.15rem;margin:1.4rem 0;border:1px solid var(--border)}
.callout-warn{background:var(--cap-bg);border-color:#6a5320}
.callout-good{background:var(--pos-bg);border-color:#1d5a47}
.callout-danger{background:#2a1018;border-color:#7a2230}
.callout .callout-h{font-weight:800;margin:0 0 .4rem;display:flex;gap:.5rem;align-items:center;font-family:var(--font-sans)}

/* ---- responsible gambling ---- */
.rg-block{background:var(--ink-900);border-top:1px solid var(--border);margin-top:3rem}
.rg-inner{display:flex;gap:1rem;align-items:flex-start;padding-block:1.5rem}
.rg-icon{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-weight:900;color:var(--cap);background:var(--cap-bg);border:1px solid #6a5320}
.rg-title{font-size:1.05rem;margin:0 0 .3rem}
.rg-block p{margin:0 0 .4rem;color:var(--ink-300);font-size:.92rem;max-width:80ch}
.rg-help a{color:var(--violet-400)}

/* ---- footer ---- */
.site-footer{background:var(--ink-900);border-top:1px solid var(--border);padding-block:2.4rem}
.footer-inner{display:grid;gap:1.8rem;grid-template-columns:1.1fr 2fr}
@media (max-width:760px){.footer-inner{grid-template-columns:1fr}}
.footer-brand .brand-mark{font-size:1rem}
.footer-brand .brand-name{font-weight:800;color:var(--ink-50);margin-left:.4rem;font-family:var(--font-display)}
.footer-tagline{color:var(--ink-300);font-size:.9rem;margin:.6rem 0}
.badge-18--footer{display:inline-block;min-width:0;height:auto;padding:.15rem .5rem}
.footer-nav{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
.footer-col-h{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-300);font-weight:700;margin:0 0 .5rem}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin:.25rem 0}
.footer-col a{color:var(--ink-200);font-size:.9rem}
.footer-legal{grid-column:1/-1;border-top:1px solid var(--border-soft);padding-top:1rem}
.footer-legal p{color:var(--ink-300);font-size:.84rem;margin:.3rem 0}
.footer-copy{color:var(--ink-500)!important}

/* ---- page banner / breadcrumb / misc ---- */
.page-banner{max-width:var(--maxw);margin:1.4rem auto 0;padding-inline:clamp(16px,4vw,28px)}
.page-banner img{width:100%;height:auto;aspect-ratio:1200/630;border-radius:var(--radius);border:1px solid var(--border);display:block;box-shadow:var(--shadow)}
.breadcrumb{font-size:.85rem;color:var(--ink-400);margin:1.4rem 0 .2rem;display:flex;flex-wrap:wrap;gap:.4rem}
.breadcrumb a{color:var(--ink-300)}
.breadcrumb span{color:var(--ink-500)}
.hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}
.pros-cons{display:grid;gap:1rem;grid-template-columns:1fr 1fr}
@media (max-width:560px){.pros-cons{grid-template-columns:1fr}}
.pros,.cons{border-radius:var(--radius);padding:1rem 1.15rem;border:1px solid var(--border)}
.pros{background:var(--pos-bg);border-color:#1d5a47}
.cons{background:var(--cap-bg);border-color:#6a5320}
.pros ul,.cons ul{margin:.4rem 0 0;padding-left:1.1rem}

html.nav-open{overflow:hidden}
