/* ============================================================
   Silverplay Casino — style.css
   Archetype: VELVET LEDGER reworked as a bright casino-luxe dark theme.
   Brand accents: #53bbed (primary) · #85caed (CTA) · #b5d2e2 · #eae1e1
   Prefix: hwv-  ·  Fonts loaded by header: Sora + Inter
   ============================================================ */

/* ---------- design tokens ---------- */
:root{
  /* surfaces (deep cool charcoal-navy ladder) */
  --hwv-bg:#0c131b;
  --hwv-surface:#121d27;
  --hwv-surface-2:#1a2935;
  --hwv-surface-3:#223543;
  --hwv-dark:#080d13;            /* header / footer band */
  /* ink */
  --hwv-ink:#eef3f6;
  --hwv-ink-2:#b5d2e2;           /* brand pale blue, muted text */
  --hwv-ink-3:#8aa6b8;           /* dim, still AA on --hwv-bg */
  --hwv-dark-ink:#eae1e1;        /* brand warm off-white on dark band */
  /* accents */
  --hwv-accent:#53bbed;
  --hwv-accent-2:#85caed;        /* CTA fill */
  --hwv-accent-soft:#eae1e1;
  --hwv-cta:#85caed;
  --hwv-cta-ink:#06131d;
  --hwv-gold:#f3c969;            /* "win" accent for ratings/multipliers */
  --hwv-tp-star:#00b67a;
  /* hairlines via single source */
  --hwv-hairline:color-mix(in oklab, var(--hwv-ink) 14%, transparent);
  --hwv-hairline-2:color-mix(in oklab, var(--hwv-ink) 22%, transparent);
  --hwv-accent-line:color-mix(in oklab, var(--hwv-accent) 55%, transparent);
  --hwv-glow:color-mix(in oklab, var(--hwv-accent) 38%, transparent);
  /* radii — mixed: pill buttons, soft cards */
  --hwv-r:10px;
  --hwv-r-sm:5px;
  --hwv-r-lg:16px;
  --hwv-pill:999px;
  --hwv-shadow:0 18px 44px -22px rgba(0,0,0,.75), 0 6px 16px -10px rgba(0,0,0,.6);
  /* layout */
  --hwv-wrap:1280px;
  --hwv-pad:clamp(16px,4vw,40px);
  --hwv-gap:32px;
  /* type scale (ratio ~1.25) */
  --hwv-display:"Sora", system-ui, "Segoe UI", sans-serif;
  --hwv-text:"Inter", system-ui, "Segoe UI", Arial, sans-serif;
  --hwv-step-6:clamp(2.4rem,1.3rem + 4.6vw,4rem);
  --hwv-step-5:clamp(2rem,1.3rem + 2.9vw,3rem);
  --hwv-step-4:clamp(1.6rem,1.15rem + 1.9vw,2.3rem);
  --hwv-step-3:clamp(1.35rem,1.1rem + 1.05vw,1.7rem);
  --hwv-step-2:clamp(1.15rem,1.02rem + .55vw,1.35rem);
  --hwv-step-1:1.0625rem;
  --hwv-step-0:1rem;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0}
img,svg,video{max-width:100%;height:auto;display:block}
button,input,select,textarea{font:inherit;color:inherit}
a{color:inherit}
h1,h2,h3,h4,p,ul,ol,dl,figure,blockquote{margin:0}
::selection{background:color-mix(in oklab, var(--hwv-accent) 36%, transparent);color:#fff}
:focus-visible{outline:2px solid var(--hwv-accent);outline-offset:2px;border-radius:2px}
::-webkit-scrollbar{height:10px;width:10px}
::-webkit-scrollbar-thumb{background:var(--hwv-surface-3);border-radius:99px}
html{scrollbar-color:var(--hwv-surface-3) var(--hwv-bg)}

/* ---------- base ---------- */
body.hwv-body{
  font-family:var(--hwv-text);
  font-size:var(--hwv-step-0);
  line-height:1.65;
  color:var(--hwv-ink);
  background:var(--hwv-bg);
  background-image:
    radial-gradient(1200px 620px at 78% -8%, color-mix(in oklab, var(--hwv-accent) 13%, transparent), transparent 60%),
    radial-gradient(900px 520px at -6% 4%, color-mix(in oklab, var(--hwv-accent-soft) 6%, transparent), transparent 55%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--hwv-display);font-weight:700;line-height:1.12;color:var(--hwv-ink);letter-spacing:-.02em;text-wrap:balance}
strong,b{color:var(--hwv-ink);font-weight:700}

/* ---------- skip link ---------- */
.hwv-skip{position:absolute;left:-999px;top:8px;z-index:200;background:var(--hwv-accent);color:#06131d;padding:10px 16px;border-radius:var(--hwv-r-sm);font-weight:700;text-decoration:none}
.hwv-skip:focus{left:16px}

/* ---------- container ---------- */
.hwv-wrap{width:100%;max-width:var(--hwv-wrap);margin-inline:auto;padding-inline:var(--hwv-pad)}
.hwv-main{width:100%;max-width:var(--hwv-wrap);margin-inline:auto;padding-inline:var(--hwv-pad);padding-block:clamp(20px,3vw,34px) clamp(40px,6vw,72px)}
/* neutralise wraps nested inside main so they don't double-pad / re-center */
.hwv-main .hwv-wrap{max-width:none;padding-inline:0;margin-inline:0;width:100%}
.hwv-doc{max-width:none}

/* ============================================================
   HEADER
   ============================================================ */
.hwv-head{position:sticky;top:0;z-index:60;background:color-mix(in oklab, var(--hwv-dark) 90%, transparent);border-bottom:1px solid var(--hwv-hairline);backdrop-filter:saturate(140%) blur(9px)}
.hwv-head__bar{display:flex;align-items:center;gap:20px;min-height:70px;padding-block:10px}
.hwv-logo{display:inline-flex;align-items:center;flex:0 0 auto;transition:transform .18s ease,opacity .18s ease}
.hwv-logo img{width:auto;height:42px}
.hwv-logo:hover{opacity:.88;transform:translateY(-1px)}
.hwv-nav{margin-left:auto;display:flex;align-items:center}
.hwv-nav__list{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:4px}
.hwv-nav__list a{
  position:relative;display:inline-flex;align-items:center;padding:9px 14px;
  text-decoration:none;color:var(--hwv-dark-ink);font-weight:600;font-size:.95rem;
  border-radius:var(--hwv-r-sm);
  transition:color .16s ease,background-color .16s ease
}
.hwv-nav__list a::after{content:"";position:absolute;left:14px;right:14px;bottom:5px;height:2px;background:var(--hwv-accent);transform:scaleX(0);transform-origin:left;transition:transform .22s ease;border-radius:2px}
.hwv-nav__list a:hover{color:#fff;background:color-mix(in oklab, var(--hwv-accent) 14%, transparent)}
.hwv-nav__list a:hover::after,.hwv-nav__list a[aria-current="page"]::after{transform:scaleX(1)}
.hwv-nav__list a[aria-current="page"]{color:#fff}
.hwv-burger{color:var(--hwv-dark-ink);border:1px solid var(--hwv-hairline-2)!important;border-radius:var(--hwv-r-sm);background:color-mix(in oklab,var(--hwv-ink) 6%,transparent)!important}

/* ---------- CTA buttons ---------- */
.hwv-cta{
  position:relative;display:inline-flex;align-items:center;gap:14px;
  padding:13px 22px 13px 24px;border-radius:var(--hwv-pill);
  font-family:var(--hwv-display);font-weight:700;font-size:.98rem;letter-spacing:.01em;
  text-decoration:none;cursor:pointer;border:1px solid transparent;white-space:nowrap;
  background:linear-gradient(135deg,var(--hwv-accent-2),color-mix(in oklab,var(--hwv-accent) 80%, #ffffff 0%));
  color:var(--hwv-cta-ink);
  box-shadow:0 0 0 1px color-mix(in oklab,var(--hwv-accent) 40%,transparent), 0 14px 34px -18px var(--hwv-glow);
  transition:transform .16s ease,box-shadow .2s ease,filter .16s ease
}
.hwv-cta::after{
  content:"→";display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;flex:0 0 auto;border-radius:50%;
  background:var(--hwv-cta-ink);color:var(--hwv-accent-2);font-size:.95rem;line-height:1;
  transition:transform .3s cubic-bezier(.2,.7,.2,1)
}
.hwv-cta:hover{transform:translateY(-2px);filter:brightness(1.05);box-shadow:0 0 0 1px color-mix(in oklab,var(--hwv-accent) 62%,transparent), 0 22px 48px -18px var(--hwv-glow)}
.hwv-cta:hover::after{transform:rotate(360deg)}
.hwv-cta:active{transform:translateY(0)}
.hwv-cta--ghost{background:transparent;color:var(--hwv-accent);border-color:var(--hwv-accent-line);box-shadow:none}
.hwv-cta--ghost::after{background:color-mix(in oklab,var(--hwv-accent) 18%,transparent);color:var(--hwv-accent)}
.hwv-cta--ghost:hover{background:color-mix(in oklab,var(--hwv-accent) 12%,transparent);color:#fff;box-shadow:none}
.hwv-head__bar .hwv-cta{flex:0 0 auto}

/* ---------- body CTA centering (guard at any depth) ---------- */
.hwv-ctarow{display:flex;justify-content:center;margin:1.6em 0}
.hwv-main>.hwv-cta,
.hwv-main :not(.hwv-hero__cta):not(.hwv-nav__cta):not(.hwv-ctarow)>.hwv-cta{display:inline-flex;width:fit-content;margin-inline:auto}

/* ============================================================
   HERO  (journal spread: copy left, square art right)
   ============================================================ */
.hwv-hero{position:relative;overflow:clip;padding-block:clamp(26px,4vw,48px) clamp(20px,3vw,36px)}
.hwv-hero::before{content:"";position:absolute;inset:-10% 0 auto auto;width:min(60%,640px);height:120%;z-index:0;pointer-events:none;
  background:radial-gradient(58% 52% at 72% 26%, var(--hwv-glow), transparent 70%);filter:blur(8px);opacity:.9}
.hwv-hero__inner{position:relative;z-index:1}
.hwv-hero__grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:clamp(24px,4vw,56px);align-items:center}
.hwv-hero__copy{display:flex;flex-direction:column;gap:16px;min-width:0}
.hwv-hero__kicker{display:block;font-family:var(--hwv-display);text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;font-weight:700;color:var(--hwv-accent);margin:0}
.hwv-hero__kicker::before{content:"";display:inline-block;width:26px;height:1px;background:var(--hwv-accent);vertical-align:middle;margin-right:10px;margin-bottom:3px}
.hwv-hero__h1{font-size:var(--hwv-step-6);line-height:1.04;margin:0;text-indent:-.02em}
.hwv-hero__lead{margin:0;color:var(--hwv-ink-2);font-size:var(--hwv-step-2);line-height:1.55;max-width:48ch;text-wrap:pretty}
.hwv-hero__cta{margin:2px 0 4px;justify-content:flex-start}
.hwv-hero__facts{list-style:none;margin:8px 0 0;padding:16px 4px 4px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;
  border-top:1px solid var(--hwv-hairline);background:var(--hwv-hairline);border-radius:var(--hwv-r);overflow:hidden}
.hwv-hero__fact{display:flex;flex-direction:column;gap:3px;padding:13px 16px;background:var(--hwv-surface)}
.hwv-hero__fact-k{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--hwv-ink-3);font-weight:600}
.hwv-hero__fact-v{font-family:var(--hwv-display);font-weight:700;font-size:1.08rem;color:var(--hwv-ink);font-variant-numeric:tabular-nums}
.hwv-hero__media{position:relative;margin:0}
.hwv-hero__media::after{content:"";position:absolute;inset:auto 8% -14px 8%;height:30px;border-radius:50%;background:var(--hwv-glow);filter:blur(20px);z-index:0}
.hwv-hero__media img{position:relative;z-index:1;width:100%;max-width:460px;margin-inline:auto;aspect-ratio:1/1;object-fit:cover;border-radius:var(--hwv-r-lg);
  border:1px solid var(--hwv-hairline-2);box-shadow:0 0 0 1px color-mix(in oklab,var(--hwv-accent) 22%,transparent),0 30px 70px -30px rgba(0,0,0,.85),0 0 60px -20px var(--hwv-glow)}

/* hero entrance (one-shot, GPU only) */
@media(prefers-reduced-motion:no-preference){
  .hwv-hero__copy>*{animation:hwv-in .6s cubic-bezier(.2,.7,.2,1) both}
  .hwv-hero__kicker{animation-delay:.02s}
  .hwv-hero__h1{animation-delay:.08s}
  .hwv-hero__lead{animation-delay:.16s}
  .hwv-hero__cta{animation-delay:.24s}
  .hwv-hero__facts{animation-delay:.32s}
  .hwv-hero__media{animation:hwv-in-r .7s cubic-bezier(.2,.7,.2,1) both;animation-delay:.12s}
}
@keyframes hwv-in{from{opacity:0;transform:translateX(-14px)}to{opacity:1;transform:none}}
@keyframes hwv-in-r{from{opacity:0;transform:translateX(16px) scale(.98)}to{opacity:1;transform:none}}

/* ============================================================
   PROSE TYPOGRAPHY  (.hwv-prose / .hwv-main content)
   ============================================================ */
.hwv-prose{max-width:none;color:var(--hwv-ink-2)}
.hwv-prose>section,.hwv-main>.hwv-doc>section{scroll-margin-top:90px}
.hwv-prose p,.hwv-main p{margin-top:1em;line-height:1.72;color:var(--hwv-ink-2);text-wrap:pretty;overflow-wrap:break-word}
.hwv-prose h2,.hwv-main h2{margin-top:1.7em;font-size:var(--hwv-step-4);color:var(--hwv-ink);position:relative;padding-bottom:.34em}
.hwv-prose h2::after,.hwv-main h2::after{content:"";position:absolute;left:0;bottom:0;width:54px;height:3px;border-radius:3px;
  background:linear-gradient(90deg,var(--hwv-accent),transparent)}
.hwv-prose h3,.hwv-main h3{margin-top:1.3em;font-size:var(--hwv-step-3);color:var(--hwv-ink)}
.hwv-prose h2:first-child,.hwv-prose p:first-child,.hwv-prose section:first-child{margin-top:0}
.hwv-prose section{margin-top:2.2em}
.hwv-prose section:first-of-type{margin-top:1.4em}

/* lead paragraph */
.hwv-lede,.hwv-lede.hwv-prose>p{font-size:var(--hwv-step-2);line-height:1.62;color:var(--hwv-ink);max-width:none;
  border-left:3px solid var(--hwv-accent);padding-left:18px;margin-top:.4em}

/* prose links — animated underline */
.hwv-prose a:not(.hwv-cta),.hwv-main a:not(.hwv-cta){
  color:var(--hwv-accent);text-decoration:none;font-weight:600;
  background-image:linear-gradient(var(--hwv-accent),var(--hwv-accent));
  background-size:0% 1.5px;background-position:0 100%;background-repeat:no-repeat;
  padding-bottom:1px;transition:background-size .25s ease,color .16s ease
}
.hwv-prose a:not(.hwv-cta):hover,.hwv-main a:not(.hwv-cta):hover{background-size:100% 1.5px;color:color-mix(in oklab,var(--hwv-accent) 80%,#fff)}

/* lists — numbered drop-initial markers / hairline checks */
.hwv-prose ul,.hwv-prose ol,.hwv-main ul,.hwv-main ol{margin-top:1.05em;padding:0;list-style:none}
.hwv-prose ul li,.hwv-main ul li{position:relative;padding-left:1.7em;margin-top:.55em;line-height:1.65;color:var(--hwv-ink-2)}
.hwv-prose ul li::before,.hwv-main ul li::before{content:"";position:absolute;left:.1em;top:.62em;width:8px;height:8px;border-radius:2px;
  background:var(--hwv-accent);box-shadow:0 0 10px -1px var(--hwv-glow)}
.hwv-prose ol,.hwv-main ol{counter-reset:hwv-ol}
.hwv-prose ol li,.hwv-main ol li{position:relative;padding-left:2.4em;margin-top:.7em;line-height:1.65;color:var(--hwv-ink-2);counter-increment:hwv-ol}
.hwv-prose ol li::before,.hwv-main ol li::before{content:counter(hwv-ol);position:absolute;left:0;top:-.04em;width:1.7em;
  font-family:var(--hwv-display);font-weight:700;font-size:1.15em;color:var(--hwv-accent);font-variant-numeric:tabular-nums}

/* content figure — centered, capped, never full-bleed */
.hwv-figure{width:min(72%,760px);margin:1.8em auto;text-align:center}
.hwv-figure img{width:100%;height:auto;border-radius:var(--hwv-r);border:1px solid var(--hwv-hairline-2);
  box-shadow:0 24px 54px -28px rgba(0,0,0,.8)}
.hwv-figure figcaption{margin-top:.7em;font-size:.86rem;color:var(--hwv-ink-3);line-height:1.5;font-style:italic}

/* ============================================================
   TABLES  (ledger style: hairline rows, tabular nums)
   ============================================================ */
.hwv-tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.6em 0;border:1px solid var(--hwv-hairline);border-radius:var(--hwv-r);background:var(--hwv-surface)}
.hwv-prose table,.hwv-main table,table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums lining-nums;font-size:.95rem}
.hwv-tablewrap table{min-width:520px}
table caption{caption-side:top;text-align:left;font-weight:600;color:var(--hwv-ink-3);padding:6px 14px}
thead th{background:var(--hwv-surface-2);color:var(--hwv-ink);font-family:var(--hwv-display);font-weight:700;font-size:.82rem;
  text-transform:uppercase;letter-spacing:.04em;text-align:left;padding:13px 16px;border-bottom:1px solid var(--hwv-hairline-2);white-space:nowrap}
tbody td{padding:12px 16px;border-bottom:1px solid var(--hwv-hairline);color:var(--hwv-ink-2);vertical-align:top}
tbody tr:last-child td{border-bottom:0}
tbody td:first-child{color:var(--hwv-ink);font-weight:600}
tbody tr{transition:background-color .15s ease}
tbody tr:hover td{background:color-mix(in oklab,var(--hwv-accent) 8%,transparent)}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.hwv-crumbs{padding-block:14px 4px}
.hwv-crumbs__list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.82rem;color:var(--hwv-ink-3)}
.hwv-crumbs__item{display:inline-flex;align-items:center;gap:8px}
.hwv-crumbs__item+.hwv-crumbs__item::before{content:"›";color:var(--hwv-ink-3);opacity:.6}
.hwv-crumbs__item a{color:var(--hwv-ink-3);text-decoration:none;transition:color .15s ease}
.hwv-crumbs__item a:hover{color:var(--hwv-accent)}
.hwv-crumbs__item [aria-current="page"]{color:var(--hwv-ink-2);font-weight:600}

/* ============================================================
   PAGE TITLE (trust / author / legal heads)
   ============================================================ */
.hwv-pagetitle{padding-block:clamp(22px,4vw,44px) clamp(14px,2vw,22px);position:relative}
.hwv-pagetitle__inner{position:relative}
.hwv-pagetitle__kicker{display:block;font-family:var(--hwv-display);text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;
  font-weight:700;color:var(--hwv-accent);margin:0 0 .7em}
.hwv-pagetitle__kicker::before{content:"";display:inline-block;width:24px;height:1px;background:var(--hwv-accent);vertical-align:middle;margin-right:9px;margin-bottom:3px}
.hwv-pagetitle__row{display:flex;flex-direction:column;gap:.5em}
.hwv-pagetitle__h1{font-size:var(--hwv-step-5);line-height:1.06;margin:0}
.hwv-pagetitle__lead{margin:0;color:var(--hwv-ink-2);font-size:var(--hwv-step-2);line-height:1.55;max-width:72ch}

/* ============================================================
   BYLINE
   ============================================================ */
.hwv-byline{display:flex;align-items:center;gap:15px;padding-block:16px;margin-block:0;border-top:1px solid var(--hwv-hairline);border-bottom:1px solid var(--hwv-hairline)}
.hwv-byline__photo{flex:0 0 auto;width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid var(--hwv-accent-line)}
.hwv-byline__meta{display:flex;flex-direction:column;gap:2px;min-width:0;font-size:.9rem}
.hwv-byline__author{font-family:var(--hwv-display);font-weight:700;color:var(--hwv-ink);text-decoration:none}
.hwv-byline__author:hover{color:var(--hwv-accent)}
.hwv-byline__role{color:var(--hwv-ink-3)}
.hwv-byline__rev{color:var(--hwv-ink-3);font-size:.84rem}
.hwv-byline__rev a{color:var(--hwv-accent);text-decoration:none}
.hwv-byline__dates{display:flex;flex-wrap:wrap;align-items:baseline;gap:2px 16px;margin:.3em 0 0;font-size:.8rem;color:var(--hwv-ink-3)}
.hwv-byline__dates dt{display:inline;font-weight:600;color:var(--hwv-ink-3)}
.hwv-byline__dates dt::after{content:":";margin-right:5px}
.hwv-byline__dates dd{display:inline;margin:0 14px 0 0;color:var(--hwv-ink-2);font-variant-numeric:tabular-nums}

/* ============================================================
   SLOTS SHOWCASE
   ============================================================ */
.hwv-slots{margin:2.4em 0}
.hwv-slots__h{font-size:var(--hwv-step-4);color:var(--hwv-ink);margin:0 0 .8em;position:relative;padding-bottom:.34em}
.hwv-slots__h::after{content:"";position:absolute;left:0;bottom:0;width:54px;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--hwv-accent),transparent)}
.hwv-slots__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,168px),1fr));gap:14px}
.hwv-slot{position:relative;display:block;text-decoration:none;color:inherit;background:var(--hwv-surface);border:1px solid var(--hwv-hairline);
  border-radius:var(--hwv-r);overflow:hidden;transition:transform .18s ease,box-shadow .2s ease,border-color .18s ease}
.hwv-slot:hover{transform:translateY(-4px);border-color:var(--hwv-accent-line);box-shadow:0 18px 40px -22px rgba(0,0,0,.85),0 0 36px -16px var(--hwv-glow)}
.hwv-slot__img{width:100%;aspect-ratio:457/512;object-fit:contain;transition:transform .3s ease}
.hwv-slot:hover .hwv-slot__img{transform:scale(1.06)}
.hwv-slot__name{display:block;padding:10px 12px;font-weight:600;font-size:.86rem;color:var(--hwv-ink-2);line-height:1.3}
.hwv-slot:hover .hwv-slot__name{color:var(--hwv-ink)}

/* ============================================================
   PROS / CONS — token harmony (part carries its own layout CSS)
   ============================================================ */
.hwv-pc__col{--hwv-r:10px}
.hwv-pc__col--pro{background:color-mix(in oklab,var(--hwv-accent) 7%,var(--hwv-surface))!important;border-color:var(--hwv-accent-line)!important}
.hwv-pc__col--con{background:var(--hwv-surface)!important}
.hwv-pc__h{font-family:var(--hwv-display);color:var(--hwv-ink)}
.hwv-pc__col--pro .hwv-pc__list li::before{color:var(--hwv-accent)!important}
.hwv-pc__col--con .hwv-pc__list li::before{color:var(--hwv-ink-3)!important}

/* ============================================================
   AUTHOR PAGE (full article, photo floated left)
   ============================================================ */
.hwv-authorpage{max-width:none}
.hwv-authorpage__photo{float:left;width:200px;height:auto;aspect-ratio:3/4;object-fit:cover;border-radius:var(--hwv-r);
  margin:.4em 26px 14px 0;border:1px solid var(--hwv-hairline-2);box-shadow:0 20px 44px -26px rgba(0,0,0,.85)}
.hwv-authorpage p{max-width:none}
.hwv-authorpage h2{clear:none}
.hwv-authorpage::after{content:"";display:block;clear:both}

/* ============================================================
   404
   ============================================================ */
.hwv-404{text-align:center;padding:clamp(30px,8vw,80px) 0}
.hwv-404__code{font-family:var(--hwv-display);font-weight:700;font-size:clamp(4rem,16vw,8rem);line-height:1;color:var(--hwv-accent);
  text-shadow:0 0 60px var(--hwv-glow)}
.hwv-404 h1{margin:.2em 0 .3em;font-size:var(--hwv-step-4)}
.hwv-404 p{color:var(--hwv-ink-2)}
.hwv-404__home{display:inline-flex;margin-top:1em;color:var(--hwv-accent);font-weight:700;text-decoration:none;
  border:1px solid var(--hwv-accent-line);padding:11px 22px;border-radius:var(--hwv-pill);transition:background-color .16s ease,color .16s ease}
.hwv-404__home:hover{background:color-mix(in oklab,var(--hwv-accent) 14%,transparent);color:#fff}

/* ============================================================
   FOOTER
   ============================================================ */
.hwv-foot{margin-top:clamp(40px,7vw,80px);background:var(--hwv-dark);color:var(--hwv-dark-ink);border-top:1px solid var(--hwv-hairline-2);
  background-image:radial-gradient(900px 360px at 86% 0%,color-mix(in oklab,var(--hwv-accent) 10%,transparent),transparent 60%)}
.hwv-foot__inner{display:flex;flex-direction:column;gap:30px;padding-block:clamp(34px,5vw,52px)}
.hwv-foot__head{display:flex;flex-wrap:wrap;gap:18px 40px;align-items:center;padding-bottom:26px;border-bottom:1px solid var(--hwv-hairline)}
.hwv-foot__logo img{height:42px;width:auto}
.hwv-foot__disc{margin:0;flex:1 1 360px;min-width:0;font-size:.86rem;line-height:1.6;color:color-mix(in oklab,var(--hwv-dark-ink) 80%,transparent)}
.hwv-foot__age{display:inline-flex;align-items:center;justify-content:center;font-family:var(--hwv-display);font-weight:700;font-size:.72rem;
  border:1px solid currentColor;border-radius:99px;padding:2px 8px;margin-right:7px;color:var(--hwv-accent)}
.hwv-foot__cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,180px),1fr));gap:26px}
.hwv-foot__col{min-width:0}
.hwv-foot__h{font-family:var(--hwv-display);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--hwv-accent);margin:0 0 12px}
.hwv-foot__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.hwv-foot__list a{text-decoration:none;color:color-mix(in oklab,var(--hwv-dark-ink) 82%,transparent);font-size:.9rem;transition:color .15s ease,padding-left .15s ease}
.hwv-foot__list a:hover{color:var(--hwv-accent);padding-left:4px}
.hwv-foot__sub{display:flex;flex-direction:column;gap:6px;padding-top:22px;border-top:1px solid var(--hwv-hairline)}
.hwv-foot__nap,.hwv-foot__copy{margin:0;font-size:.8rem;color:color-mix(in oklab,var(--hwv-dark-ink) 68%,transparent)}
.hwv-foot__nap a{color:var(--hwv-accent);text-decoration:none}
.hwv-foot__nap a:hover{text-decoration:underline}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.hwv-cookie{position:fixed;left:0;right:0;bottom:0;z-index:120;background:color-mix(in oklab,var(--hwv-surface-2) 96%,transparent);
  border-top:1px solid var(--hwv-accent-line);backdrop-filter:blur(8px);box-shadow:0 -16px 40px -24px rgba(0,0,0,.9)}
.hwv-cookie[hidden]{display:none}
.hwv-cookie__inner{display:flex;flex-wrap:wrap;align-items:center;gap:14px 22px;padding-block:15px}
.hwv-cookie__txt{flex:1 1 320px;min-width:0;font-size:.86rem;line-height:1.55;color:var(--hwv-ink-2)}
.hwv-cookie__txt a{color:var(--hwv-accent);text-decoration:none}
.hwv-cookie__txt a:hover{text-decoration:underline}
.hwv-cookie__btns{display:flex;flex-wrap:wrap;gap:10px}
.hwv-cookie__btn{cursor:pointer;font-family:var(--hwv-display);font-weight:700;font-size:.85rem;padding:10px 18px;border-radius:var(--hwv-pill);
  border:1px solid var(--hwv-hairline-2);background:transparent;color:var(--hwv-ink-2);transition:transform .15s ease,border-color .15s ease,color .15s ease}
.hwv-cookie__btn:hover{transform:translateY(-1px);border-color:var(--hwv-accent-line);color:var(--hwv-ink)}
.hwv-cookie__btn--ok{background:linear-gradient(135deg,var(--hwv-accent-2),var(--hwv-accent));color:var(--hwv-cta-ink);border-color:transparent;
  box-shadow:0 12px 28px -16px var(--hwv-glow)}
.hwv-cookie__btn--ok:hover{filter:brightness(1.05);color:var(--hwv-cta-ink)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .hwv-hero__grid{gap:clamp(20px,3vw,40px)}
  .hwv-hero__media img{max-width:400px}
}

/* tablet / mobile header → burger drawer */
@media(max-width:900px){
  .hwv-head__bar{gap:12px;min-height:62px}
  .hwv-head__bar .hwv-cta{padding:11px 16px 11px 18px;font-size:.9rem;gap:10px}
  .hwv-head__bar .hwv-cta::after{width:22px;height:22px}
  .hwv-nav{position:static}
  .hwv-nav__list{position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:0;
    background:var(--hwv-dark);border-bottom:1px solid var(--hwv-hairline-2);box-shadow:0 24px 40px -24px rgba(0,0,0,.9);
    padding:8px var(--hwv-pad) 16px;max-width:100vw}
  .hwv-nav__list li{border-bottom:1px solid var(--hwv-hairline)}
  .hwv-nav__list li:last-child{border-bottom:0}
  .hwv-nav__list a{padding:14px 6px;font-size:1.02rem;border-radius:0;min-height:48px;width:100%}
  .hwv-nav__list a::after{display:none}
  .hwv-nav__list a[aria-current="page"],.hwv-nav__list a:hover{background:color-mix(in oklab,var(--hwv-accent) 16%,transparent);
    border-radius:var(--hwv-r-sm)}
}

/* hero stacking ≤760 — DOM order already: H1→facts… but we reorder for CTA-above-fold via flex order */
@media(max-width:760px){
  .hwv-hero{padding-block:20px 14px}
  .hwv-hero__grid{grid-template-columns:1fr;gap:22px}
  /* DOM order H1→facts→CTA→image: copy children reorder; media is the next grid
     cell so it stacks AFTER all copy content automatically (image stays last). */
  .hwv-hero__copy{display:flex;flex-direction:column;gap:14px}
  .hwv-hero__kicker{order:0}
  .hwv-hero__h1{order:1}
  .hwv-hero__facts{order:2;margin-top:2px}
  .hwv-hero__cta{order:3;justify-content:center}
  .hwv-hero__lead{order:4}
  .hwv-hero__media img{max-width:none;max-height:46vh;width:auto;margin-inline:auto}
  .hwv-hero::before{width:100%}
  .hwv-pagetitle__h1{font-size:var(--hwv-step-4)}
}

@media(max-width:640px){
  body.hwv-body{font-size:16px}
  .hwv-hero__facts{grid-template-columns:1fr 1fr}
  .hwv-figure{width:100%}
  .hwv-authorpage__photo{float:none;width:160px;margin:0 0 16px}
  .hwv-slots__grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,140px),1fr))}
  .hwv-foot__head{gap:14px}
  .hwv-cookie__inner{padding-block:13px}
  .hwv-cookie__btns{width:100%}
  .hwv-cookie__btn{flex:1 1 auto;text-align:center}
}

@media(max-width:420px){
  .hwv-hero__facts{grid-template-columns:1fr}
  .hwv-head__bar .hwv-cta span,.hwv-head__bar .hwv-cta{font-size:.84rem}
}

/* ============================================================
   MOTION GUARD
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hwv-cta:hover{transform:none}
}
