/* ============================================================
   THE OLD ELEMENTS — zine site system (riso / screenprint)
   Type:  Anton (display) · Spectral (body) · Space Mono (furniture)
   Lifted from the books: dark "Deep" grounds, one warm torch accent,
   hand-drawn divider rules, offset hard shadows, corner-clipped panels,
   torch numerals, vector keyed maps.
   ============================================================ */
:root{
  --f-display:'Anton','Arial Narrow',sans-serif;
  --f-body:'Spectral',Georgia,serif;
  --f-mono:'Space Mono','Courier New',monospace;

  /* default (un-themed chrome) = water/drowned */
  --abyss:#0b0f12;
  --abyss2:#141b20;
  --foam:#cbd3ce;
  --foam-dim:#7f8c8a;
  --bone:#e3e7df;
  --bone2:#d6dccf;
  --ink:#0c1316;
  --ink-soft:#54625f;
  --torch:#df7a30;
  --torch2:#f2a455;
  --rule:#33414a;
  --divider:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='8' viewBox='0 0 24 8'%3E%3Cpath d='M0 5 q6 -3 12 0 t12 0' fill='none' stroke='%23000' stroke-width='1.6'/%3E%3C/svg%3E");

  --gut:clamp(20px,5vw,72px);
  --pad:clamp(66px,9vw,148px);
  --maxw:1280px;
  --lh:1.62;
}
[data-density="compact"]{--pad:clamp(48px,6vw,96px);--lh:1.5}
[data-density="comfy"]{--pad:clamp(88px,12vw,200px);--lh:1.7}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--abyss);color:var(--foam);
  font-family:var(--f-body);font-size:18px;line-height:var(--lh);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{display:block}
.mono{font-family:var(--f-mono);text-transform:uppercase}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}

/* paper grain + film decay over everything */
body::after{content:"";position:fixed;inset:0;z-index:3;pointer-events:none;opacity:.09;mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px}
[data-ground="bone"] body::after{mix-blend-mode:multiply;opacity:.06}
[data-grain="off"] body::after{display:none}

/* ---------- ink decay layers (background-image, never masks) ---------- */
.grit{position:absolute;inset:0;z-index:0;pointer-events:none;background-repeat:no-repeat;opacity:.12;
  background-image:url("../art/ink-splatter-l.png")}
[data-ground="bone"] .grit{background-image:url("../art/ink-splatter.png");opacity:.1;mix-blend-mode:multiply}
[data-grain="off"] .grit{display:none}

/* ---------- furniture ---------- */
.kick{font-family:var(--f-mono);font-weight:700;font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--torch)}
.lab{font-family:var(--f-mono);font-weight:700;font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--foam-dim)}

/* hand-drawn divider rule */
.wrule{display:block;width:100%;height:8px;background:var(--torch);
  -webkit-mask:var(--divider) left center/auto 100% repeat-x;
  mask:var(--divider) left center/auto 100% repeat-x}
.wrule.dim{background:var(--rule)}

/* zine buttons — corner-clipped, offset hard shadow */
.zbtn{display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:2px solid var(--torch);
  background:none;color:var(--foam);font-family:var(--f-mono);font-weight:700;font-size:12px;
  letter-spacing:.16em;text-transform:uppercase;padding:15px 24px;position:relative;
  clip-path:polygon(0 0,calc(100% - 11px) 0,100% 11px,100% 100%,11px 100%,0 calc(100% - 11px));
  transition:transform .16s ease,background .16s ease,color .16s ease}
.zbtn:hover{transform:translate(-2px,-2px)}
.zbtn.fill{background:var(--torch);color:#0c0f0c}
.zbtn.fill:hover{background:var(--torch2)}
.zbtn.sm{padding:11px 16px;font-size:11px}

/* ---------- top bar ---------- */
.topbar{position:relative;z-index:6;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:14px var(--gut);border-bottom:1px solid var(--rule);font-family:var(--f-mono);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.topbar .brand{font-weight:700;color:var(--foam);letter-spacing:.22em}
.topbar nav{display:flex;gap:clamp(14px,2.4vw,34px)}
.topbar nav a{color:var(--foam-dim);transition:color .15s ease}
.topbar nav a:hover{color:var(--torch)}
@media(max-width:760px){.topbar nav{display:none}}

/* ===================== HERO ===================== */
.hero{position:relative;overflow:hidden;padding:clamp(40px,6vw,84px) 0 0}
.hero::after{content:"";position:absolute;left:-4%;bottom:-6%;width:46%;height:70%;z-index:0;pointer-events:none;opacity:.14;
  background:url("../art/ink-splatter-l.png") left bottom/contain no-repeat}
[data-grain="off"] .hero::after{display:none}
.hero .wash{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 18% -10%,rgba(223,122,48,.14),transparent 52%),
    radial-gradient(100% 90% at 92% 8%,rgba(39,73,85,.55),transparent 55%),
    radial-gradient(140% 120% at 60% 120%,rgba(8,12,14,.7),transparent 60%)}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;
  gap:clamp(24px,5vw,72px);align-items:center;padding-top:clamp(20px,4vw,52px);padding-bottom:clamp(40px,6vw,80px)}
.hero .meta{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:11px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--foam-dim);margin-bottom:30px}
.hero h1{font-family:var(--f-display);font-weight:400;text-transform:uppercase;
  line-height:.84;letter-spacing:.5px;color:var(--foam);margin:8px 0 0}
.hero h1 .l1{display:block;font-size:clamp(46px,9vw,118px)}
.hero h1 .l2{display:block;font-size:clamp(46px,9vw,118px);color:var(--torch);
  margin-left:.02em;text-shadow:5px 5px 0 rgba(0,0,0,.35)}
.hero .sub{font-family:var(--f-body);font-style:italic;font-size:clamp(18px,2vw,24px);
  line-height:1.5;color:var(--foam);max-width:30ch;margin:26px 0 0}
.hero .stat{display:flex;gap:clamp(20px,3vw,38px);margin:28px 0 30px;flex-wrap:wrap}
.hero .stat div{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--foam-dim);min-width:max-content}
.hero .stat b{display:block;font-family:var(--f-display);font-weight:400;font-size:30px;color:var(--foam);letter-spacing:.5px;line-height:1}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
.hero .heroDivider{margin-top:34px;max-width:420px}

/* hero stack: featured cover + tucked map */
.hero .show{position:relative;justify-self:center;width:min(100%,420px);aspect-ratio:1/1.12}
.hero .show .cover{position:absolute;right:0;top:0;width:74%;rotate:2.5deg;
  box-shadow:14px 14px 0 var(--torch),0 30px 60px -20px #000;border:1px solid rgba(0,0,0,.5)}
.hero .show .cover img{width:100%;height:auto}
.hero .show .cover .folio{position:absolute;left:0;top:0;font-family:var(--f-mono);font-weight:700;
  font-size:11px;letter-spacing:.12em;color:#f3ead8;background:rgba(12,15,12,.78);padding:6px 10px}
.hero .show .map{position:absolute;left:0;bottom:0;width:50%;rotate:-5deg;border:2px solid var(--foam);
  box-shadow:0 22px 40px -16px #000;background:var(--abyss)}
.hero .show .map svg{width:100%;height:auto}
.hero .show .maptag{position:absolute;left:2%;bottom:-6px;font-family:var(--f-mono);font-weight:700;
  font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--abyss);background:var(--torch);padding:4px 8px;rotate:-5deg}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr}.hero .show{order:-1;width:min(86%,360px)}}

/* ===================== ELEMENT INDEX ===================== */
.index{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--abyss2);position:relative;z-index:1}
.index .row{display:grid;grid-template-columns:repeat(8,1fr);max-width:var(--maxw);margin:0 auto}
.idx{--torch:var(--t);position:relative;display:flex;flex-direction:column;align-items:center;gap:9px;
  padding:20px 6px 16px;border-right:1px solid var(--rule);cursor:pointer;transition:background .18s ease}
.idx:last-child{border-right:none}
.idx:hover{background:color-mix(in srgb,var(--t) 12%,transparent)}
.idx .gl{width:40px;height:40px}.idx .gl svg{width:100%;height:100%}
.idx .en{font-family:var(--f-mono);font-weight:700;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--foam)}
.idx .nn{font-family:var(--f-mono);font-size:9px;letter-spacing:.12em;color:var(--foam-dim)}
.idx::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--t);transform:scaleX(0);transition:transform .2s ease}
.idx:hover::after{transform:scaleX(1)}
@media(max-width:720px){.index .row{grid-template-columns:repeat(4,1fr)}
  .idx:nth-child(4){border-right:none}.idx:nth-child(-n+4){border-bottom:1px solid var(--rule)}}

/* ===================== SECTION HEAD ===================== */
.shead{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding:var(--pad) 0 26px}
.shead .l .kick{margin-bottom:14px}
.shead h2{font-family:var(--f-display);font-weight:400;text-transform:uppercase;letter-spacing:.5px;
  font-size:clamp(30px,4.4vw,52px);line-height:.92}
.shead .r{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--foam-dim);text-align:right;padding-bottom:6px}

/* ===================== MANIFESTO (bone page) ===================== */
.manifesto{background:var(--bone);color:var(--ink);position:relative;overflow:hidden}
.manifesto .grain{position:absolute;inset:0;background-image:url("../art/grain.png");background-size:300px;opacity:.5;mix-blend-mode:multiply;pointer-events:none}
.manifesto::before{content:"";position:absolute;top:-1px;left:0;right:0;height:158px;z-index:1;pointer-events:none;
  background:url("../art/ink-drip.png") top left/100% auto no-repeat;opacity:.92}
.manifesto::after{content:"";position:absolute;right:-3%;bottom:-8%;width:34%;height:60%;z-index:0;pointer-events:none;opacity:.09;
  mix-blend-mode:multiply;background:url("../art/ink-splatter.png") right bottom/contain no-repeat}
[data-grain="off"] .manifesto::before,[data-grain="off"] .manifesto::after{display:none}
.manifesto .wrap{position:relative;z-index:2;padding:clamp(140px,13vw,194px) var(--gut) clamp(50px,6vw,84px)}
.manifesto .top{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:clamp(28px,3.5vw,40px)}
.manifesto .kick{color:var(--torch)}
.manifesto h2{font-family:var(--f-display);font-weight:400;text-transform:uppercase;color:var(--ink);
  font-size:clamp(28px,4vw,46px);line-height:.92;letter-spacing:.5px;margin-top:12px;max-width:16ch}
.manifesto .intro{font-family:var(--f-body);font-size:clamp(17px,1.5vw,20px);line-height:1.6;color:var(--ink-soft);max-width:34ch}
.principles{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px)}
.panel{position:relative;background:var(--bone);border:2px solid var(--ink);padding:26px 24px 28px;
  box-shadow:7px 7px 0 var(--ink);
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,14px 100%,0 calc(100% - 14px))}
.panel .pn{font-family:var(--f-mono);font-weight:700;font-size:13px;color:var(--torch);
  border-bottom:2px solid var(--torch);display:inline-block;padding-bottom:3px;margin-bottom:16px;letter-spacing:.08em}
.panel h3{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:24px;line-height:1.14;letter-spacing:.4px;margin-bottom:18px}
.panel p{font-size:15.5px;line-height:1.55;color:var(--ink-soft)}
@media(max-width:820px){.principles{grid-template-columns:1fr;gap:26px}.panel{box-shadow:6px 6px 0 var(--ink)}}

/* ===================== SHELF ===================== */
.shelf{position:relative}
.shelf .wrap{position:relative;z-index:1;padding-bottom:var(--pad)}
.rack{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(22px,2.6vw,40px) clamp(16px,2vw,30px)}
@media(max-width:980px){.rack{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.rack{grid-template-columns:repeat(2,1fr);gap:24px 16px}}
.book{--torch:var(--t);cursor:pointer;position:relative}
.book .plate{position:relative;aspect-ratio:2/3;overflow:hidden;background:var(--abyss);
  border:1px solid rgba(255,255,255,.06);transition:transform .25s ease,box-shadow .25s ease}
.book .plate img{width:100%;height:100%;object-fit:cover;transform:scale(1.06)}
.book .plate .folio{position:absolute;left:0;top:0;font-family:var(--f-mono);font-weight:700;font-size:10.5px;
  letter-spacing:.1em;color:#f2ead9;background:rgba(10,12,11,.8);padding:5px 9px}
.book .plate .open{position:absolute;inset:0;display:flex;align-items:flex-end;padding:14px;opacity:0;
  background:linear-gradient(to top,rgba(8,10,9,.86),transparent 46%);transition:opacity .25s ease}
.book .plate .open span{font-family:var(--f-mono);font-weight:700;font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:#0c0f0c;background:var(--t);padding:7px 12px}
.book:hover .plate{transform:translateY(-7px);box-shadow:0 0 0 1px var(--t),0 22px 44px -18px #000,0 0 46px -10px var(--t)}
.book:hover .plate .open{opacity:1}
.book .cap{margin-top:13px}
.book .cap .wrule{height:6px;margin-bottom:11px;opacity:.0;transition:opacity .25s ease}
.book:hover .cap .wrule{opacity:1}
.book .cap .t{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:21px;line-height:1.12;letter-spacing:.4px;color:var(--foam)}
.book .cap .m{display:flex;justify-content:space-between;gap:8px;margin-top:11px;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}
.book .cap .m .no{color:var(--t)}
.book .cap .m .el{color:var(--foam-dim)}

/* ===================== MAP SHOWCASE ===================== */
.mapshow{--torch:var(--t);position:relative;background:var(--abyss2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);overflow:hidden}
.mapshow .wash{position:absolute;inset:0;pointer-events:none;background:radial-gradient(90% 80% at 80% 50%,color-mix(in srgb,var(--t) 16%,transparent),transparent 60%)}
.mapshow .wrap{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center;padding:var(--pad) var(--gut)}
.mapshow .copy .kick{color:var(--torch);margin-bottom:16px}
.mapshow .copy h2{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(28px,4vw,46px);line-height:1.12;letter-spacing:.5px;margin-bottom:24px}
.mapshow .copy p{font-size:17px;line-height:1.6;color:var(--foam);max-width:40ch;margin-bottom:14px}
.mapshow .copy p.dim{color:var(--foam-dim);font-size:15px}
.mapshow .copy .wrule{max-width:340px;margin:22px 0}
.mapshow .copy .legend{list-style:none;columns:2;column-gap:26px;margin-top:8px}
.mapshow .copy .legend li{display:grid;grid-template-columns:22px 1fr;gap:9px;margin-bottom:9px;break-inside:avoid;font-size:13px;line-height:1.3}
.mapshow .copy .legend .n{font-family:var(--f-mono);font-weight:700;font-size:11px;color:#0c0f0c;background:var(--torch);
  border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.mapshow .copy .legend b{font-family:var(--f-mono);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--foam);display:block}
.mapshow .copy .legend span{color:var(--foam-dim);font-size:12.5px}
.mapshow .frame{position:relative;aspect-ratio:1/1;border:2px solid var(--foam);box-shadow:12px 12px 0 var(--torch),0 30px 60px -24px #000;background:var(--abyss);overflow:hidden;padding:clamp(40px,5vw,52px) clamp(16px,2.2vw,28px) clamp(16px,2.2vw,28px)}
.mapshow .frame img{width:100%;height:100%;object-fit:contain;display:block}
.mapshow .frame svg{width:100%;height:100%}
.mapshow .frame .tag{position:absolute;left:0;top:0;z-index:2;font-family:var(--f-mono);font-weight:700;font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;color:#0c0f0c;background:var(--torch);padding:6px 11px}
.mapcol{position:relative}
/* editorial plate caption — not a console */
.mapctl{display:flex;align-items:baseline;justify-content:space-between;gap:18px;margin-top:16px;
  border-top:1px solid var(--rule);padding-top:15px}
.mapctl .step{background:none;border:0;cursor:pointer;font-family:var(--f-mono);font-weight:700;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--torch);padding:2px 0;display:inline-flex;gap:8px;align-items:center;
  border-bottom:2px solid transparent;transition:border-color .15s ease,color .15s ease}
.mapctl .step:hover{color:var(--torch2);border-bottom-color:var(--torch2)}
.mapctl .step .ar{font-size:16px;line-height:1}
.mapctl .cap{text-align:center;font-family:var(--f-mono);line-height:1.35}
.mapctl .cap .el{display:block;font-weight:700;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--foam)}
.mapctl .cap .sub{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--foam-dim)}
@media(max-width:860px){.mapshow .wrap{grid-template-columns:1fr;gap:30px}}

/* ===================== RELICS THREAD ===================== */
.thread .wrap{padding-bottom:var(--pad)}
.thread .lede{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(24px,4vw,60px);align-items:start;margin-bottom:46px}
.thread .lede h2{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(28px,4vw,48px);line-height:.92;letter-spacing:.5px}
.thread .lede p{font-size:17px;line-height:1.62;color:var(--foam)}
.thread .lede p .hot{color:var(--torch);font-style:italic}
.relics{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,20px)}
.relic{--torch:var(--t);position:relative;background:var(--abyss2);border:1.5px solid var(--rule);
  padding:18px 17px 20px;display:flex;flex-direction:column;gap:10px;min-height:178px;transition:border-color .2s ease,transform .2s ease}
.relic:hover{border-color:var(--t);transform:translateY(-4px)}
.relic .top{display:flex;align-items:center;gap:10px}
.relic .gl{width:30px;height:30px;flex:none}.relic .gl svg{width:100%;height:100%}
.relic .rn{font-family:var(--f-mono);font-weight:700;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--t)}
.relic .rt{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:18px;line-height:1.06;letter-spacing:.3px;color:var(--foam)}
.relic .rd{font-size:13px;line-height:1.5;color:var(--foam-dim)}
.relic.cap{background:color-mix(in srgb,var(--t) 14%,var(--abyss2));border-color:var(--t)}
@media(max-width:880px){.relics{grid-template-columns:repeat(2,1fr)}}

/* ===================== BUNDLE / WHOLE SHELF ===================== */
.bundle{position:relative;border-top:1px solid var(--rule);background:var(--abyss2);overflow:hidden}
.bundle .wrap{position:relative;z-index:1;padding:var(--pad) var(--gut)}
.bundlecard{position:relative;border:2px solid var(--torch);background:var(--abyss);
  padding:clamp(28px,4vw,52px);display:grid;grid-template-columns:auto 1fr;gap:clamp(28px,5vw,60px);align-items:center;
  box-shadow:12px 12px 0 var(--torch);
  clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px))}
.bspines{display:flex;padding-left:20px}
.spine{position:relative;width:74px;height:111px;margin-left:-20px;transition:transform .22s ease}
.spine img{width:100%;height:100%;object-fit:cover;border:1px solid #000;
  box-shadow:0 10px 22px -10px #000;background:var(--abyss2);display:block;transition:box-shadow .22s ease}
/* glyph + label bloom ABOVE the lifted cover */
.spine .bloom{position:absolute;left:50%;bottom:calc(100% + 8px);z-index:6;pointer-events:none;
  display:flex;flex-direction:column;align-items:center;gap:5px;
  opacity:0;transform:translate(-50%,10px) scale(.7);
  transition:opacity .2s ease,transform .28s cubic-bezier(.2,.8,.2,1)}
.spine .bloom .gl{position:relative;width:44px;height:44px;display:flex;align-items:center;justify-content:center}
.spine .bloom .gl::before{content:"";position:absolute;inset:-12px;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--t) 55%,transparent),transparent 70%)}
.spine .bloom .gl svg{position:relative;width:44px;height:44px;filter:drop-shadow(0 0 7px var(--t)) drop-shadow(0 0 2px var(--t2))}
.spine .bloom .el{font-family:var(--f-mono);font-weight:700;font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--t2);text-shadow:0 1px 4px #000,0 0 8px var(--t);white-space:nowrap}
.spine:hover{transform:translateY(-14px);z-index:5}
.spine:hover img{box-shadow:0 18px 30px -10px #000,0 0 0 1.5px var(--t),0 0 28px -4px var(--t)}
.spine:hover .bloom{opacity:1;transform:translate(-50%,0) scale(1)}
.bcopy .kick{margin-bottom:14px}
.bcopy h2{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(28px,3.6vw,44px);line-height:1.14;letter-spacing:.5px;margin-bottom:16px}
.bcopy p{font-size:16px;line-height:1.55;color:var(--foam);max-width:42ch;margin-bottom:24px}
.tipjar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.tipjar .tl{font-family:var(--f-mono);font-weight:700;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--foam-dim)}
.chips{display:flex;border:2px solid var(--torch)}
.chip{font-family:var(--f-mono);font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  background:none;color:var(--foam);border:0;border-right:2px solid var(--torch);padding:10px 16px;cursor:pointer;transition:background .15s ease,color .15s ease}
.chip:last-child{border-right:0}
.chip:hover{background:color-mix(in srgb,var(--torch) 22%,transparent)}
.chip.on{background:var(--torch);color:#0c0f0c}
.bactions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
@media(max-width:820px){.bundlecard{grid-template-columns:1fr;gap:30px}.bspines{flex-wrap:wrap;row-gap:14px;justify-content:center;padding-left:20px}}

/* ===================== SUBSCRIBE / SUPPORT ===================== */
.bands{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--rule)}
.band{padding:var(--pad) clamp(28px,5vw,64px)}
.band+.band{border-left:1px solid var(--rule)}
.band .kick{margin-bottom:16px}
.band h3{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(26px,3vw,40px);line-height:.95;letter-spacing:.5px;margin-bottom:14px}
.band p{font-size:16px;line-height:1.55;color:var(--foam-dim);max-width:34ch;margin-bottom:26px}
.signup{display:flex;border:2px solid var(--torch);max-width:440px}
.signup input{flex:1;border:0;background:none;padding:14px 16px;font-family:var(--f-mono);font-size:13px;color:var(--foam);outline:none}
.signup input::placeholder{color:var(--foam-dim)}
.signup button{border:0;background:var(--torch);color:#0c0f0c;font-family:var(--f-mono);font-weight:700;font-size:12px;
  letter-spacing:.14em;text-transform:uppercase;padding:0 22px;cursor:pointer}
.signup button:hover{background:var(--torch2)}
.signup.done{border-color:var(--torch);padding:14px 16px;font-family:var(--f-mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--torch)}
.note{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--foam-dim);margin-top:13px}
.pwyw{display:flex;gap:12px;flex-wrap:wrap}
@media(max-width:820px){.bands{grid-template-columns:1fr}.band+.band{border-left:none;border-top:1px solid var(--rule)}}

/* ===================== FOOTER ===================== */
footer{position:relative;border-top:1px solid var(--rule);padding:50px 0 60px;background:var(--abyss2);overflow:hidden}
footer .colophon{display:flex;flex-direction:column;align-items:center;gap:18px;margin-bottom:36px}
footer .stamp{display:flex;gap:20px;align-items:center;justify-content:center;flex-wrap:wrap}
footer .stamp .g{width:26px;height:26px;filter:grayscale(1) brightness(1.7) opacity(.45);transition:filter .2s ease}
footer .stamp .g:hover{filter:none}
footer .stamp .g svg{width:100%;height:100%}
footer .ruleone{width:min(420px,80%);height:8px;background:var(--foam-dim);opacity:.5;
  -webkit-mask:var(--divider) left center/auto 100% repeat-x;mask:var(--divider) left center/auto 100% repeat-x}
footer .foot{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--foam-dim)}
footer .foot b{font-family:var(--f-display);font-weight:400;font-size:16px;letter-spacing:.6px;color:var(--foam)}

/* ===================== MODAL (a page from the book) ===================== */
.modal{position:fixed;inset:0;z-index:50;display:none;align-items:center;justify-content:center;padding:clamp(12px,3vw,36px)}
.modal.open{display:flex}
.modal .scrim{position:absolute;inset:0;background:rgba(5,7,8,.74);backdrop-filter:blur(3px);animation:fade .25s ease}
.sheet{--torch:var(--t);position:relative;width:100%;max-width:960px;max-height:90vh;overflow:hidden;
  background:var(--abyss);color:var(--foam);border:2px solid var(--torch);
  display:grid;grid-template-columns:340px 1fr;
  box-shadow:16px 16px 0 var(--torch),0 50px 100px -30px #000;animation:rise .3s cubic-bezier(.2,.7,.2,1)}
.sheet .wash{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(90% 70% at 30% 0%,color-mix(in srgb,var(--ground) 70%,transparent),transparent 60%),
    radial-gradient(80% 90% at 90% 100%,color-mix(in srgb,var(--t) 12%,transparent),transparent 55%)}
.sheet .left{position:relative;z-index:1;background:var(--abyss2);border-right:2px solid var(--torch)}
.sheet .left img{width:100%;height:100%;object-fit:cover}
.sheet .left .folio{position:absolute;left:0;top:0;font-family:var(--f-mono);font-weight:700;font-size:11px;
  letter-spacing:.12em;color:#f2ead9;background:rgba(10,12,11,.82);padding:6px 11px}
.sheet .right{position:relative;z-index:1;padding:clamp(24px,3vw,38px) clamp(24px,3vw,40px);overflow-y:auto}
.sheet .x{position:absolute;top:12px;right:12px;z-index:6;width:38px;height:38px;border:2px solid var(--torch);
  background:var(--abyss);color:var(--foam);font-family:var(--f-mono);font-size:15px;cursor:pointer}
.sheet .x:hover{background:var(--torch);color:#0c0f0c}
.sheet .mk{font-family:var(--f-mono);font-weight:700;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--torch)}
.sheet h2{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(34px,4.4vw,52px);line-height:1.04;letter-spacing:.5px;margin:9px 0 0}
.sheet .fing{font-family:var(--f-body);font-style:italic;font-size:17px;line-height:1.5;color:var(--foam);margin:15px 0 4px}
.sheet .measure{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--foam-dim);margin-top:8px}
.sheet .wrule{margin:20px 0}
.sheet .seclab{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--f-mono);font-weight:700;
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--foam-dim);margin-bottom:14px}
.keyed{list-style:none;display:flex;flex-direction:column;gap:0}
.keyed li{display:grid;grid-template-columns:64px 1fr;gap:14px;padding:13px 0;border-bottom:1px dashed var(--rule);align-items:center}
.keyed li:last-child{border-bottom:none}
.keyed .map{position:relative;border:1.5px solid var(--torch);background:var(--abyss2);aspect-ratio:1/1;overflow:hidden}
.keyed .map svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.keyed .et{display:flex;align-items:baseline;gap:9px}
.keyed .et .n{font-family:var(--f-mono);font-weight:700;font-size:11px;color:var(--torch);border-bottom:2px solid var(--torch);line-height:1}
.keyed .et .nm{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:19px;letter-spacing:.3px;line-height:1}
.keyed .ed{font-size:13.5px;line-height:1.45;color:var(--foam-dim);margin-top:5px}
.keyed .tag{justify-self:start;margin-top:6px;font-family:var(--f-mono);font-weight:700;font-size:8.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--torch);border:1px solid var(--torch);padding:3px 7px}
/* relic statblock */
.relicstat{position:relative;font-family:var(--f-mono);border:1.5px solid var(--torch);background:var(--abyss2);
  padding:15px 16px 16px;margin-top:22px;box-shadow:6px 6px 0 var(--torch)}
.relicstat .rl{font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--foam-dim)}
.relicstat .rn{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:22px;letter-spacing:.4px;line-height:1;margin:6px 0 9px;color:var(--foam)}
.relicstat .rd{font-family:var(--f-body);font-size:14.5px;line-height:1.5;color:var(--foam)}
.dlnote{font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--foam-dim)}
.sheet .actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:24px}
@media(max-width:720px){.sheet{grid-template-columns:1fr;max-height:92vh;box-shadow:8px 8px 0 var(--torch),0 40px 80px -30px #000}
  .sheet .left{height:200px;border-right:none;border-bottom:2px solid var(--torch)}
  .keyed li{grid-template-columns:52px 1fr;gap:11px}}

@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* toast */
#toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:99;opacity:0;pointer-events:none;
  background:var(--torch);color:#0c0f0c;font-family:var(--f-mono);font-weight:700;font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;padding:13px 22px;transition:opacity .25s ease;
  box-shadow:5px 5px 0 rgba(0,0,0,.4)}

/* reveal — visible by default; gentle transform-only entrance (never gates content) */
.reveal{opacity:1}
@media(prefers-reduced-motion:no-preference){
  .reveal{transform:translateY(18px);transition:transform .6s ease;will-change:transform}
  .reveal.in{transform:none}
}

/* ===================== SAMPLE READER (a page from the book) ===================== */
.reader,.picker{position:fixed;inset:0;z-index:60;display:none;align-items:center;justify-content:center;padding:clamp(10px,2.5vw,32px)}
.reader.open,.picker.open{display:flex}
.reader .scrim,.picker .scrim{position:absolute;inset:0;background:rgba(5,7,8,.8);backdrop-filter:blur(3px);animation:fade .25s ease}

/* ---- picker (choose a book to sample) ---- */
.pbox{position:relative;width:100%;max-width:760px;max-height:90vh;overflow-y:auto;background:var(--abyss);
  border:2px solid var(--foam);box-shadow:14px 14px 0 rgba(0,0,0,.5),0 50px 90px -30px #000;
  padding:clamp(24px,3.5vw,40px);animation:rise .3s cubic-bezier(.2,.7,.2,1)}
.pbox .phead{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px}
.pbox .phead .kick{margin-bottom:9px}
.pbox .phead h2{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(24px,3vw,34px);line-height:1.04;letter-spacing:.5px;color:var(--foam)}
.pbox .phead p{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--foam-dim);margin-top:8px}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pcard{--torch:var(--t);cursor:pointer;position:relative;text-align:left}
.pcard .pl{position:relative;aspect-ratio:2/3;overflow:hidden;border:1px solid rgba(255,255,255,.08);transition:transform .2s ease,box-shadow .2s ease}
.pcard .pl img{width:100%;height:100%;object-fit:cover}
.pcard .pl .glow{position:absolute;inset:0;display:flex;align-items:flex-end;padding:9px;opacity:0;
  background:linear-gradient(to top,rgba(8,10,9,.9),transparent 50%);transition:opacity .2s ease}
.pcard .pl .glow span{font-family:var(--f-mono);font-weight:700;font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:#0c0f0c;background:var(--t);padding:5px 8px}
.pcard:hover .pl{transform:translateY(-5px);box-shadow:0 0 0 1px var(--t),0 16px 30px -14px #000,0 0 26px -8px var(--t)}
.pcard:hover .pl .glow{opacity:1}
.pcard .pt{margin-top:9px;font-family:var(--f-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--foam-dim)}
.pcard .pt b{display:block;font-family:var(--f-display);font-weight:400;font-size:13px;letter-spacing:.3px;color:var(--foam);text-transform:uppercase;line-height:1.05;margin-bottom:3px}
@media(max-width:620px){.pgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:430px){.pgrid{grid-template-columns:repeat(2,1fr)}}

/* ---- reader sheet: bone paper, themed ---- */
.rsheet{--paper:#e7e0d1;--paper2:#dcd3c1;--rink:#1b1813;--rink2:#5a5042;--tdeep:color-mix(in srgb,var(--t) 60%,#161009);
  position:relative;width:100%;max-width:1020px;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;
  background:var(--paper);color:var(--rink);border:2px solid var(--tdeep);
  box-shadow:16px 16px 0 var(--tdeep),0 50px 100px -30px #000;animation:rise .3s cubic-bezier(.2,.7,.2,1)}
.rsheet .rgrain{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;mix-blend-mode:multiply;
  background-image:url("../art/grain.png");background-size:300px}
.rsheet .rsplat{position:absolute;right:-4%;top:38%;width:34%;height:46%;z-index:0;pointer-events:none;opacity:.07;mix-blend-mode:multiply;
  background:url("../art/ink-splatter.png") right center/contain no-repeat}
[data-grain="off"] .rsheet .rgrain,[data-grain="off"] .rsheet .rsplat{display:none}
.rsheet .x{position:absolute;top:12px;right:12px;z-index:8;width:38px;height:38px;border:2px solid var(--tdeep);
  background:var(--paper);color:var(--rink);font-family:var(--f-mono);font-size:15px;cursor:pointer}
.rsheet .x:hover{background:var(--tdeep);color:var(--paper)}

.rscroll{position:relative;z-index:1;overflow-y:auto;padding:clamp(26px,4vw,48px) clamp(22px,4vw,52px) clamp(18px,2vw,26px)}

/* header */
.rhead{border-bottom:2px solid var(--rink);padding-bottom:20px;margin-bottom:24px}
.rhead .rkick{font-family:var(--f-mono);font-weight:700;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--tdeep);margin-bottom:14px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.rhead .rkick .dot{width:5px;height:5px;background:var(--t);border-radius:50%}
.rhead h2{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(34px,5.2vw,62px);line-height:.92;letter-spacing:.5px;margin:0;color:var(--rink)}
.rhead .deck{font-family:var(--f-body);font-style:italic;font-size:clamp(16px,1.7vw,19px);line-height:1.45;color:var(--rink2);margin-top:12px;max-width:46ch}

/* body grid */
.rbody{display:grid;grid-template-columns:1.45fr 1fr;gap:clamp(24px,3.5vw,44px);align-items:start}
@media(max-width:780px){.rbody{grid-template-columns:1fr;gap:26px}}

/* read-aloud */
.readbox{position:relative;padding:4px 0 6px 20px;margin-bottom:22px}
.readbox::before{content:"";position:absolute;left:0;top:2px;bottom:2px;width:4px;background:linear-gradient(180deg,var(--t),var(--tdeep))}
.readbox .lab{font-family:var(--f-mono);font-weight:700;font-size:8.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--tdeep);display:block;margin-bottom:8px}
.readbox p{font-family:var(--f-body);font-style:italic;font-size:16.5px;line-height:1.58;margin:0 0 10px;color:var(--rink)}
.readbox p:last-child{margin-bottom:0}

/* meta strip */
.rmeta{display:flex;border-top:2px solid var(--rink);border-bottom:2px solid var(--rink);margin-bottom:24px}
.rmeta>div{flex:1;padding:10px 4px 11px}
.rmeta>div+div{border-left:1.5px solid color-mix(in srgb,var(--rink) 28%,transparent);padding-left:12px}
.rmeta b{display:block;font-family:var(--f-mono);font-weight:700;font-size:7.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tdeep);margin-bottom:4px}
.rmeta .v{font-family:var(--f-mono);font-size:12px;letter-spacing:.02em;color:var(--rink)}

/* subhead */
.rsub{font-family:var(--f-mono);font-weight:700;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--tdeep);
  display:flex;align-items:center;gap:10px;margin:0 0 14px}
.rsub::after{content:"";flex:1;height:6px;background:repeating-linear-gradient(90deg,var(--tdeep) 0 5px,transparent 5px 10px);opacity:.55}

/* clock */
.rclock{list-style:none;margin:0 0 26px;padding:0;counter-reset:beat}
.rclock li{counter-increment:beat;display:grid;grid-template-columns:26px 1fr;gap:12px;padding:8px 0;border-bottom:1px dashed color-mix(in srgb,var(--rink) 26%,transparent);font-size:14.5px;line-height:1.45;color:var(--rink)}
.rclock li:last-child{border-bottom:none}
.rclock li::before{content:counter(beat);font-family:var(--f-mono);font-weight:700;font-size:12px;color:var(--t);
  background:var(--rink);width:24px;height:24px;display:flex;align-items:center;justify-content:center;align-self:start}

/* statblock */
.rstat{position:relative;background:var(--paper2);border:2px solid var(--tdeep);padding:18px 18px 19px;margin-bottom:22px;
  box-shadow:6px 6px 0 var(--tdeep)}
.rstat .snm{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:24px;letter-spacing:.4px;line-height:1;color:var(--rink)}
.rstat .skind{font-family:var(--f-mono);font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--tdeep);margin:6px 0 12px}
.rstat .svit{font-family:var(--f-body);font-size:14.5px;line-height:1.5;color:var(--rink);padding-bottom:10px;margin-bottom:10px;border-bottom:1.5px solid color-mix(in srgb,var(--rink) 24%,transparent)}
.rstat .srow{font-family:var(--f-body);font-size:13.5px;line-height:1.45;color:var(--rink);margin-bottom:7px}
.rstat .srow:last-child{margin-bottom:0}
.rstat .srow .k{font-family:var(--f-mono);font-weight:700;font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--tdeep);margin-right:6px}

/* 5e note */
.r5e{border:1.5px dashed var(--tdeep);padding:14px 16px;margin-bottom:8px;background:color-mix(in srgb,var(--t) 8%,transparent)}
.r5e .h{font-family:var(--f-mono);font-weight:700;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--tdeep);margin-bottom:8px}
.r5e p{font-family:var(--f-body);font-size:13.5px;line-height:1.5;color:var(--rink);margin:0}

/* aside: map + notes */
.raside{position:relative}
.rmap{position:relative;border:2px solid var(--rink);background:#0c1316;box-shadow:9px 9px 0 var(--t);aspect-ratio:1/1;overflow:hidden;padding:34px 12px 12px}
.rmap img{width:100%;height:100%;object-fit:contain}
.rmap .tag{position:absolute;left:0;top:0;font-family:var(--f-mono);font-weight:700;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:#0c0f0c;background:var(--t);padding:5px 10px}
.rmap .scale{position:absolute;right:8px;bottom:7px;font-family:var(--f-mono);font-size:7.5px;letter-spacing:.1em;text-transform:uppercase;color:#9fb0ab}
.rcard{border:1.5px solid var(--tdeep);padding:15px 16px;margin-top:18px;background:var(--paper2)}
.rcard .rl{font-family:var(--f-mono);font-weight:700;font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--tdeep);margin-bottom:9px}
.rcard .rt{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:19px;letter-spacing:.3px;line-height:1;color:var(--rink);margin-bottom:8px}
.rcard p{font-family:var(--f-body);font-size:13px;line-height:1.5;color:var(--rink2);margin:0}
.rcard .rooms{font-family:var(--f-mono);font-size:11px;letter-spacing:.04em;color:var(--rink);line-height:1.7}
.rcard .rooms .on{color:var(--tdeep);font-weight:700}
.rcard .rooms .num{color:var(--t);font-weight:700}

/* footer CTA bar */
.rfoot{position:relative;z-index:2;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:16px clamp(22px,4vw,52px);border-top:2px solid var(--rink);background:var(--paper2)}
.rfoot .zbtn{border-color:var(--tdeep);color:var(--rink)}
.rfoot .zbtn.fill{background:var(--tdeep);color:var(--paper)}
.rfoot .zbtn.fill:hover{background:var(--t);color:#0c0f0c}
.rfoot .zbtn.ghost:hover{background:var(--tdeep);color:var(--paper)}
.rfoot .spacer{flex:1}
.rfoot .rdl{font-family:var(--f-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--rink2)}
@media(max-width:560px){.rfoot .spacer{display:none}.rfoot .rdl{flex-basis:100%;order:5}}

/* ---------- BONE GROUND override (Tweak) ---------- */
[data-ground="bone"] body{background:var(--bone);color:var(--ink)}
[data-ground="bone"] .topbar{background:var(--bone);border-color:var(--bone2)}
[data-ground="bone"] .topbar .brand{color:var(--ink)}
[data-ground="bone"] .hero .wash{background:radial-gradient(120% 80% at 18% -10%,color-mix(in srgb,var(--torch) 14%,transparent),transparent 52%),radial-gradient(100% 90% at 92% 8%,rgba(120,130,120,.18),transparent 55%)}
[data-ground="bone"] .hero h1{color:var(--ink)}
[data-ground="bone"] .hero .sub,[data-ground="bone"] .hero .stat b{color:var(--ink)}
[data-ground="bone"] .index{background:var(--bone2);border-color:var(--bone2)}
[data-ground="bone"] .idx .en{color:var(--ink)}
[data-ground="bone"] .shead h2,[data-ground="bone"] .book .cap .t{color:var(--ink)}
[data-ground="bone"] .mapshow{background:var(--bone2);border-color:var(--bone2)}
[data-ground="bone"] .mapshow .copy h2,[data-ground="bone"] .mapshow .copy p{color:var(--ink)}
[data-ground="bone"] .relic{background:var(--bone);border-color:var(--bone2)}
[data-ground="bone"] .relic .rt,[data-ground="bone"] .thread .lede h2,[data-ground="bone"] .thread .lede p{color:var(--ink)}
[data-ground="bone"] .band h3{color:var(--ink)}
[data-ground="bone"] footer{background:var(--bone2);border-color:var(--bone2)}
[data-ground="bone"] footer .foot b{color:var(--ink)}
[data-ground="bone"] .foam,[data-ground="bone"] body{--foam:var(--ink);--foam-dim:var(--ink-soft);--rule:#b8b0a0}
