/* ============================================================================
   Hotnow2026 — Editorial Design System (styles.css)
   Professional, modern trending-media platform. The Verge / Polygon / Morning
   Brew quality: confident single accent, refined neutrals, 8pt grid, magazine
   layout, soft shadows, tasteful motion. Dark-mode-aware via CSS variables.
   Single shared stylesheet for every page. Honors prefers-reduced-motion.
   ============================================================================ */

:root{
  /* ---- brand accent (one confident color) ---- */
  --accent:#ff4500;            /* hot ember orange-red — energetic, editorial */
  --accent-ink:#ffffff;        /* text on accent */
  --accent-soft:rgba(255,69,0,.10);
  --accent-line:rgba(255,69,0,.32);

  /* ---- neutrals (light theme defaults) ---- */
  --bg:#f7f7f8;
  --surface:#ffffff;
  --surface-2:#f1f1f3;
  --ink:#16161a;
  --ink-2:#3d3d44;
  --muted:#6b6b76;
  --muted-2:#9a9aa4;
  --line:#e6e6ea;
  --line-2:#d8d8de;

  --good:#15a05a;
  --bad:#d63852;
  --warn:#c98a00;

  --shadow-1:0 1px 2px rgba(20,20,30,.05), 0 2px 8px rgba(20,20,30,.05);
  --shadow-2:0 4px 12px rgba(20,20,30,.08), 0 12px 28px rgba(20,20,30,.08);

  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:22px; --r-pill:999px;
  --maxw:1200px;
  --space:24px;

  /* refined type scale (1.25 major-third-ish) */
  --fs-display:clamp(2.4rem,6vw,4rem);
  --fs-h1:clamp(1.9rem,4.2vw,2.9rem);
  --fs-h2:clamp(1.35rem,2.6vw,1.7rem);
  --fs-h3:1.18rem;
  --fs-body:1.0rem;
  --fs-sm:.875rem;
  --fs-xs:.78rem;

  --font-display:"Georgia","Times New Roman",ui-serif,serif;
  --font-sans:"Inter","Segoe UI",system-ui,-apple-system,"Helvetica Neue",Arial,sans-serif;

  /* ---- legacy token aliases (old pages reference these inline) ---- */
  --stroke:var(--line);
  --stroke-hot:var(--line-2);
  --card:var(--surface);
  --card-2:var(--surface-2);
  --bg-2:var(--surface);
  --grad:var(--accent);
  --grad-warm:var(--accent);
  --grad-cool:var(--accent);
  --neon-pink:var(--accent);
  --neon-cyan:var(--accent);
  --neon-lime:var(--accent);
  --neon-violet:var(--accent);
  --neon-orange:var(--accent);
}

@media (prefers-color-scheme: dark){
  :root{
    --bg:#0d0d10;
    --surface:#16161b;
    --surface-2:#1d1d23;
    --ink:#f4f4f6;
    --ink-2:#d2d2d8;
    --muted:#a0a0ac;
    --muted-2:#74747f;
    --line:#28282f;
    --line-2:#34343c;
    --accent:#ff5a1f;
    --accent-soft:rgba(255,90,31,.13);
    --accent-line:rgba(255,90,31,.4);
    --shadow-1:0 1px 2px rgba(0,0,0,.4), 0 2px 8px rgba(0,0,0,.35);
    --shadow-2:0 6px 18px rgba(0,0,0,.5), 0 16px 40px rgba(0,0,0,.45);
  }
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font:var(--fs-body)/1.6 var(--font-sans);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  min-height:100vh;
}
a{color:var(--ink);text-decoration:none}
a:hover{color:var(--accent)}
img{max-width:100%;display:block}
button{font-family:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
::selection{background:var(--accent);color:var(--accent-ink)}

h1,h2,h3,h4{letter-spacing:-.02em}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--bg);
  padding:10px 16px;font-weight:700;border-radius:0 0 8px 0;z-index:200}
.skip:focus{left:0}

/* fade-in on load */
.fade-in{animation:fadeIn .4s ease both}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- top nav ---------- */
.nav{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--surface) 88%,transparent);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.nav__in{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:20px;
  padding:12px var(--space)}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:700;
  font-size:1.4rem;letter-spacing:-.03em;color:var(--ink);white-space:nowrap}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px var(--accent-soft);animation:pulse 2.6s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px var(--accent-soft)}50%{box-shadow:0 0 0 6px transparent}}
.nav__links{display:flex;gap:2px;margin-left:8px;flex:1;overflow-x:auto;scrollbar-width:none}
.nav__links::-webkit-scrollbar{display:none}
.nav__links a{color:var(--muted);font-weight:600;font-size:.92rem;padding:8px 12px;border-radius:8px;
  white-space:nowrap;transition:color .15s,background .15s}
.nav__links a:hover{color:var(--ink);background:var(--surface-2)}
.nav__links a[aria-current="page"]{color:var(--accent)}
.nav__search{display:flex;align-items:center;gap:6px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:var(--r-pill);padding:5px 6px 5px 14px;transition:border-color .15s}
.nav__search:focus-within{border-color:var(--accent-line)}
.nav__search input{background:none;border:0;color:var(--ink);font:inherit;font-size:.9rem;width:150px;outline:none}
.nav__search button{background:var(--ink);border:0;color:var(--bg);width:30px;height:30px;
  border-radius:50%;cursor:pointer;font-size:.85rem;display:grid;place-items:center;transition:background .15s}
.nav__search button:hover{background:var(--accent)}
@media (max-width:760px){.nav__search input{width:5.5rem}}

/* ---------- layout ---------- */
main{max-width:var(--maxw);margin:0 auto;padding:var(--space);min-height:50vh}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--space)}
.grid-2{display:grid;gap:40px;grid-template-columns:1fr}
@media (min-width:960px){.grid-2{grid-template-columns:1fr 320px}}

/* ---------- breadcrumbs ---------- */
.crumbs{display:flex;flex-wrap:wrap;gap:6px;align-items:center;color:var(--muted-2);
  font-size:var(--fs-xs);margin:8px 0 16px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--accent)}
.crumbs li{list-style:none}
.crumbs ol{display:flex;flex-wrap:wrap;gap:6px;margin:0;padding:0}
.crumbs .sep{opacity:.5}

/* ---------- homepage hero band ---------- */
.masthead{border-bottom:1px solid var(--line);background:var(--surface)}
.masthead__in{max-width:var(--maxw);margin:0 auto;padding:clamp(32px,6vw,64px) var(--space) clamp(28px,4vw,44px)}
.masthead .kicker{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-xs);font-weight:800;
  text-transform:uppercase;letter-spacing:.12em;color:var(--accent)}
.masthead .kicker::before{content:"";width:22px;height:2px;background:var(--accent);display:inline-block}
.masthead h1{font-family:var(--font-display);font-size:var(--fs-display);line-height:1.04;
  font-weight:700;margin:14px 0 0;max-width:18ch}
.masthead .lede{color:var(--muted);font-size:1.12rem;margin:14px 0 0;max-width:54ch;line-height:1.55}
.masthead .actions{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:1px solid transparent;
  padding:11px 20px;border-radius:var(--r-pill);font-weight:700;font-size:.92rem;line-height:1;
  transition:transform .15s,box-shadow .2s,background .15s,border-color .15s,color .15s}
.btn--primary,.btn--lime,.btn--grad{color:var(--accent-ink);background:var(--accent)}
.btn--primary:hover,.btn--lime:hover,.btn--grad:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}
.btn--ghost{color:var(--ink);background:var(--surface);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn--sm{padding:8px 14px;font-size:.85rem}
.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none!important;box-shadow:none!important}

/* ---------- section headers ---------- */
.section{font-size:var(--fs-h2);margin:44px 0 20px;display:flex;align-items:center;gap:12px;
  font-weight:800;font-family:var(--font-sans);padding-bottom:12px;border-bottom:2px solid var(--ink)}
.section--cool,.section--warm{border-bottom-color:var(--ink)}
.section__more{margin-left:auto;font-size:var(--fs-sm);font-weight:700;color:var(--accent);
  border-bottom:0;text-transform:uppercase;letter-spacing:.04em}

/* ---------- segmented tabs ---------- */
.tabs{display:inline-flex;gap:0;background:var(--surface-2);border:1px solid var(--line);
  border-radius:var(--r-pill);padding:4px;margin:0 0 24px;flex-wrap:wrap}
.tabs button{background:none;border:0;color:var(--muted);font-weight:700;padding:8px 18px;
  border-radius:var(--r-pill);cursor:pointer;transition:all .18s;font-size:.88rem}
.tabs button:hover{color:var(--ink)}
.tabs button[aria-selected="true"]{color:var(--accent-ink);background:var(--ink);box-shadow:var(--shadow-1)}

/* ---------- feed / magazine grid ---------- */
.feed{display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
@media (max-width:560px){.feed{grid-template-columns:1fr}}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;position:relative;transition:transform .2s,border-color .2s,box-shadow .2s;
  display:flex;flex-direction:column;color:var(--ink)}
.card:hover{transform:translateY(-3px);border-color:var(--line-2);box-shadow:var(--shadow-2)}
.card__media{aspect-ratio:16/9;background:var(--surface-2);position:relative;overflow:hidden;display:block}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card__media img{transform:scale(1.04)}
.card__body{padding:18px;display:flex;flex-direction:column;flex:1}
.card h3{margin:10px 0 8px;font-size:var(--fs-h3);line-height:1.32;font-weight:700;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card a:hover h3{color:var(--accent)}
.card p{color:var(--muted);font-size:var(--fs-sm);margin:0;line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card__meta{display:flex;align-items:center;gap:14px;margin-top:14px;padding-top:14px;
  border-top:1px solid var(--line);color:var(--muted-2);font-size:var(--fs-xs);flex-wrap:wrap}
.card__meta .score{color:var(--accent);font-weight:800;margin-left:auto}
.card__meta .mi{display:inline-flex;align-items:center;gap:4px}

/* topic pill */
.pill{display:inline-flex;align-items:center;gap:6px;width:fit-content;font-size:var(--fs-xs);
  font-weight:800;text-transform:uppercase;letter-spacing:.07em;padding:4px 10px;border-radius:var(--r-pill);
  background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent-line)}
.pill .swatch{width:7px;height:7px;border-radius:50%;background:currentColor}
.pill--hot{background:var(--accent);color:var(--accent-ink);border-color:transparent}
.pill--neutral{background:var(--surface-2);color:var(--muted);border-color:var(--line)}

/* ---------- hero (lead) story ---------- */
.lead{display:grid;gap:0;grid-template-columns:1fr;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-xl);overflow:hidden;margin-bottom:32px;transition:box-shadow .2s,border-color .2s}
.lead:hover{box-shadow:var(--shadow-2);border-color:var(--line-2)}
@media (min-width:760px){.lead{grid-template-columns:1.25fr 1fr}}
.lead__media{aspect-ratio:16/9;background:var(--surface-2);overflow:hidden;position:relative}
@media (min-width:760px){.lead__media{aspect-ratio:auto;min-height:340px}}
.lead__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.lead:hover .lead__media img{transform:scale(1.03)}
.lead__body{padding:clamp(22px,3vw,38px);display:flex;flex-direction:column;justify-content:center}
.lead__body .eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.lead__body h2{font-family:var(--font-display);font-size:clamp(1.5rem,2.8vw,2.2rem);line-height:1.12;
  font-weight:700;margin:0 0 12px}
.lead:hover .lead__body h2{color:var(--accent)}
.lead__body p{color:var(--muted);font-size:1.02rem;margin:0;line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.lead__body .card__meta{border-top:1px solid var(--line)}

/* reaction bar */
.react{margin:14px 18px 18px;display:flex;gap:8px;flex-wrap:wrap}
.react button{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-pill);
  cursor:pointer;padding:5px 11px;font-size:.95rem;color:var(--ink);
  transition:transform .12s,border-color .15s,background .15s;display:inline-flex;align-items:center;gap:5px}
.react button .n{font-size:.74rem;color:var(--muted);font-weight:700}
.react button:hover{border-color:var(--accent-line)}
.react button:active{transform:scale(1.18)}
.react button.on{border-color:var(--accent);background:var(--accent-soft)}

/* ---------- skeletons ---------- */
.skeleton{position:relative;overflow:hidden;color:transparent!important;pointer-events:none;
  border-color:var(--line)!important}
.skeleton *{visibility:hidden}
.skeleton::before{content:"";position:absolute;inset:0;z-index:1;background:
  linear-gradient(100deg,transparent 20%,var(--surface-2) 50%,transparent 80%);
  background-size:200% 100%;animation:shimmer 1.4s linear infinite}
@keyframes shimmer{to{background-position:-200% 0}}
.card.skeleton .card__media{visibility:visible}

/* ---------- offline / states ---------- */
.offline,.statebox{display:none;background:var(--accent-soft);border:1px solid var(--accent-line);
  color:var(--ink);padding:16px 18px;border-radius:var(--r-md);margin:16px 0;font-weight:600}
.offline strong{color:var(--accent)}
.empty{text-align:center;padding:48px 16px;color:var(--muted);grid-column:1/-1}
.empty .em{font-size:2.6rem;display:block;margin-bottom:10px}
.empty strong{color:var(--ink)}
.is-shown{display:block}

/* ---------- native ad slot ---------- */
.ad{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:20px;position:relative;overflow:hidden;box-shadow:var(--shadow-1)}
.ad::before{content:"SPONSORED";position:absolute;top:12px;right:14px;font-size:.6rem;
  font-weight:800;letter-spacing:.14em;color:var(--muted-2)}
.ad h4{margin:6px 0 8px;font-size:1.05rem;font-weight:800;color:var(--ink)}
.ad p{color:var(--muted);margin:0 0 14px;font-size:var(--fs-sm)}

/* ---------- aside / sidebar widgets ---------- */
.widget{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:20px;margin-bottom:24px;box-shadow:var(--shadow-1)}
.widget h4{margin:0 0 14px;font-size:.78rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.1em;color:var(--muted);display:flex;align-items:center;gap:8px}
.widget ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.widget li a{color:var(--ink);font-weight:600;font-size:.92rem}
.widget li a:hover{color:var(--accent)}
.taglist{display:flex;flex-wrap:wrap;gap:8px}
.taglist a{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border-radius:var(--r-pill);
  background:var(--surface-2);border:1px solid var(--line);font-size:.82rem;font-weight:700;color:var(--ink-2);
  transition:border-color .15s,color .15s}
.taglist a:hover{border-color:var(--accent);color:var(--accent)}
.taglist a .swatch{width:8px;height:8px;border-radius:50%}
.taglist a .tcount{font-size:.68rem;font-weight:800;color:var(--muted-2);background:var(--surface);
  border-radius:var(--r-pill);padding:1px 6px;margin-left:2px}

/* ---------- Ask AI widget ---------- */
.ask{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-1)}
.ask h4{margin:0 0 6px;font-size:1.02rem;font-weight:800;display:flex;align-items:center;gap:8px}
.ask p.sub{color:var(--muted);font-size:var(--fs-sm);margin:0 0 14px;line-height:1.5}
.ask form{display:flex;gap:8px}
.ask input,.ask textarea{flex:1;background:var(--surface-2);border:1px solid var(--line);color:var(--ink);
  font:inherit;font-size:.92rem;padding:11px 13px;border-radius:var(--r-md);outline:none;transition:border-color .15s}
.ask input:focus,.ask textarea:focus{border-color:var(--accent)}
.ask__answer{margin-top:14px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);
  padding:14px;font-size:.92rem;line-height:1.65;display:none}
.ask__answer.is-shown{display:block;animation:fadeIn .3s ease both}
.ask__answer .disc{margin-top:12px;color:var(--muted-2);font-size:var(--fs-xs);
  border-top:1px solid var(--line);padding-top:9px}

/* ---------- forms ---------- */
.form{display:flex;flex-direction:column;gap:16px;max-width:560px}
.field label{display:block;font-weight:700;font-size:var(--fs-sm);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;background:var(--surface);border:1px solid var(--line-2);
  color:var(--ink);font:inherit;font-size:.95rem;padding:12px 14px;border-radius:var(--r-md);outline:none;transition:border-color .15s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent)}
.field textarea{min-height:130px;resize:vertical}
.field .hint{color:var(--muted-2);font-size:var(--fs-xs);margin-top:6px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.consent{display:flex;gap:9px;align-items:flex-start;font-size:.82rem;color:var(--muted)}
.consent input{width:auto;margin-top:4px}
.form__msg{font-weight:600;padding:12px 14px;border-radius:var(--r-md);display:none}
.form__msg.ok{display:block;background:rgba(21,160,90,.1);border:1px solid var(--good);color:var(--good)}
.form__msg.err{display:block;background:rgba(214,56,82,.1);border:1px solid var(--bad);color:var(--bad)}

/* ---------- share sheet ---------- */
.share{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:20px 0;padding:16px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.share span.lbl{font-weight:800;font-size:var(--fs-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.share a,.share button{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line-2);
  background:var(--surface);color:var(--ink);border-radius:var(--r-pill);padding:8px 14px;font-weight:600;
  font-size:.82rem;cursor:pointer;transition:all .15s}
.share a:hover,.share button:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- comments ---------- */
.comments{margin-top:48px;max-width:760px}
.comment{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:16px;margin-bottom:12px}
.comment .who{font-weight:800;font-size:var(--fs-sm);color:var(--ink)}
.comment .when{color:var(--muted-2);font-size:var(--fs-xs);margin-left:8px}
.comment p{margin:8px 0 0;font-size:.92rem;color:var(--ink-2)}
.comment .pend{font-size:.72rem;color:var(--warn);font-weight:700}

/* ---------- article body ---------- */
.article-wrap{max-width:760px}
.article-head{margin:8px 0 24px}
.article-head h1{font-family:var(--font-display);font-size:var(--fs-h1);line-height:1.12;margin:14px 0;font-weight:700}
.article-head .tldr{font-size:1.18rem;color:var(--ink-2);font-weight:500;line-height:1.5;margin:0}
.article-head .byline{display:flex;gap:10px;align-items:center;flex-wrap:wrap;color:var(--muted);
  font-size:var(--fs-sm);margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.article-head .byline a{color:var(--accent);font-weight:600}
.cover{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9;
  background:var(--surface-2);margin:0 0 28px}
.cover img{width:100%;height:100%;object-fit:cover}
.cover figcaption{padding:8px 4px 0;font-size:var(--fs-xs);color:var(--muted-2)}
.prose{font-size:1.1rem;line-height:1.8;color:var(--ink-2);font-family:var(--font-display)}
.prose h2{font-family:var(--font-sans);font-size:1.5rem;margin:32px 0 14px;font-weight:800;color:var(--ink)}
.prose h3{font-family:var(--font-sans);font-size:1.22rem;margin:26px 0 10px;font-weight:800;color:var(--ink)}
.prose p{margin:0 0 20px}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.prose ul,.prose ol{margin:0 0 20px;padding-left:24px}
.prose li{margin:0 0 8px}
.prose blockquote{border-left:3px solid var(--accent);margin:24px 0;padding:6px 20px;color:var(--muted);font-style:italic}
.prose img{border-radius:var(--r-md);margin:20px 0}
.source-chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line-2);
  border-radius:var(--r-pill);padding:8px 14px;font-size:var(--fs-sm);font-weight:600;margin:6px 8px 6px 0}
.source-chip:hover{border-color:var(--accent);color:var(--accent)}
.source-chip .lab{color:var(--muted-2);text-transform:uppercase;font-size:var(--fs-xs);letter-spacing:.05em}

/* ---------- creator / profile ---------- */
.profile{display:flex;gap:20px;align-items:center;flex-wrap:wrap;margin:8px 0 28px;
  padding:24px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg)}
.avatar{width:84px;height:84px;border-radius:50%;background:var(--accent);display:grid;place-items:center;
  font-size:2rem;font-weight:800;color:var(--accent-ink);flex:0 0 auto}
.profile h1{margin:0;font-size:1.8rem;font-weight:800}
.profile .handle{color:var(--accent);font-weight:700}

/* ---------- gallery ---------- */
.gallery{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
.gallery a{position:relative;aspect-ratio:1;border-radius:var(--r-md);overflow:hidden;
  background:var(--surface-2);border:1px solid var(--line)}
.gallery a img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.gallery a:hover img{transform:scale(1.06)}
.gallery a .play{position:absolute;inset:0;display:grid;place-items:center;font-size:2.4rem;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.gallery a .gtag{position:absolute;top:8px;left:8px;font-size:.62rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.06em;padding:3px 7px;border-radius:6px;background:rgba(0,0,0,.55);color:#fff;backdrop-filter:blur(4px)}
.gallery a .gcred{position:absolute;left:0;right:0;bottom:0;padding:14px 8px 6px;font-size:.66rem;color:#fff;
  background:linear-gradient(to top,rgba(0,0,0,.72),transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---------- footer ---------- */
.foot{padding:56px var(--space) 40px;color:var(--muted);border-top:1px solid var(--line);margin-top:64px;
  background:var(--surface)}
.foot__in{max-width:var(--maxw);margin:0 auto;display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.foot h5{color:var(--ink);font-weight:800;margin:0 0 14px;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em}
.foot a{color:var(--muted);font-size:.9rem;display:block;padding:5px 0}
.foot a:hover{color:var(--accent)}
.foot .brand{font-family:var(--font-display);font-size:1.3rem;margin-bottom:8px}
.foot__bar{max-width:var(--maxw);margin:32px auto 0;padding-top:24px;border-top:1px solid var(--line);
  font-size:var(--fs-xs);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--muted-2)}

/* ---------- chips/list rows ---------- */
.rows{display:flex;flex-direction:column;gap:10px}
.row{display:flex;gap:16px;align-items:center;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-md);padding:14px;transition:border-color .15s,transform .15s;color:var(--ink)}
.row:hover{border-color:var(--accent-line);transform:translateX(2px)}
.row .num{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--accent);
  min-width:1.8rem;text-align:center}
.row__thumb{flex:0 0 auto;width:60px;height:42px;border-radius:var(--r-sm);overflow:hidden;background:var(--surface-2)}
.row__thumb img{width:100%;height:100%;object-fit:cover}
.row .body{flex:1;min-width:0}
.row .body h3{margin:0 0 4px;font-size:.98rem;line-height:1.3;font-weight:700;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.row:hover .body h3{color:var(--accent)}
.row .body p{margin:0;color:var(--muted);font-size:var(--fs-xs)}

/* ---------- confetti canvas ---------- */
#confetti{position:fixed;inset:0;pointer-events:none;z-index:300}

/* ---------- utility ---------- */
.center{text-align:center}
.muted{color:var(--muted)}
.mt{margin-top:20px}.mb{margin-bottom:20px}
.hidden{display:none!important}
.spinner{width:1.05rem;height:1.05rem;border:2px solid var(--line-2);border-top-color:var(--accent);
  border-radius:50%;animation:spin .7s linear infinite;display:inline-block;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}
.page-head{margin:8px 0 8px}
.page-head h1{font-family:var(--font-display);font-size:var(--fs-h1);font-weight:700;margin:0}
.page-head .lede{color:var(--muted);font-size:1.05rem;margin:10px 0 0;max-width:60ch}

/* ---------- insights / charts ---------- */
.insights{display:grid;gap:24px;grid-template-columns:1fr;margin:8px 0 8px}
@media(min-width:760px){.insights{grid-template-columns:1fr 1fr}}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:22px;box-shadow:var(--shadow-1)}
.panel h3{margin:0 0 4px;font-size:var(--fs-h3);font-weight:800;letter-spacing:-.02em}
.panel .sub{margin:0 0 16px;color:var(--muted);font-size:var(--fs-sm)}
.panel--span{grid-column:1/-1}

/* horizontal bar chart */
.barchart{display:flex;flex-direction:column;gap:11px}
.bc__row{display:grid;grid-template-columns:minmax(72px,30%) 1fr auto;align-items:center;gap:12px}
.bc__label{font-size:var(--fs-sm);font-weight:600;color:var(--ink-2);overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
.bc__track{height:12px;background:var(--surface-2);border-radius:var(--r-pill);overflow:hidden}
.bc__fill{display:block;height:100%;border-radius:var(--r-pill);
  transition:width .6s cubic-bezier(.2,.7,.2,1)}
.bc__val{font-size:var(--fs-xs);font-weight:800;color:var(--muted);min-width:2.4em;text-align:right}

/* sparkline */
.spark{display:block;width:100%;height:auto;overflow:visible}

/* donut */
.donut{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.donut svg{flex:0 0 auto}
.donut__n{font-family:var(--font-display);font-size:20px;font-weight:700;fill:var(--ink)}
.donut__l{font-size:9px;fill:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.donut__legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;flex:1;min-width:140px}
.donut__legend li{display:flex;align-items:center;gap:9px;font-size:var(--fs-sm);color:var(--ink-2)}
.donut__legend .sw{width:11px;height:11px;border-radius:3px;flex:0 0 auto}
.donut__legend b{margin-left:auto;color:var(--ink);font-weight:800}

/* trending numbered rail */
.rail{display:flex;flex-direction:column;gap:4px}
.rrow{display:flex;gap:14px;align-items:flex-start;padding:12px 6px;border-bottom:1px solid var(--line);
  color:var(--ink);transition:background .15s}
.rrow:last-child{border-bottom:0}
.rrow:hover{background:var(--surface-2)}
.rrow__n{font-family:var(--font-display);font-size:1.5rem;font-weight:700;line-height:1;
  color:var(--accent);min-width:1.3em;text-align:center}
.rrow__b{min-width:0;flex:1}
.rrow__t{font-weight:700;font-size:.98rem;line-height:1.32;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rrow:hover .rrow__t{color:var(--accent)}
.rrow__m{margin-top:4px;font-size:var(--fs-xs);color:var(--muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.rrow__m .swatch{width:8px;height:8px;border-radius:50%;display:inline-block}

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