/* ============================================
   CITY OF PUNK — DESIGN SYSTEM
   Consolidated from the design samples: shared chrome + per-page styles.
   Dark cyberpunk: void black, acid green, hot pink, cyan, violet.
   Fonts: Anton (display), Bricolage Grotesque (UI/body), Space Mono (meta).
   ============================================ */
:root{
  --void:#05060a;
  --void-2:#0a0c14;
  --void-3:#0e1019;
  --ink:#f4f3ff;
  --dim:#7b7f99;
  --dim-2:#9da1bd;
  --acid:#c6ff00;
  --acid-dim:#8fb800;
  --hot:#ff2a6d;
  --cyan:#05d9e8;
  --violet:#7b2fff;
  --grid:rgba(123,47,255,.10);
  --edge:rgba(255,255,255,.08);
  --edge-2:rgba(255,255,255,.14);
  --glass:rgba(13,15,24,.55);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--void);color:var(--ink);
  font-family:'Bricolage Grotesque',sans-serif;
  overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased;
}
::selection{background:var(--acid);color:var(--void)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---- atmosphere ---- */
.grain{position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.scan{position:fixed;inset:0;z-index:201;pointer-events:none;opacity:.35;
  background:repeating-linear-gradient(to bottom,transparent 0,transparent 2px,rgba(0,0,0,.18) 3px,transparent 4px)}
.glow-a{position:fixed;top:-15%;left:-12%;width:50vw;height:50vw;border-radius:50%;
  background:radial-gradient(circle,var(--violet),transparent 60%);filter:blur(70px);opacity:.22;z-index:0;pointer-events:none}
.glow-b{position:fixed;bottom:-20%;right:-12%;width:46vw;height:46vw;border-radius:50%;
  background:radial-gradient(circle,var(--hot),transparent 62%);filter:blur(80px);opacity:.15;z-index:0;pointer-events:none}
.bg-grid{position:fixed;inset:-50%;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:54px 54px;transform:perspective(500px) rotateX(60deg);
  mask-image:radial-gradient(ellipse 70% 40% at 50% 0%,#000 5%,transparent 65%);
  -webkit-mask-image:radial-gradient(ellipse 70% 40% at 50% 0%,#000 5%,transparent 65%);opacity:.55}

/* ---- nav ---- */
nav.site-nav{position:fixed;top:0;left:0;right:0;z-index:120;display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(20px,5vw,64px);backdrop-filter:blur(14px);
  background:linear-gradient(to bottom,rgba(5,6,10,.9),rgba(5,6,10,.4));border-bottom:1px solid var(--edge)}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:-.03em;font-size:1.02rem}
.brand .mark svg{width:28px;height:28px;display:block}
.brand b{color:var(--acid)}
.brand .v{color:var(--dim);font-family:'Space Mono',monospace;font-size:.6rem;letter-spacing:.1em;padding:2px 6px;border:1px solid var(--edge);border-radius:4px;margin-left:4px}
.nav-links{display:flex;gap:30px;align-items:center;font-family:'Space Mono',monospace;font-size:.76rem;letter-spacing:.04em}
.nav-links a{color:var(--dim);transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--acid);transition:width .25s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.05em;padding:9px 16px;
  border:1px solid var(--acid);color:var(--acid);border-radius:6px;transition:all .2s;text-transform:uppercase}
.nav-cta:hover{background:var(--acid);color:var(--void);box-shadow:0 0 24px rgba(198,255,0,.5)}
@media(max-width:900px){.nav-links{display:none}}

/* ---- buttons ---- */
.btn{font-family:'Space Mono',monospace;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;
  padding:14px 26px;border-radius:8px;transition:all .22s;display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:none}
.btn-primary{background:var(--acid);color:var(--void);font-weight:700}
.btn-primary:hover{box-shadow:0 0 30px rgba(198,255,0,.5);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--edge-2)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(255,255,255,.04)}
.btn-sm{padding:10px 18px;font-size:.74rem}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--void);animation:pulse 1.4s infinite}
@keyframes pulse{50%{opacity:.3}}

/* ---- shared type ---- */
.eyebrow{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--cyan)}
.sec-tag{font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--hot);display:block;margin-bottom:16px}
h1,h2,h3{letter-spacing:-.02em}
.display{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;line-height:.9;letter-spacing:-.01em}

/* ---- breadcrumb ---- */
.crumb{font-family:'Space Mono',monospace;font-size:.74rem;color:var(--dim);display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.crumb a:hover{color:var(--acid)}
.crumb span{color:var(--edge-2)}

/* ---- footer ---- */
footer{position:relative;z-index:2;border-top:1px solid var(--edge);padding:54px clamp(20px,6vw,80px) 40px;background:var(--void-2)}
.foot-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px;max-width:1280px;margin:0 auto}
.foot-brand{max-width:280px}
.foot-brand p{color:var(--dim);font-size:.86rem;margin-top:14px;line-height:1.6}
.foot-cols{display:flex;gap:56px;flex-wrap:wrap}
.fcol h5{font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);margin-bottom:16px}
.fcol a{display:block;color:var(--dim);font-size:.86rem;margin-bottom:10px;transition:color .2s}
.fcol a:hover{color:var(--acid)}
.foot-bot{max-width:1280px;margin:48px auto 0;padding-top:24px;border-top:1px solid var(--edge);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-family:'Space Mono',monospace;font-size:.7rem;color:var(--dim)}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(34px);transition:all .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
/* No-JS / pre-JS safety: only hide when JS has tagged the page */
html:not(.js) .reveal{opacity:1;transform:none}

/* ---- utility ---- */
.wrap{max-width:1240px;margin:0 auto;padding:0 clamp(20px,6vw,64px)}
.tag-pill{font-family:'Space Mono',monospace;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 11px;border:1px solid var(--edge-2);border-radius:20px;color:var(--dim);transition:all .18s;display:inline-block}
a.tag-pill:hover,.tag-pill.on{border-color:var(--acid);color:var(--acid)}

/* ============================================
   HOME (landing)
   ============================================ */
header.home-hero{position:relative;z-index:2;min-height:100vh;display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;padding:120px 20px 60px}
.home-hero .eyebrow{margin-bottom:26px;display:flex;align-items:center;gap:12px;opacity:0;animation:rise .8s .1s forwards}
.home-hero .eyebrow::before,.home-hero .eyebrow::after{content:'';width:34px;height:1px;background:linear-gradient(90deg,transparent,var(--cyan))}
.home-hero .eyebrow::after{background:linear-gradient(90deg,var(--cyan),transparent)}
.home-hero h1{font-family:'Anton',sans-serif;font-weight:400;font-size:clamp(3.4rem,15vw,12rem);line-height:.84;letter-spacing:-.02em;text-transform:uppercase;position:relative}
.home-hero h1 .l1{display:block;opacity:0;animation:rise .9s .2s forwards}
.home-hero h1 .l2{display:block;opacity:0;animation:rise .9s .34s forwards;
  background:linear-gradient(100deg,var(--hot),var(--violet) 45%,var(--cyan));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;position:relative}
.glitch{position:relative;display:inline-block}
.glitch::before,.glitch::after{content:attr(data-t);position:absolute;inset:0;-webkit-background-clip:text;background-clip:text}
.glitch::before{color:var(--cyan);-webkit-text-fill-color:var(--cyan);animation:gl1 3.4s infinite steps(2)}
.glitch::after{color:var(--hot);-webkit-text-fill-color:var(--hot);animation:gl2 2.8s infinite steps(2)}
@keyframes gl1{0%,92%,100%{opacity:0;transform:none}93%{opacity:.85;transform:translate(-3px,2px)}96%{opacity:.85;transform:translate(2px,-1px)}}
@keyframes gl2{0%,90%,100%{opacity:0;transform:none}91%{opacity:.85;transform:translate(3px,-2px)}95%{opacity:.85;transform:translate(-2px,1px)}}
.home-hero .sub{max-width:620px;margin:34px auto 0;font-size:clamp(1rem,2.1vw,1.22rem);color:var(--dim);line-height:1.65;opacity:0;animation:rise .9s .5s forwards}
.home-hero .sub b{color:var(--ink);font-weight:600}
.hero-cta{display:flex;gap:16px;margin-top:44px;flex-wrap:wrap;justify-content:center;opacity:0;animation:rise .9s .62s forwards}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* visualizer */
.viz-wrap{position:relative;width:min(880px,92vw);margin:60px auto 0;opacity:0;animation:rise 1s .8s forwards}
.viz-shell{border:1px solid var(--edge);border-radius:16px;overflow:hidden;background:var(--glass);backdrop-filter:blur(8px);
  box-shadow:0 30px 80px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.05)}
.viz-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--edge);
  font-family:'Space Mono',monospace;font-size:.7rem;color:var(--dim)}
.dot{width:11px;height:11px;border-radius:50%}
.dot.r{background:var(--hot)}.dot.y{background:var(--acid)}.dot.g{background:var(--cyan)}
.viz-bar .track{margin-left:14px;color:var(--ink)}
.viz-bar .track .blink{color:var(--acid);animation:pulse 1s infinite}
.viz-bar .right{margin-left:auto;letter-spacing:.1em}
canvas#viz{display:block;width:100%;height:230px;background:radial-gradient(ellipse at 50% 120%,rgba(123,47,255,.12),transparent 70%)}
.viz-controls{display:flex;align-items:center;gap:18px;padding:14px 18px;border-top:1px solid var(--edge)}
.play{width:46px;height:46px;border-radius:50%;border:1px solid var(--acid);background:transparent;color:var(--acid);
  display:grid;place-items:center;cursor:pointer;transition:all .2s;flex-shrink:0}
.play:hover{background:var(--acid);color:var(--void);box-shadow:0 0 22px rgba(198,255,0,.5)}
.play svg{width:18px;height:18px}
.viz-meta{font-family:'Space Mono',monospace;font-size:.74rem;color:var(--dim)}
.viz-meta b{color:var(--ink)}
.seed{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.chip{font-family:'Space Mono',monospace;font-size:.66rem;padding:5px 10px;border:1px solid var(--edge);
  border-radius:20px;color:var(--dim);cursor:pointer;transition:all .18s}
.chip:hover,.chip.on{border-color:var(--acid);color:var(--acid)}
.hint{font-family:'Space Mono',monospace;font-size:.66rem;color:var(--dim);text-align:center;margin-top:14px;letter-spacing:.06em}

/* marquee */
.marquee{margin-top:90px;border-top:1px solid var(--edge);border-bottom:1px solid var(--edge);
  padding:20px 0;overflow:hidden;white-space:nowrap;background:var(--void-2);position:relative;z-index:2}
.marquee-track{display:inline-block;animation:scroll 28s linear infinite}
.marquee span{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:1.5rem;letter-spacing:.04em;color:var(--dim);margin:0 26px}
.marquee span em{color:var(--acid);font-style:normal}
@keyframes scroll{to{transform:translateX(-50%)}}

/* home sections */
section.home-sec{position:relative;z-index:2;padding:clamp(80px,12vw,160px) clamp(20px,6vw,80px);max-width:1280px;margin:0 auto}
.sec-head{margin-bottom:64px;max-width:680px}
.sec-head h2{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;font-size:clamp(2.2rem,6vw,4.4rem);line-height:.92;letter-spacing:-.01em}
.sec-head h2 em{font-style:normal;color:var(--acid)}
.sec-head p{color:var(--dim);margin-top:20px;font-size:1.05rem;line-height:1.7}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{border:1px solid var(--edge);border-radius:16px;padding:32px;background:var(--glass);
  backdrop-filter:blur(6px);position:relative;overflow:hidden;transition:all .3s}
.card:hover{border-color:rgba(198,255,0,.3);transform:translateY(-4px)}
.card .ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;margin-bottom:22px;
  border:1px solid var(--edge);background:rgba(255,255,255,.02)}
.card .ic svg{width:24px;height:24px;stroke:var(--acid)}
.card h3{font-size:1.3rem;font-weight:700;letter-spacing:-.02em;margin-bottom:10px}
.card p{color:var(--dim);font-size:.95rem;line-height:1.65}
.card .num{position:absolute;top:24px;right:26px;font-family:'Space Mono',monospace;font-size:.72rem;color:var(--dim)}
.c-wide{grid-column:span 6}.c-third{grid-column:span 4}.c-half{grid-column:span 6}
@media(max-width:880px){.c-wide,.c-third,.c-half{grid-column:span 12}}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--edge);
  border:1px solid var(--edge);border-radius:16px;overflow:hidden}
.stat{background:var(--void);padding:38px 28px;text-align:center}
.stat .big{font-family:'Anton',sans-serif;font-size:clamp(2.4rem,6vw,3.6rem);
  background:linear-gradient(120deg,var(--cyan),var(--acid));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.stat .lbl{font-family:'Space Mono',monospace;font-size:.72rem;color:var(--dim);margin-top:10px;letter-spacing:.06em;text-transform:uppercase}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:20px}
.step{position:relative;padding-top:40px}
.step .n{font-family:'Anton',sans-serif;font-size:3.2rem;color:transparent;-webkit-text-stroke:1.5px var(--violet);line-height:.7;position:absolute;top:0;left:0;opacity:.85}
.step h4{font-size:1.15rem;font-weight:700;margin-bottom:8px;margin-top:6px}
.step p{color:var(--dim);font-size:.92rem;line-height:1.6}
@media(max-width:760px){.steps{grid-template-columns:1fr;gap:36px}}
.cta-band{text-align:center;padding:clamp(80px,12vw,150px) 20px;position:relative;z-index:2;border-top:1px solid var(--edge);margin-top:40px}
.cta-band h2{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:clamp(2.6rem,9vw,7rem);line-height:.86;letter-spacing:-.01em}
.cta-band h2 em{font-style:normal;background:linear-gradient(100deg,var(--hot),var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cta-band p{color:var(--dim);max-width:480px;margin:24px auto 36px;font-size:1.08rem}

/* ============================================
   LISTING PAGES (The Signal / categories / archive / topics / authors)
   ============================================ */
.page-hero{position:relative;z-index:2;padding:140px 0 50px;text-align:center}
.page-hero .display{font-size:clamp(2.6rem,10vw,7rem)}
.page-hero .display em{font-style:normal;background:linear-gradient(100deg,var(--hot),var(--violet) 50%,var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.page-hero p{color:var(--dim);max-width:560px;margin:22px auto 0;font-size:1.08rem}
.page-hero .eyebrow{margin-bottom:20px;display:block}
.filters{position:relative;z-index:2;display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:44px auto 0;max-width:760px}
.list-meta{position:relative;z-index:2;text-align:center;font-family:'Space Mono',monospace;font-size:.72rem;color:var(--dim);margin-top:26px;letter-spacing:.08em;text-transform:uppercase}

/* featured post */
.featured{position:relative;z-index:2;margin:48px auto 0;display:grid;grid-template-columns:1.15fr 1fr;gap:0;
  border:1px solid var(--edge);border-radius:18px;overflow:hidden;background:var(--glass);backdrop-filter:blur(6px);transition:all .3s}
.featured:hover{border-color:rgba(198,255,0,.3)}
.featured .art{position:relative;min-height:340px;background:
  radial-gradient(circle at 30% 30%,rgba(123,47,255,.5),transparent 55%),
  radial-gradient(circle at 75% 70%,rgba(255,42,109,.45),transparent 55%),var(--void-3);
  display:flex;align-items:flex-end;padding:24px;overflow:hidden}
.featured .art::before{content:'';position:absolute;inset:0;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:30px 30px;opacity:.4}
.featured .art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.featured .art .eq{display:flex;gap:5px;align-items:flex-end;height:80px;position:relative;z-index:1}
.featured .art .eq i{width:7px;background:linear-gradient(to top,var(--violet),var(--acid));border-radius:3px;animation:eqbar 1.2s ease-in-out infinite}
@keyframes eqbar{0%,100%{height:18%}50%{height:100%}}
.featured .body{padding:40px;display:flex;flex-direction:column;justify-content:center}
.featured .meta{font-family:'Space Mono',monospace;font-size:.7rem;color:var(--cyan);letter-spacing:.1em;margin-bottom:16px;text-transform:uppercase}
.featured h2{font-size:clamp(1.6rem,3.2vw,2.4rem);font-weight:800;line-height:1.1;margin-bottom:14px}
.featured p{color:var(--dim);font-size:.98rem;margin-bottom:24px}
.featured .author{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--dim);margin-top:auto}
.featured .author .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--hot))}
@media(max-width:840px){.featured{grid-template-columns:1fr}.featured .art{min-height:200px}}

/* post cards */
.posts{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:24px auto 0}
@media(max-width:980px){.posts{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.posts{grid-template-columns:1fr}}
.post{border:1px solid var(--edge);border-radius:16px;overflow:hidden;background:var(--glass);backdrop-filter:blur(6px);
  transition:all .3s;display:flex;flex-direction:column}
.post:hover{border-color:rgba(198,255,0,.3);transform:translateY(-5px)}
.post .thumb{height:170px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.post .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.post .thumb .badge{position:absolute;top:12px;left:12px;z-index:2;font-family:'Space Mono',monospace;font-size:.6rem;
  letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:20px;background:rgba(5,6,10,.7);backdrop-filter:blur(4px);border:1px solid var(--edge-2)}
.post .thumb.t1{background:radial-gradient(circle at 30% 40%,rgba(5,217,232,.4),transparent 60%),var(--void-3)}
.post .thumb.t2{background:radial-gradient(circle at 70% 50%,rgba(255,42,109,.4),transparent 60%),var(--void-3)}
.post .thumb.t3{background:radial-gradient(circle at 50% 40%,rgba(198,255,0,.3),transparent 60%),var(--void-3)}
.post .thumb.t4{background:radial-gradient(circle at 40% 60%,rgba(123,47,255,.45),transparent 60%),var(--void-3)}
.post .thumb .ico{font-family:'Anton',sans-serif;font-size:2.6rem;color:rgba(255,255,255,.08)}
.post .pbody{padding:22px;display:flex;flex-direction:column;flex:1}
.post .pmeta{font-family:'Space Mono',monospace;font-size:.66rem;color:var(--dim);letter-spacing:.06em;margin-bottom:12px;text-transform:uppercase}
.post h3{font-size:1.18rem;font-weight:700;line-height:1.25;margin-bottom:10px}
.post p{color:var(--dim);font-size:.88rem;flex:1}
.post .read{font-family:'Space Mono',monospace;font-size:.72rem;color:var(--acid);margin-top:16px;display:flex;align-items:center;gap:6px;transition:gap .2s}
.post:hover .read{gap:12px}

/* pagination */
.pager{position:relative;z-index:2;display:flex;gap:8px;justify-content:center;margin:56px auto 0;font-family:'Space Mono',monospace;font-size:.8rem;flex-wrap:wrap}
.pager a,.pager span{min-width:40px;height:40px;display:grid;place-items:center;border:1px solid var(--edge);border-radius:8px;color:var(--dim);transition:all .2s;padding:0 12px}
.pager a:hover,.pager .on{border-color:var(--acid);color:var(--acid)}
.pager .disabled{opacity:.35}

/* newsletter card */
.news{position:relative;z-index:2;margin:90px auto 0;border:1px solid var(--edge);border-radius:18px;
  padding:48px;text-align:center;background:radial-gradient(circle at 50% 0%,rgba(198,255,0,.06),transparent 60%),var(--glass)}
.news .display{font-size:clamp(1.8rem,5vw,3rem)}
.news .display em{font-style:normal;color:var(--acid)}
.news p{color:var(--dim);margin:14px auto 26px;max-width:420px}
.news .form{display:flex;gap:10px;max-width:440px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.news input{flex:1;min-width:220px;background:var(--void);border:1px solid var(--edge-2);border-radius:8px;
  padding:14px 16px;color:var(--ink);font-family:'Space Mono',monospace;font-size:.84rem}
.news input:focus{outline:none;border-color:var(--acid)}

section.pad{padding-bottom:60px}

/* ============================================
   ARTICLE
   ============================================ */
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:130;
  background:linear-gradient(90deg,var(--violet),var(--hot),var(--acid))}
.a-hero{position:relative;z-index:2;padding:130px 0 0}
.a-hero .crumb{margin-bottom:28px}
.a-cat{display:inline-block;font-family:'Space Mono',monospace;font-size:.68rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--cyan);border:1px solid rgba(5,217,232,.35);border-radius:20px;padding:5px 12px;margin-bottom:22px}
.a-hero h1{font-size:clamp(2.1rem,5.5vw,3.8rem);font-weight:800;line-height:1.08;max-width:880px}
.a-hero .standfirst{color:var(--dim-2);font-size:1.2rem;line-height:1.6;max-width:720px;margin-top:22px}
.a-byline{display:flex;align-items:center;gap:16px;margin-top:30px;flex-wrap:wrap;
  font-family:'Space Mono',monospace;font-size:.78rem;color:var(--dim)}
.a-byline .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--hot));
  display:grid;place-items:center;font-weight:700;color:var(--ink);font-family:'Bricolage Grotesque',sans-serif}
.a-byline b{color:var(--ink)}
.a-byline .dot-sep{color:var(--edge-2)}
.a-art{position:relative;z-index:2;height:clamp(220px,38vw,420px);margin:40px 0 0;border-radius:18px;overflow:hidden;
  background:radial-gradient(circle at 25% 30%,rgba(123,47,255,.55),transparent 55%),
  radial-gradient(circle at 78% 65%,rgba(255,42,109,.5),transparent 55%),var(--void-3);
  display:flex;align-items:center;justify-content:center}
.a-art::before{content:'';position:absolute;inset:0;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:40px 40px;opacity:.4}
.a-art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.a-art .wave{display:flex;gap:6px;align-items:center;height:120px;position:relative;z-index:1}
.a-art .wave i{width:8px;background:linear-gradient(to top,var(--violet),var(--cyan),var(--acid));border-radius:4px;animation:eqbar 1.3s ease-in-out infinite}
.a-layout{position:relative;z-index:2;display:grid;grid-template-columns:1fr 240px;gap:60px;margin:56px 0 0;align-items:start}
@media(max-width:920px){.a-layout{grid-template-columns:1fr}.toc{display:none}}

/* article typography (markdown-rendered body) */
.article{font-size:1.08rem;line-height:1.8;color:var(--dim-2);max-width:720px}
.article h2{font-family:'Bricolage Grotesque',sans-serif;font-size:1.75rem;font-weight:700;color:var(--ink);
  margin:48px 0 18px;line-height:1.2;scroll-margin-top:90px}
.article h2::before{content:'';display:inline-block;width:18px;height:18px;margin-right:12px;border-radius:4px;
  background:linear-gradient(135deg,var(--acid),var(--cyan));vertical-align:middle;transform:translateY(-2px)}
.article h3{font-size:1.28rem;font-weight:700;color:var(--ink);margin:34px 0 12px;scroll-margin-top:90px}
.article p{margin-bottom:22px}
.article a{color:var(--acid);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--acid-dim)}
.article strong{color:var(--ink);font-weight:600}
.article ul,.article ol{margin:0 0 22px 4px;padding-left:24px;display:flex;flex-direction:column;gap:10px}
.article li{padding-left:6px}
.article li::marker{color:var(--acid)}
.article blockquote{border-left:3px solid var(--hot);padding:6px 0 6px 22px;margin:28px 0;
  font-size:1.3rem;line-height:1.5;color:var(--ink);font-weight:500}
.article table{width:100%;border-collapse:collapse;margin:28px 0;font-size:.92rem;border:1px solid var(--edge);border-radius:12px;overflow:hidden}
.article th,.article td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--edge)}
.article th{font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--cyan);background:var(--void-3)}
.article td{color:var(--dim-2)}
.article td:first-child{color:var(--ink);font-weight:600}
.article tr:last-child td{border-bottom:none}
.article pre{background:var(--void-3);border:1px solid var(--edge);border-radius:12px;padding:20px;overflow-x:auto;
  margin:0 0 22px;font-family:'Space Mono',monospace;font-size:.85rem;line-height:1.6;color:var(--dim-2)}
.article code{font-family:'Space Mono',monospace;font-size:.88em;color:var(--acid)}
.article pre code{color:inherit}
.article img{border-radius:12px;border:1px solid var(--edge);margin:8px 0 22px}
.article hr{border:none;border-top:1px solid var(--edge);margin:36px 0}
.article figure{margin:32px 0}
.article figcaption{font-family:'Space Mono',monospace;font-size:.72rem;color:var(--dim);margin-top:10px;text-align:center}

/* rich blocks */
.callout{border:1px solid var(--edge-2);border-left:3px solid var(--acid);border-radius:10px;
  padding:22px 24px;margin:28px 0;background:rgba(198,255,0,.04)}
.callout .lbl{font-family:'Space Mono',monospace;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--acid);margin-bottom:8px}
.callout p:last-child{margin-bottom:0}
.inline-cta{border:1px solid rgba(198,255,0,.3);border-radius:16px;padding:30px;margin:40px 0;
  background:radial-gradient(circle at 80% 0%,rgba(198,255,0,.08),transparent 60%),var(--glass);
  display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.inline-cta .ic-txt{flex:1;min-width:240px}
.inline-cta h4{font-size:1.25rem;color:var(--ink);font-weight:700;margin-bottom:6px}
.inline-cta p{color:var(--dim);font-size:.92rem;margin:0}

/* TOC sidebar */
.toc{position:sticky;top:100px;font-family:'Space Mono',monospace}
.toc .ttl{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-bottom:16px}
.toc a{display:block;font-size:.8rem;color:var(--dim);padding:7px 0 7px 14px;border-left:1px solid var(--edge);transition:all .2s;line-height:1.4}
.toc a:hover{color:var(--ink)}
.toc a.active{color:var(--acid);border-left-color:var(--acid)}

/* tags + author footer */
.a-tags{max-width:720px;display:flex;gap:8px;flex-wrap:wrap;margin:48px 0 0}
.author-box{max-width:720px;border:1px solid var(--edge);border-radius:16px;padding:28px;margin:32px 0 0;
  display:flex;gap:20px;background:var(--glass);align-items:center;flex-wrap:wrap}
.author-box .av{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--hot));flex-shrink:0;
  display:grid;place-items:center;font-weight:700;font-size:1.4rem;color:var(--ink)}
.author-box h4{font-size:1.1rem;color:var(--ink);margin-bottom:4px}
.author-box .role{font-family:'Space Mono',monospace;font-size:.72rem;color:var(--cyan);margin-bottom:8px}
.author-box p{font-size:.88rem;color:var(--dim);margin:0}
.author-box a{color:var(--acid)}

/* related */
.related{position:relative;z-index:2;margin:80px 0 0}
.related .rh{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:1.8rem;margin-bottom:28px}
.related .rh em{font-style:normal;color:var(--acid)}

/* prev / next */
.pn-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:40px 0 0}
@media(max-width:780px){.pn-grid{grid-template-columns:1fr}}
.pn-card{border:1px solid var(--edge);border-radius:14px;padding:22px;background:var(--glass);transition:all .25s}
.pn-card:hover{border-color:rgba(198,255,0,.3)}
.pn-card .pn-lbl{font-family:'Space Mono',monospace;font-size:.64rem;color:var(--acid);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.pn-card h4{font-size:1rem;color:var(--ink);line-height:1.3}

/* ============================================
   TOPIC HUB
   ============================================ */
.t-hero{position:relative;z-index:2;padding:130px 0 0}
.t-hero .crumb{margin-bottom:26px}
.t-hero h1{font-size:clamp(2.6rem,7vw,5rem);max-width:840px}
.t-hero h1 em{font-style:normal;background:linear-gradient(100deg,var(--cyan),var(--acid));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.t-intro{max-width:680px;color:var(--dim-2);font-size:1.15rem;line-height:1.7;margin-top:24px}
.t-stats{display:flex;gap:40px;margin-top:34px;flex-wrap:wrap;font-family:'Space Mono',monospace}
.t-stats .s b{display:block;font-family:'Anton',sans-serif;font-size:2rem;color:var(--acid);line-height:1}
.t-stats .s span{font-size:.72rem;color:var(--dim);text-transform:uppercase;letter-spacing:.08em}
.cluster{position:relative;z-index:2;margin:70px 0 0}
.cluster-head{display:flex;align-items:baseline;justify-content:space-between;border-bottom:1px solid var(--edge);padding-bottom:16px;margin-bottom:28px;flex-wrap:wrap;gap:10px}
.cluster-head h2{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:1.7rem;letter-spacing:-.01em}
.cluster-head h2 .n{color:var(--violet);margin-right:10px}
.cluster-head a{font-family:'Space Mono',monospace;font-size:.74rem;color:var(--acid)}
.clist{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:760px){.clist{grid-template-columns:1fr}}
.citem{display:flex;gap:18px;border:1px solid var(--edge);border-radius:14px;padding:20px;background:var(--glass);transition:all .25s;align-items:center}
.citem:hover{border-color:rgba(198,255,0,.3);transform:translateX(4px)}
.citem .idx{font-family:'Space Mono',monospace;font-size:.8rem;color:var(--dim);flex-shrink:0;width:28px}
.citem .ci-body{flex:1}
.citem .ci-meta{font-family:'Space Mono',monospace;font-size:.64rem;color:var(--cyan);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.citem h3{font-size:1.05rem;font-weight:700;line-height:1.25;color:var(--ink)}
.citem .arrow{color:var(--dim);transition:all .2s}
.citem:hover .arrow{color:var(--acid);transform:translateX(3px)}
.hub-cta{position:relative;z-index:2;margin:80px 0 0;border:1px solid rgba(198,255,0,.3);border-radius:20px;padding:50px;text-align:center;
  background:radial-gradient(circle at 50% 0%,rgba(198,255,0,.08),transparent 60%),var(--glass)}
.hub-cta .display{font-size:clamp(2rem,6vw,3.6rem)}
.hub-cta .display em{font-style:normal;color:var(--acid)}
.hub-cta p{color:var(--dim);max-width:460px;margin:16px auto 28px}
.subtopics{position:relative;z-index:2;margin:70px 0 0;display:flex;gap:10px;flex-wrap:wrap}

/* ============================================
   COMPARE PAGE
   ============================================ */
.c-hero{position:relative;z-index:2;text-align:center;padding:130px 0 0}
.c-hero .crumb{justify-content:center;margin-bottom:26px}
.c-hero h1{font-size:clamp(2.4rem,7vw,5rem);display:flex;align-items:center;gap:18px;justify-content:center;flex-wrap:wrap}
.c-hero h1 .vs{font-family:'Space Mono',monospace;font-size:1.4rem;color:var(--hot);-webkit-text-fill-color:var(--hot)}
.c-hero h1 .us{background:linear-gradient(100deg,var(--cyan),var(--acid));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.c-hero p{color:var(--dim);max-width:560px;margin:22px auto 0;font-size:1.08rem}
.verdict{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:54px 0 0}
@media(max-width:760px){.verdict{grid-template-columns:1fr}}
.vcard{border:1px solid var(--edge);border-radius:18px;padding:30px;background:var(--glass);position:relative;overflow:hidden}
.vcard.win{border-color:var(--acid);box-shadow:0 0 40px rgba(198,255,0,.1)}
.vcard.win::after{content:'WINNER';position:absolute;top:18px;right:22px;font-family:'Space Mono',monospace;font-size:.6rem;letter-spacing:.12em;color:var(--void);background:var(--acid);padding:3px 9px;border-radius:20px;font-weight:700}
.vcard .vname{font-family:'Anton',sans-serif;font-size:1.8rem;text-transform:uppercase;margin-bottom:6px}
.vcard .vsub{font-family:'Space Mono',monospace;font-size:.72rem;color:var(--cyan);margin-bottom:18px}
.vcard .score{font-family:'Anton',sans-serif;font-size:3rem;line-height:1;margin-bottom:14px}
.vcard.win .score{color:var(--acid)}
.vcard .best{font-size:.9rem;color:var(--dim);line-height:1.6}
.vcard .best b{color:var(--ink)}
.cmp{position:relative;z-index:2;margin:80px 0 0}
.cmp h2{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:clamp(1.8rem,5vw,2.6rem);text-align:center;margin-bottom:36px}
.cmp h2 em{font-style:normal;color:var(--acid)}
.cmptable{width:100%;border-collapse:collapse;border:1px solid var(--edge);border-radius:14px;overflow:hidden;font-size:.92rem}
.cmptable th,.cmptable td{padding:16px 18px;text-align:center;border-bottom:1px solid var(--edge)}
.cmptable th:first-child,.cmptable td:first-child{text-align:left}
.cmptable thead th{font-family:'Space Mono',monospace;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;background:var(--void-3)}
.cmptable thead th.hl{color:var(--acid)}
.cmptable td:first-child{color:var(--ink);font-weight:600}
.cmptable td{color:var(--dim-2)}
.cmptable .y{color:var(--acid)}.cmptable .n{color:var(--dim);opacity:.45}
.cmptable tr:last-child td{border-bottom:none}
.cmptable .col-hl{background:rgba(198,255,0,.04)}
.narrative{position:relative;z-index:2;max-width:760px;margin:80px auto 0;font-size:1.06rem;line-height:1.8;color:var(--dim-2)}
.narrative h2{font-family:'Bricolage Grotesque',sans-serif;font-size:1.7rem;font-weight:700;color:var(--ink);margin:44px 0 16px}
.narrative h2::before{content:'';display:inline-block;width:18px;height:18px;margin-right:12px;border-radius:4px;background:linear-gradient(135deg,var(--acid),var(--cyan));vertical-align:middle;transform:translateY(-2px)}
.narrative p{margin-bottom:20px}
.narrative strong{color:var(--ink)}
.c-cta{position:relative;z-index:2;text-align:center;margin:90px 0 0;padding:50px;border:1px solid rgba(198,255,0,.3);border-radius:20px;background:radial-gradient(circle at 50% 0%,rgba(198,255,0,.08),transparent 60%),var(--glass)}
.c-cta .display{font-size:clamp(2rem,6vw,3.4rem)}
.c-cta .display em{font-style:normal;color:var(--acid)}
.c-cta p{color:var(--dim);margin:14px auto 26px;max-width:440px}

/* ============================================
   FEATURES (static)
   ============================================ */
.f-hero{position:relative;z-index:2;text-align:center;padding:140px 0 0}
.f-hero h1{font-size:clamp(3rem,11vw,8rem)}
.f-hero h1 em{font-style:normal;background:linear-gradient(100deg,var(--hot),var(--violet) 50%,var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.f-hero p{color:var(--dim);max-width:560px;margin:22px auto 0;font-size:1.1rem}
.frow{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin:90px 0 0}
.frow.alt .ftext{order:2}
@media(max-width:840px){.frow{grid-template-columns:1fr;gap:30px}.frow.alt .ftext{order:0}}
.ftext .fnum{font-family:'Space Mono',monospace;font-size:.74rem;color:var(--hot);letter-spacing:.2em;margin-bottom:16px}
.ftext h2{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;line-height:1.1;margin-bottom:16px}
.ftext p{color:var(--dim);font-size:1rem;margin-bottom:20px}
.ftext ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ftext li{display:flex;gap:10px;color:var(--dim-2);font-size:.92rem;align-items:flex-start}
.ftext li svg{width:16px;height:16px;stroke:var(--acid);flex-shrink:0;margin-top:4px}
.fart{height:360px;border-radius:18px;border:1px solid var(--edge);overflow:hidden;position:relative;background:var(--void-3)}
.fart::before{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:34px 34px;opacity:.4}
.fart.a1{background:radial-gradient(circle at 30% 35%,rgba(123,47,255,.5),transparent 55%),radial-gradient(circle at 75% 65%,rgba(255,42,109,.4),transparent 55%),var(--void-3)}
.fart.a2{background:radial-gradient(circle at 70% 40%,rgba(5,217,232,.45),transparent 55%),var(--void-3)}
.fart.a3{background:radial-gradient(circle at 40% 50%,rgba(198,255,0,.3),transparent 55%),var(--void-3)}
.fart.a4{background:radial-gradient(circle at 60% 60%,rgba(255,42,109,.45),transparent 55%),radial-gradient(circle at 25% 30%,rgba(123,47,255,.4),transparent 55%),var(--void-3)}
.fart .eq{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:6px}
.fart .eq i{width:7px;background:linear-gradient(to top,var(--violet),var(--acid));border-radius:4px;animation:eqbar 1.3s ease-in-out infinite}
.fart .panel{position:absolute;inset:20px;border:1px solid var(--edge-2);border-radius:12px;background:rgba(5,6,10,.5);backdrop-filter:blur(6px);padding:18px;font-family:'Space Mono',monospace;font-size:.72rem;color:var(--dim)}
.fart .panel .line{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--edge)}
.fart .panel .line:last-child{border:none}
.fart .panel .bar{flex:1;height:5px;border-radius:3px;background:linear-gradient(90deg,var(--violet),var(--cyan));opacity:.8}
.specs{position:relative;z-index:2;margin:110px 0 0;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--edge);border:1px solid var(--edge);border-radius:16px;overflow:hidden}
.spec{background:var(--void);padding:34px 24px;text-align:center}
.spec .big{font-family:'Anton',sans-serif;font-size:2.6rem;background:linear-gradient(120deg,var(--cyan),var(--acid));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.spec .lbl{font-family:'Space Mono',monospace;font-size:.7rem;color:var(--dim);margin-top:10px;letter-spacing:.06em;text-transform:uppercase}
@media(max-width:760px){.specs{grid-template-columns:repeat(2,1fr)}}
.f-cta{position:relative;z-index:2;text-align:center;margin:100px 0 0;padding:50px;border:1px solid rgba(198,255,0,.3);border-radius:20px;background:radial-gradient(circle at 50% 0%,rgba(198,255,0,.08),transparent 60%),var(--glass)}
.f-cta .display{font-size:clamp(2rem,6vw,3.6rem)}
.f-cta .display em{font-style:normal;color:var(--acid)}
.f-cta p{color:var(--dim);margin:16px auto 28px;max-width:440px}

/* ============================================
   PRICING (static)
   ============================================ */
.p-hero{position:relative;z-index:2;text-align:center;padding:140px 0 0}
.p-hero h1{font-size:clamp(3rem,11vw,7rem)}
.p-hero h1 em{font-style:normal;background:linear-gradient(100deg,var(--hot),var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.p-hero p{color:var(--dim);max-width:480px;margin:20px auto 0;font-size:1.08rem}
.toggle{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:14px;margin:40px auto 0;font-family:'Space Mono',monospace;font-size:.82rem}
.toggle .sw{width:52px;height:28px;border-radius:20px;border:1px solid var(--edge-2);background:var(--void-3);position:relative;cursor:pointer;transition:all .2s}
.toggle .sw::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:var(--acid);transition:all .25s}
.toggle .sw.on::after{left:27px}
.toggle .save{color:var(--acid);font-size:.7rem;border:1px solid var(--acid);border-radius:20px;padding:3px 10px}
.toggle .muted{color:var(--dim)}
.price-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:50px 0 0}
@media(max-width:880px){.price-grid{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}}
.plan{border:1px solid var(--edge);border-radius:18px;padding:34px;background:var(--glass);backdrop-filter:blur(6px);position:relative;transition:all .3s}
.plan:hover{transform:translateY(-5px)}
.plan.feat{border-color:var(--acid);box-shadow:0 0 50px rgba(198,255,0,.12)}
.plan.feat::after{content:'MOST WANTED';position:absolute;top:-11px;left:34px;font-family:'Space Mono',monospace;font-size:.62rem;letter-spacing:.12em;background:var(--acid);color:var(--void);padding:4px 10px;border-radius:20px;font-weight:700}
.plan .pname{font-family:'Space Mono',monospace;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan)}
.plan .pprice{font-family:'Anton',sans-serif;font-size:3.4rem;margin:14px 0 4px;line-height:1}
.plan .pprice small{font-size:1rem;color:var(--dim);font-family:'Space Mono',monospace}
.plan .pdesc{color:var(--dim);font-size:.86rem;min-height:40px}
.plan ul{list-style:none;margin:24px 0 28px;display:flex;flex-direction:column;gap:12px}
.plan li{display:flex;gap:10px;font-size:.9rem;color:var(--dim-2);align-items:flex-start}
.plan li svg{width:16px;height:16px;stroke:var(--acid);flex-shrink:0;margin-top:3px}
.plan .btn{width:100%;justify-content:center}
.faq{position:relative;z-index:2;margin:90px auto 0;max-width:760px}
.faq h2{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:clamp(1.8rem,5vw,2.8rem);text-align:center;margin-bottom:36px}
.faq h2 em{font-style:normal;color:var(--acid)}
.qa{border:1px solid var(--edge);border-radius:12px;margin-bottom:12px;overflow:hidden;background:var(--glass);transition:border-color .2s}
.qa.open{border-color:rgba(198,255,0,.3)}
.qa .q{padding:20px 22px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:1.02rem;gap:16px}
.qa .q .pl{color:var(--acid);font-size:1.4rem;transition:transform .25s;flex-shrink:0;font-family:'Space Mono',monospace}
.qa.open .q .pl{transform:rotate(45deg)}
.qa .a{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--dim);font-size:.94rem;line-height:1.7}
.qa .a p{padding:0 22px 22px}
.p-cta{position:relative;z-index:2;text-align:center;margin:90px 0 0;padding:50px;border:1px solid rgba(198,255,0,.3);border-radius:20px;background:radial-gradient(circle at 50% 0%,rgba(198,255,0,.08),transparent 60%),var(--glass)}
.p-cta .display{font-size:clamp(2rem,6vw,3.4rem)}
.p-cta .display em{font-style:normal;color:var(--acid)}
.p-cta p{color:var(--dim);margin:14px auto 26px;max-width:420px}

/* ============================================
   PROSE PAGES (about / contact / disclosure)
   ============================================ */
.prose{position:relative;z-index:2;max-width:760px;margin:56px auto 0;font-size:1.06rem;line-height:1.8;color:var(--dim-2)}
.prose h2{font-family:'Bricolage Grotesque',sans-serif;font-size:1.7rem;font-weight:700;color:var(--ink);margin:44px 0 16px}
.prose h2::before{content:'';display:inline-block;width:18px;height:18px;margin-right:12px;border-radius:4px;background:linear-gradient(135deg,var(--acid),var(--cyan));vertical-align:middle;transform:translateY(-2px)}
.prose p{margin-bottom:20px}
.prose strong{color:var(--ink)}
.prose a{color:var(--acid);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--acid-dim)}
.prose ul{margin:0 0 20px 4px;padding-left:24px;display:flex;flex-direction:column;gap:10px}
.prose li::marker{color:var(--acid)}

/* hub grids (topic index / author index / 404 links) */
.hub{position:relative;z-index:2;margin:40px auto 0;max-width:1240px}
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:980px){.hub-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.hub-grid{grid-template-columns:1fr}}
.hub-card{border:1px solid var(--edge);border-radius:14px;padding:24px;background:var(--glass);transition:all .25s;display:flex;flex-direction:column}
.hub-card:hover{border-color:rgba(198,255,0,.3);transform:translateY(-4px)}
.hub-card h3{font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:6px}
.hub-card p{color:var(--dim);font-size:.86rem;line-height:1.5;margin:4px 0 12px}
.hub-card .ct{font-family:'Space Mono',monospace;font-size:.7rem;color:var(--acid);margin-top:auto}

/* 404 */
.nf{position:relative;z-index:2;text-align:center;padding:160px 20px 40px}
.nf .big{font-family:'Anton',sans-serif;font-size:clamp(6rem,22vw,16rem);line-height:.85;
  background:linear-gradient(100deg,var(--hot),var(--violet) 50%,var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nf h1{font-size:clamp(1.6rem,4vw,2.6rem);font-weight:800;margin-top:20px}
.nf h1 em{font-style:normal;color:var(--acid)}
.nf p{color:var(--dim);max-width:460px;margin:18px auto 30px}
