/* =============================================================================
   Contagious Queer — design system
   "Independent queer zine": deep-plum ground, archival-paper blocks, four
   rotating saturated accents (never rainbow-soup), risograph posters, grain,
   grotesque display + literary serif body. Dark-first, mobile-first, AA.
   ============================================================================= */

:root{
  /* ground */
  --ink:#14101a; --ink-2:#1d1726; --ink-3:#272031; --line:#372e46;
  --paper:#f7f1e6; --paper-2:#efe6d6; --paper-ink:#1a1320;
  /* type colour on dark */
  --text:#ece6f2; --muted:#b6abc6; --faint:#8b809e;
  /* accents */
  --magenta:#ff2e88; --marigold:#ffb23d; --teal:#2fe0c4; --violet:#a981ff;
  --acc:var(--magenta);              /* per-section override */
  --acc-ink:#14101a;                 /* readable text ON an accent fill */
  /* live channel colours (distinct, equal weight — neither is "default") */
  --men:#39c2ff; --trans:#ff8fc6;
  /* shape */
  --rad:14px; --rad-lg:22px; --maxw:1180px; --read:68ch;
  --shadow:0 18px 50px -22px rgba(0,0,0,.75);
  --shadow-acc:10px 10px 0 var(--acc);
  --display:'Bricolage Grotesque',ui-sans-serif,system-ui,sans-serif;
  --serif:'Newsreader',Georgia,'Times New Roman',serif;
}

/* ---- reset ---------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--ink); color:var(--text);
  font-family:var(--serif); font-size:1.075rem; line-height:1.7;
  font-optical-sizing:auto; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.noscroll{overflow:hidden}
img{max-width:100%; height:auto; display:block}
a{color:var(--text); text-decoration-color:color-mix(in oklab,var(--acc) 70%,transparent); text-underline-offset:3px}
a:hover{text-decoration-color:var(--acc)}
h1,h2,h3,h4{font-family:var(--display); font-weight:800; line-height:1.04; letter-spacing:-.015em; margin:0 0 .5em}
strong{font-weight:600}
hr{border:0;border-top:1px solid var(--line);margin:2.4rem 0}
::selection{background:var(--magenta);color:#fff}

/* grain + vignette atmosphere */
body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:9999; opacity:.05;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.container{width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(18px,4vw,40px)}

.skip{position:absolute;left:-9999px;top:0;background:var(--acc);color:#14101a;padding:.6rem 1rem;font-family:var(--display);font-weight:700;z-index:10000;border-radius:0 0 10px 0}
.skip:focus{left:0}
:focus-visible{outline:3px solid var(--teal); outline-offset:2px; border-radius:4px}

/* ---- transparency strip --------------------------------------------------- */
.transparency{background:#0e0a13;border-bottom:1px solid var(--line);font-family:var(--display);font-size:.82rem;color:var(--muted)}
.transparency-in{display:flex;gap:.6rem;align-items:center;padding:.5rem 0;flex-wrap:wrap}
.transparency a{color:var(--marigold);font-weight:600;text-decoration:underline}
.transparency .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px color-mix(in oklab,var(--teal) 25%,transparent);flex:0 0 auto}

/* ---- masthead ------------------------------------------------------------- */
.masthead{position:sticky;top:0;z-index:200;background:color-mix(in oklab,var(--ink) 88%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.masthead-in{display:flex;align-items:center;gap:1.2rem;padding:.7rem 0}
.brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text)}
.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;background:var(--magenta);color:#14101a;font-family:var(--display);font-weight:800;font-size:1.05rem;letter-spacing:-.03em;transform:rotate(-4deg);box-shadow:3px 3px 0 var(--violet)}
.brand-words{font-family:var(--display);font-weight:800;font-size:1.32rem;letter-spacing:-.02em;line-height:1}
.brand-q{color:var(--magenta)}
.brand-foot .brand-mark{width:34px;height:34px}

.navtoggle{margin-left:auto;display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.navtoggle span{width:26px;height:2.5px;background:var(--text);border-radius:2px;transition:.25s}
.navtoggle.is-open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.navtoggle.is-open span:nth-child(2){opacity:0}
.navtoggle.is-open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.primary{margin-left:auto}
.primary ul{display:flex;gap:.3rem;list-style:none;margin:0;padding:0}
.primary a{font-family:var(--display);font-weight:600;font-size:.95rem;text-decoration:none;color:var(--muted);padding:.45rem .7rem;border-radius:9px;display:block;transition:.18s}
.primary a:hover{color:var(--text);background:var(--ink-2)}
.primary a.active{color:var(--text);background:var(--ink-3);box-shadow:inset 0 -3px 0 var(--magenta)}

/* ---- ticker --------------------------------------------------------------- */
.ticker{overflow:hidden;border-bottom:1px solid var(--line);background:var(--magenta)}
.ticker-track{display:inline-flex;gap:1.4rem;align-items:center;white-space:nowrap;padding:.34rem 0;font-family:var(--display);font-weight:700;font-size:.82rem;color:#14101a;text-transform:uppercase;letter-spacing:.04em;animation:marquee 28s linear infinite}
.ticker-track span{flex:0 0 auto}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- breadcrumbs ---------------------------------------------------------- */
.crumbs{font-family:var(--display);font-size:.82rem;color:var(--faint);padding:1rem 0 0}
.crumbs a{color:var(--muted);text-decoration:none}
.crumbs a:hover{color:var(--text)}
.crumbs .sep{color:var(--line);margin:0 .15rem}

/* ---- buttons -------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);font-weight:700;font-size:1rem;text-decoration:none;padding:.85rem 1.4rem;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s;line-height:1}
.btn:hover{transform:translateY(-2px)}
.btn-sm{padding:.5rem .9rem;font-size:.85rem}
.btn-solid{background:var(--magenta);color:#14101a;box-shadow:5px 5px 0 var(--violet)}
.btn-solid:hover{box-shadow:7px 7px 0 var(--violet)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--text)}
.btn-men{background:var(--men);color:#06121b;box-shadow:5px 5px 0 #0a4a6b}
.btn-men:hover{box-shadow:7px 7px 0 #0a4a6b}
.btn-trans{background:var(--trans);color:#2a0c1c;box-shadow:5px 5px 0 #7a2a55}
.btn-trans:hover{box-shadow:7px 7px 0 #7a2a55}

/* ---- live chooser (explicit, never pre-selected) -------------------------- */
.live-chooser{border:1px solid var(--line);background:linear-gradient(180deg,var(--ink-2),var(--ink));border-radius:var(--rad-lg);padding:clamp(1.2rem,3vw,2rem);margin:2.2rem 0;position:relative;overflow:hidden}
.live-chooser::before{content:"18+";position:absolute;top:10px;right:16px;font-family:var(--display);font-weight:800;font-size:.7rem;letter-spacing:.1em;color:var(--faint);border:1px solid var(--line);border-radius:999px;padding:.15rem .5rem}
.live-chooser-row{display:flex;gap:1rem;flex-wrap:wrap}
.live-chooser .btn{flex:1 1 220px;justify-content:center}
.chooser-note{margin:.9rem 0 0;font-family:var(--display);font-size:.8rem;color:var(--faint)}

/* ---- eyebrow -------------------------------------------------------------- */
.eyebrow{font-family:var(--display);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;margin:0 0 .7rem;display:inline-flex;align-items:center;gap:.5rem;color:var(--text)}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--acc);border-radius:2px}
.eyebrow-magenta{--acc:var(--magenta)} .eyebrow-marigold{--acc:var(--marigold)}
.eyebrow-teal{--acc:var(--teal)} .eyebrow-violet{--acc:var(--violet)}

/* ---- byline --------------------------------------------------------------- */
.byline{font-family:var(--display);margin:.4rem 0 1.6rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.byline-author{font-weight:700;color:var(--text);text-decoration:none}
.byline-author:hover{text-decoration:underline;text-decoration-color:var(--magenta)}
.byline-role{color:var(--faint);font-size:.85rem;margin-left:.4rem}
.byline-meta{color:var(--muted);font-size:.82rem;margin-top:.25rem}
.byline-upd{color:var(--marigold)}

/* ---- poster + figures ----------------------------------------------------- */
.poster{margin:0 0 2rem;border-radius:var(--rad-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);position:relative}
.poster img{width:100%;aspect-ratio:5/3;object-fit:cover}
.poster-magenta{--acc:var(--magenta)} .poster-marigold{--acc:var(--marigold)}
.poster-teal{--acc:var(--teal)} .poster-violet{--acc:var(--violet)}
.poster::after{content:"";position:absolute;inset:0;border:3px solid var(--acc);border-radius:var(--rad-lg);mix-blend-mode:screen;opacity:.5;pointer-events:none}

.fig{margin:2rem 0;border-radius:var(--rad);overflow:hidden;border:1px solid var(--line)}
.fig img{width:100%}
figcaption{font-family:var(--display);font-size:.8rem;color:var(--muted);padding:.6rem .9rem;background:var(--ink-2);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.credit{color:var(--faint)}

/* ---- article typography --------------------------------------------------- */
.article{max-width:var(--read);margin-inline:auto}
.article-wide{max-width:860px;margin-inline:auto}
.article h1,.page-h1{font-size:clamp(2.1rem,5.5vw,3.4rem);margin:.2rem 0 .6rem;letter-spacing:-.025em}
.article h2{font-size:clamp(1.5rem,3.4vw,2rem);margin:2.4rem 0 .7rem;padding-top:.4rem}
.article h2::before{content:"";display:block;width:46px;height:4px;background:var(--acc);border-radius:3px;margin-bottom:.7rem}
.article h3{font-size:1.28rem;margin:1.8rem 0 .5rem;color:var(--text)}
.article p{margin:0 0 1.2rem}
.article a{color:var(--text);font-weight:500}
.article ul,.article ol{margin:0 0 1.3rem;padding-left:1.3rem}
.article li{margin:.4rem 0}
.article ul li::marker{color:var(--acc)}
.lede{font-size:1.3rem;line-height:1.55;color:var(--text)}
.lede::first-letter{font-family:var(--display);font-weight:800;float:left;font-size:3.4em;line-height:.72;padding:.05em .12em 0 0;color:var(--magenta)}

/* pull quote breaks the measure */
.pullquote{margin:2rem -10px;padding:1.2rem 1.4rem;border-left:5px solid var(--acc);background:var(--ink-2);border-radius:0 var(--rad) var(--rad) 0}
.pullquote p{font-family:var(--display);font-weight:600;font-size:1.5rem;line-height:1.25;margin:0;letter-spacing:-.01em}
.pullquote cite{display:block;margin-top:.6rem;font-family:var(--serif);font-style:italic;color:var(--muted);font-size:.95rem}

/* callouts / notes */
.callout{margin:1.8rem 0;border:1px solid var(--line);border-radius:var(--rad);padding:1.2rem 1.3rem;background:var(--ink-2)}
.callout h3{font-size:1.05rem;margin:0 0 .5rem}
.callout-body{font-size:.98rem;color:var(--muted)}
.callout-body :last-child{margin-bottom:0}
.callout-note{border-left:4px solid var(--teal)}
.callout-tip{border-left:4px solid var(--marigold)}
.callout-key{border-left:4px solid var(--violet)}

/* content warning */
.cw{display:flex;gap:.7rem;align-items:flex-start;margin:1.6rem 0;padding:.9rem 1.1rem;border-radius:var(--rad);background:color-mix(in oklab,var(--marigold) 14%,var(--ink-2));border:1px solid color-mix(in oklab,var(--marigold) 35%,var(--line));font-size:.96rem;color:var(--text)}
.cw-tag{font-family:var(--display);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;background:var(--marigold);color:#14101a;padding:.2rem .5rem;border-radius:6px;flex:0 0 auto;margin-top:.1rem}

/* resources box */
.resources{margin:2rem 0;border:1px dashed color-mix(in oklab,var(--teal) 55%,var(--line));border-radius:var(--rad);padding:1.3rem 1.4rem;background:color-mix(in oklab,var(--teal) 7%,var(--ink-2))}
.resources h3{font-size:1.1rem;margin:0 0 .7rem;color:var(--text)}
.resources ul{list-style:none;margin:0;padding:0;font-family:var(--display);font-size:.96rem}
.resources li{margin:.5rem 0;padding-left:1.2rem;position:relative}
.resources li::before{content:"→";position:absolute;left:0;color:var(--teal)}
.resources a{font-weight:700;color:var(--text)}
.res-note{font-weight:400;color:var(--muted);font-family:var(--serif)}
.res-foot{font-family:var(--serif);font-style:italic;font-size:.82rem;color:var(--faint);margin:.9rem 0 0}

/* inline external 18+ link marker */
.inline-aff{font-weight:600;color:var(--text);text-decoration-color:var(--marigold)}
.inline-aff::after{content:"↗";font-family:var(--display);font-weight:700;font-size:.8em;color:var(--marigold);margin-left:.3em;vertical-align:.1em;text-decoration:none;white-space:nowrap}

/* partner links */
.partner-strip{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin:1.5rem 0;padding:1rem;border:1px solid var(--line);border-radius:var(--rad);background:var(--ink-2)}
.partner-strip span{font-family:var(--display);font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}
.paper .partner-strip{background:#fff8ea;border-color:#e1cfb5}

/* forum */
.forum-shell{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:1.5rem;align-items:start;margin-top:1.4rem}
.forum-panel,.forum-thread,.forum-form{border:1px solid var(--line);background:var(--ink-2);border-radius:var(--rad-lg);padding:1.2rem}
.forum-thread{display:block;text-decoration:none;color:var(--text);margin-bottom:1rem;transition:transform .16s,border-color .16s}
.forum-thread:hover{transform:translateY(-2px);border-color:var(--magenta)}
.forum-thread h2,.forum-thread h3{font-size:1.25rem;margin:0 0 .35rem}
.forum-meta{font-family:var(--display);font-size:.8rem;color:var(--faint);margin:.35rem 0 0}
.forum-body{white-space:pre-wrap;color:var(--muted)}
.forum-list{margin-top:1rem}
.forum-reply{border-top:1px solid var(--line);padding:1rem 0}
.forum-reply:first-child{border-top:0}
.forum-sidebar{position:sticky;top:130px}
.forum-form label{display:block;font-family:var(--display);font-weight:700;margin:.8rem 0 .3rem}
.forum-form input,.forum-form textarea{width:100%;border:1px solid var(--line);border-radius:12px;background:#0f0b14;color:var(--text);padding:.75rem;font:inherit}
.forum-form textarea{min-height:140px;resize:vertical}
.forum-form .hp{position:absolute;left:-9999px;opacity:0}
.forum-alert{padding:.85rem 1rem;border-radius:12px;margin:1rem 0;font-family:var(--display);font-size:.95rem}
.forum-alert.ok{background:color-mix(in oklab,var(--teal) 18%,var(--ink-2));border:1px solid color-mix(in oklab,var(--teal) 45%,var(--line))}
.forum-alert.bad{background:color-mix(in oklab,var(--magenta) 16%,var(--ink-2));border:1px solid color-mix(in oklab,var(--magenta) 45%,var(--line))}

/* ---- cards / grid --------------------------------------------------------- */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.4rem;margin:1.6rem 0}
.card{--acc:var(--magenta);display:flex;flex-direction:column;text-decoration:none;color:var(--text);background:var(--ink-2);border:1px solid var(--line);border-radius:var(--rad-lg);overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s}
.card:hover{transform:translateY(-4px);border-color:var(--acc);box-shadow:0 22px 40px -26px var(--acc)}
.card-art{display:block;aspect-ratio:10/7;overflow:hidden;background:var(--ink-3)}
.card-art img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card-art img{transform:scale(1.05)}
.card-body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.4rem}
.card-kicker{font-family:var(--display);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--acc)}
.card-title{font-family:var(--display);font-weight:800;font-size:1.2rem;line-height:1.1;letter-spacing:-.01em}
.card-excerpt{font-size:.95rem;color:var(--muted);line-height:1.5}
.card-go{font-family:var(--display);font-weight:700;font-size:.85rem;color:var(--text);margin-top:.3rem}
.card-magenta{--acc:var(--magenta)} .card-marigold{--acc:var(--marigold)}
.card-teal{--acc:var(--teal)} .card-violet{--acc:var(--violet)}

/* ---- home hero ------------------------------------------------------------ */
.hero{position:relative;padding:clamp(2.4rem,6vw,4.6rem) 0 clamp(1.6rem,4vw,2.6rem)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.6rem,4vw,3rem);align-items:center}
.hero-kicker{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;color:var(--marigold);margin:0 0 1rem}
.hero h1{font-size:clamp(2.6rem,7vw,5rem);letter-spacing:-.03em;margin:0 0 1rem}
.hero h1 em{font-style:normal;color:var(--magenta);position:relative}
.hero-sub{font-size:1.25rem;color:var(--muted);max-width:46ch;margin:0 0 1.6rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-art{position:relative}
.hero-art img{border-radius:var(--rad-lg);border:1px solid var(--line);box-shadow:var(--shadow);transform:rotate(2deg)}
.hero-badge{position:absolute;left:-14px;bottom:-14px;background:var(--teal);color:#06201b;font-family:var(--display);font-weight:800;font-size:.82rem;padding:.55rem .8rem;border-radius:12px;transform:rotate(-5deg);box-shadow:4px 4px 0 #0c2f29}

/* section heading band */
.band{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin:3rem 0 1.2rem;padding-bottom:.8rem;border-bottom:2px solid var(--line)}
.band h2{font-size:clamp(1.6rem,3.6vw,2.3rem);margin:0}
.band .more{font-family:var(--display);font-weight:700;font-size:.9rem;color:var(--muted);text-decoration:none;white-space:nowrap}
.band .more:hover{color:var(--magenta)}

/* generic page header */
.page-head{padding:1.4rem 0 .4rem;max-width:54ch}
.page-head.center{margin-inline:auto;text-align:center}
.page-lead{font-size:1.2rem;color:var(--muted)}

/* paper block (light editorial section) */
.paper{background:var(--paper);color:var(--paper-ink);border-radius:var(--rad-lg);padding:clamp(1.6rem,4vw,3rem);margin:2.6rem 0}
.paper h2,.paper h3{color:var(--paper-ink)}
.paper a{color:#8a1252;text-decoration-color:#d23a86}
.paper .eyebrow{color:var(--paper-ink)}

/* feature list / stats-free fact rows */
.deflist{display:grid;gap:.2rem;margin:1.4rem 0}
.deflist div{display:grid;grid-template-columns:auto 1fr;gap:1rem;padding:.7rem 0;border-bottom:1px solid var(--line)}
.deflist dt{font-family:var(--display);font-weight:700;color:var(--text)}
.deflist dd{margin:0;color:var(--muted)}

/* tags */
.tags{display:flex;gap:.5rem;flex-wrap:wrap;margin:1.4rem 0}
.tag{font-family:var(--display);font-weight:600;font-size:.8rem;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:.3rem .8rem;text-decoration:none}
.tag:hover{border-color:var(--magenta);color:var(--text)}

/* sticky bottom cta (tasteful, dismissible-feeling, not nagging) */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:150;background:color-mix(in oklab,var(--ink) 92%,transparent);backdrop-filter:blur(8px);border-top:1px solid var(--line);transform:translateY(110%);animation:rise .5s 1.1s forwards}
@keyframes rise{to{transform:translateY(0)}}
.sticky-in{display:flex;align-items:center;gap:1rem;padding:.7rem 0;flex-wrap:wrap}
.sticky-in p{margin:0;font-family:var(--display);font-weight:600;font-size:.95rem}
.sticky-in .spacer{flex:1}
.sticky-in .btn{padding:.6rem 1rem;font-size:.9rem}

/* ---- footer --------------------------------------------------------------- */
.site-footer{margin-top:4rem;background:#0e0a13;border-top:1px solid var(--line);padding:3rem 0 4.5rem}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:2rem}
.footer-col h4{font-family:var(--display);font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--faint);margin:0 0 .8rem}
.footer-col a{display:block;color:var(--muted);text-decoration:none;font-size:.94rem;padding:.22rem 0}
.footer-col a:hover{color:var(--text)}
.foot-tag{color:var(--muted);font-size:.95rem;margin:.8rem 0 .3rem;max-width:30ch}
.foot-since{color:var(--faint);font-size:.85rem;font-family:var(--display)}
.footer-bottom{margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.footer-bottom p{margin:.3rem 0;color:var(--faint);font-size:.85rem}
.disclaimer{max-width:none;line-height:1.6}
.disclaimer a{color:var(--muted)}
.disclaimer code{font-family:ui-monospace,monospace;font-size:.85em;color:var(--marigold)}

/* ---- age gate ------------------------------------------------------------- */
.agegate{position:fixed;inset:0;z-index:10001;background:rgba(8,5,12,.86);backdrop-filter:blur(8px);display:grid;place-items:center;padding:24px}
.agegate[hidden]{display:none}
.agegate-box{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--rad-lg);max-width:440px;padding:2.2rem;text-align:center;box-shadow:var(--shadow)}
.agegate-mark{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:13px;background:var(--magenta);color:#14101a;font-family:var(--display);font-weight:800;transform:rotate(-4deg);margin-bottom:1rem;box-shadow:3px 3px 0 var(--violet)}
.agegate-box h2{font-size:1.5rem}
.agegate-box p{color:var(--muted);font-size:.96rem}
.agegate-actions{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin:1.3rem 0 .4rem}
.agegate-foot a{color:var(--marigold)}

/* ---- utilities ------------------------------------------------------------ */
.center{text-align:center}
.muted{color:var(--muted)}
.mt0{margin-top:0}.mb0{margin-bottom:0}
.note-sm{font-family:var(--display);font-size:.82rem;color:var(--faint)}
.divider-art{height:3px;background:repeating-linear-gradient(90deg,var(--magenta) 0 22px,var(--marigold) 22px 44px,var(--teal) 44px 66px,var(--violet) 66px 88px);border-radius:2px;margin:3rem 0;opacity:.85}

/* ---- responsive ----------------------------------------------------------- */
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr}
  .hero-art{order:-1;max-width:460px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .forum-shell{grid-template-columns:1fr}
  .forum-sidebar{position:static}
}
@media (max-width:760px){
  .navtoggle{display:flex}
  .primary{position:fixed;inset:0 0 0 auto;width:min(82vw,320px);background:var(--ink-2);border-left:1px solid var(--line);transform:translateX(100%);transition:transform .28s ease;padding:5rem 1.2rem 2rem;margin:0;overflow:auto;z-index:190}
  .primary.open{transform:translateX(0)}
  .primary ul{flex-direction:column;gap:.2rem}
  .primary a{font-size:1.1rem;padding:.8rem 1rem}
  .pullquote{margin-inline:0}
}
@media (max-width:560px){
  body{font-size:1.02rem}
  .footer-grid{grid-template-columns:1fr}
  .live-chooser .btn{flex:1 1 100%}
}

/* ---- motion & contrast preferences --------------------------------------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .sticky-cta{transform:none}
}
@media (prefers-contrast:more){
  :root{--muted:#d6cee2;--faint:#b7adc6;--line:#5a4f6e}
}
