/* ============================================================
   anttka4 — shared design system for sub-pages
   Mirrors the homepage (ember / void) so every page matches.
   ============================================================ */
:root{
  --void:#06080D; --void-2:#090C13; --fog:#0f131c; --ash:#161b26; --ash-line:#1f2532;
  --ember:#D8362F; --ember-bright:#F2554A; --ember-deep:#8f2420;
  --bone:#E8E0D2; --mist:#828b9e; --mist-dim:#586173;
  --maxw:1140px; --pad:clamp(20px,5vw,40px);
  --f-display:"Cormorant",Georgia,serif;
  --f-body:"Manrope",system-ui,sans-serif;
  --f-mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{background:var(--void);color:var(--bone);font-family:var(--f-body);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;min-height:100vh;display:flex;flex-direction:column}

/* --- atmosphere --- */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.05;
  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' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.fog{position:fixed;inset:-20%;z-index:0;pointer-events:none;
  background:radial-gradient(40% 40% at 25% 30%,rgba(216,54,47,.05),transparent 70%),radial-gradient(45% 45% at 78% 65%,rgba(70,96,140,.06),transparent 70%);
  animation:drift 46s ease-in-out infinite alternate;}
@keyframes drift{from{transform:translate(-3%,-2%) scale(1)}to{transform:translate(4%,3%) scale(1.12)}}
#lantern{position:fixed;top:0;left:0;width:780px;height:780px;margin:-390px 0 0 -390px;border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(circle,rgba(216,54,47,.17) 0%,rgba(216,54,47,.06) 33%,transparent 64%);
  transition:transform .5s cubic-bezier(.2,.8,.2,1);will-change:transform;}
#lantern .flame{position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle,rgba(242,85,74,.10) 0%,transparent 45%);animation:flicker 3.6s steps(1,end) infinite;}
@keyframes flicker{0%,100%{opacity:1}8%{opacity:.78}11%{opacity:.95}19%{opacity:.62}22%{opacity:.9}34%{opacity:.84}41%{opacity:1}53%{opacity:.7}57%{opacity:.92}66%{opacity:.55}70%{opacity:.88}83%{opacity:.95}92%{opacity:.66}}
.vignette{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(125% 95% at 50% 42%,transparent 48%,rgba(0,0,0,.55) 100%);box-shadow:inset 0 0 220px 40px rgba(0,0,0,.6);}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);width:100%}
.content{position:relative;z-index:1;flex:1 0 auto}
.eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ember);display:inline-flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--ember);opacity:.55}
h1,h2,h3{font-family:var(--f-display);line-height:1.04;letter-spacing:-.01em}
h2 em{font-style:italic;font-weight:600;color:var(--ember-bright)}
p.lead{font-size:clamp(18px,2vw,20px);color:var(--mist);line-height:1.6;max-width:62ch;font-weight:400}

/* --- buttons --- */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--f-body);font-weight:700;font-size:16px;
  padding:15px 26px;border-radius:2px;border:1px solid transparent;cursor:pointer;line-height:1;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease,border-color .25s ease;}
.btn-primary{background:var(--ember);color:#fff;box-shadow:0 0 30px -10px rgba(216,54,47,.5)}
.btn-primary:hover{background:var(--ember-bright);transform:translateY(-2px);box-shadow:0 16px 44px -12px rgba(216,54,47,.65)}
.btn-ghost{background:transparent;color:var(--bone);border-color:var(--ash-line)}
.btn-ghost:hover{border-color:var(--ember);color:var(--ember-bright);transform:translateY(-2px)}
.btn-lg{padding:18px 34px;font-size:17px}
:focus-visible{outline:2px solid var(--ember-bright);outline-offset:3px;border-radius:2px}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}

/* --- nav --- */
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(6,8,13,.74);border-bottom:1px solid transparent;transition:border-color .3s ease,background .3s ease;}
header.nav.scrolled{border-bottom-color:var(--ash-line);background:rgba(6,8,13,.92)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{font-family:var(--f-display);font-weight:700;font-size:24px;display:flex;align-items:center;gap:.5em}
.brand .dot{width:8px;height:8px;border-radius:50%;background:var(--ember);box-shadow:0 0 14px 3px rgba(216,54,47,.75);animation:flicker 3.6s steps(1,end) infinite}
.nav-right{display:flex;align-items:center;gap:22px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a.link{font-size:15px;color:var(--mist);transition:color .2s;font-family:var(--f-body)}
.nav-links a.link:hover{color:var(--bone)}
.nav-toggle{display:none;background:none;border:0;color:var(--bone);cursor:pointer;padding:8px}

/* --- page hero (sub-page header) --- */
.page-hero{padding:clamp(76px,12vw,128px) 0 clamp(28px,5vw,46px);text-align:center;position:relative}
.page-hero .eyebrow{display:inline-flex;justify-content:center}
.page-hero h1{font-weight:700;font-size:clamp(40px,7vw,72px);margin-top:14px;text-shadow:0 0 60px rgba(216,54,47,.12)}
.page-hero h1 .glow{color:var(--ember);text-shadow:0 0 28px rgba(242,85,74,.5);animation:flicker 3.6s steps(1,end) infinite}
.page-hero p.lead{margin:18px auto 0;text-align:center}

/* --- generic block + card --- */
section.block{padding:clamp(40px,7vw,72px) 0;position:relative}
.card{border:1px solid var(--ash-line);border-radius:10px;padding:clamp(26px,4vw,44px);background:linear-gradient(180deg,rgba(16,20,28,.7),var(--fog));box-shadow:0 26px 64px -40px rgba(0,0,0,.85)}

/* --- prose (legal / about / articles) --- */
.prose{max-width:76ch;margin:0 auto}
.prose>h2{font-family:var(--f-display);font-weight:700;font-size:clamp(24px,3.4vw,34px);color:var(--bone);margin:2.1em 0 .55em;letter-spacing:-.01em}
.prose>h2:first-child{margin-top:0}
.prose h3{font-family:var(--f-display);font-weight:700;font-size:22px;color:var(--bone);margin:1.6em 0 .5em}
.prose p,.prose li{color:var(--mist);font-size:16.5px;line-height:1.78}
.prose p{margin:0 0 1.1em}
.prose strong{color:var(--bone);font-weight:600}
.prose a{color:var(--ember);border-bottom:1px solid rgba(216,54,47,.4);transition:color .2s}
.prose a:hover{color:var(--ember-bright)}
.prose ul{list-style:none;margin:0 0 1.2em;padding:0}
.prose ul li{position:relative;padding-left:1.5em;margin:.5em 0}
.prose ul li::before{content:"◆";position:absolute;left:0;top:.5em;color:var(--ember);font-size:.62em}
.prose hr{border:0;border-top:1px solid var(--ash-line);margin:2.2em 0}
.prose .meta-date{font-family:var(--f-mono);font-size:13px;letter-spacing:.04em;color:var(--mist-dim);margin-bottom:2em;display:block}
.prose .lede{font-size:clamp(18px,2vw,21px);color:var(--bone);line-height:1.65;margin-bottom:1.4em}

/* --- 404 --- */
.err{padding:clamp(80px,15vw,160px) 0;text-align:center;position:relative}
.err .code{font-family:var(--f-display);font-weight:700;font-size:clamp(120px,26vw,250px);line-height:.86;color:var(--bone);text-shadow:0 0 80px rgba(216,54,47,.3)}
.err .code .glow{color:var(--ember);animation:flicker 3.6s steps(1,end) infinite}
.err h1{font-family:var(--f-display);font-weight:700;font-size:clamp(28px,4.4vw,46px);margin:6px 0 0}
.err p{color:var(--mist);max-width:50ch;margin:18px auto 0;font-size:17px}
.err .cta-row{justify-content:center}

/* --- about portrait --- */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,60px);align-items:start;margin-top:36px}
.portrait{aspect-ratio:1;border-radius:12px;border:1px solid var(--ash-line);position:relative;overflow:hidden;
  background:radial-gradient(70% 70% at 32% 26%,rgba(216,54,47,.22),transparent 60%),linear-gradient(155deg,var(--fog),var(--void));display:flex;align-items:center;justify-content:center}
.portrait img{width:100%;height:100%;object-fit:cover}
.portrait .ini{font-family:var(--f-display);font-weight:700;font-size:clamp(80px,13vw,140px);color:rgba(232,224,210,.13);letter-spacing:-.04em}
.modal-legal{margin:1.6em 0;padding:18px 22px;border-left:2px solid var(--ember);background:linear-gradient(90deg,rgba(216,54,47,.08),transparent);border-radius:0 6px 6px 0}
.modal-legal-t{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ember);margin-bottom:8px}
.modal-legal p{font-size:14px;color:var(--bone);margin:0;line-height:1.6}
.link-row{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:24px;padding-top:20px;border-top:1px solid var(--ash-line)}
.link-row a{font-family:var(--f-mono);font-size:13px;color:var(--ember);border-bottom:1px solid rgba(216,54,47,.35);padding-bottom:2px;transition:color .2s}
.link-row a:hover{color:var(--ember-bright)}
.discord-copy{cursor:pointer;border-bottom:1px dotted currentColor}

/* --- blog feed --- */
.post-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:46px}
.post-card{display:flex;flex-direction:column;border:1px solid var(--ash-line);border-radius:10px;padding:28px 26px;background:var(--fog);transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease;position:relative;overflow:hidden}
.post-card:hover{transform:translateY(-4px);border-color:rgba(216,54,47,.45);box-shadow:0 26px 64px -34px rgba(0,0,0,.85)}
.post-card .ptag{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ember)}
.post-card h3{font-family:var(--f-display);font-weight:700;font-size:26px;color:var(--bone);margin:10px 0 8px;letter-spacing:-.01em}
.post-card p{color:var(--mist);font-size:15px;line-height:1.6;flex:1}
.post-card .pmeta{margin-top:16px;font-family:var(--f-mono);font-size:12px;color:var(--mist-dim);display:flex;justify-content:space-between;align-items:center}
.post-card .pmeta .arr{color:var(--ember);transition:transform .25s}
.post-card:hover .pmeta .arr{transform:translateX(3px)}

/* --- footer --- */
footer.foot{border-top:1px solid var(--ash-line);padding:40px 0;position:relative;z-index:1;flex-shrink:0}
.foot-in{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px;align-items:center}
.foot-brand{font-family:var(--f-display);font-weight:700;font-size:22px}
.foot-tag{font-family:var(--f-mono);font-size:12px;color:var(--mist-dim);letter-spacing:.04em;margin-top:2px}
.foot-links{display:flex;gap:24px;flex-wrap:wrap}
.foot-links a{font-size:14px;color:var(--mist);transition:color .2s;font-family:var(--f-body)}
.foot-links a:hover{color:var(--ember)}
.foot-legal{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-top:26px;padding-top:20px;border-top:1px solid var(--ash-line);flex-wrap:wrap}
.foot-legal-main{display:flex;flex-direction:column;gap:6px;max-width:620px}
.foot-legal span{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.02em;color:var(--mist-dim);line-height:1.5}
.foot-cookie{opacity:.8}
.foot-legal-links a{font-family:var(--f-mono);font-size:11.5px;color:var(--mist-dim);border-bottom:1px solid var(--ash-line);padding-bottom:2px;transition:color .2s;white-space:nowrap}
.foot-legal-links a:hover{color:var(--ember)}

/* --- reveal --- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* --- responsive --- */
@media (max-width:820px){
  .about-grid{grid-template-columns:1fr}
  .portrait{max-width:320px}
  .post-grid{grid-template-columns:1fr}
}
@media (max-width:620px){
  body{font-size:16px}
  .nav-links{position:absolute;top:70px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:6px;
    background:var(--void-2);border-bottom:1px solid var(--ash-line);padding:16px var(--pad) 22px;transform:translateY(-12px);opacity:0;pointer-events:none;transition:.25s}
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a.link{font-size:17px;padding:6px 0}
  .nav-links .btn{margin-top:8px}
  .nav-toggle{display:block}
  .cta-row .btn{flex:1;justify-content:center}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  #lantern,.fog{display:none}
  .brand .dot,.glow{animation:none}
  *{transition:none!important}
}

/* --- blog timeline --- */
.tl{margin-top:46px;border-left:1px solid var(--ash-line);padding-left:clamp(20px,4vw,40px);max-width:780px}
.tl-item{position:relative;padding-bottom:42px}
.tl-item::before{content:"";position:absolute;left:calc(-1*clamp(20px,4vw,40px) - 5px);top:6px;width:9px;height:9px;border-radius:50%;background:var(--ember);box-shadow:0 0 12px 2px rgba(216,54,47,.6)}
.tl-date{font-family:var(--f-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ember)}
.tl-body{margin-top:8px}
.tl-body h3{font-family:var(--f-display);font-weight:700;font-size:clamp(22px,3vw,28px);color:var(--bone);margin-bottom:8px;letter-spacing:-.01em}
.tl-body p{color:var(--mist);font-size:16px;line-height:1.7;margin-bottom:14px}
.tl-media{display:block;border:1px solid var(--ash-line);border-radius:8px;overflow:hidden;margin:0 0 14px;max-width:440px;background:var(--fog)}
.tl-media img{width:100%;height:auto;display:block;transition:transform .4s ease}
.tl-media:hover img{transform:scale(1.03)}
.tl-links{display:flex;flex-wrap:wrap;gap:8px 16px;font-family:var(--f-mono);font-size:13px}
.tl-links a{color:var(--ember);border-bottom:1px solid rgba(216,54,47,.4);padding-bottom:2px;transition:color .2s}
.tl-links a:hover{color:var(--ember-bright)}
