/* ============================================================
   COBRA CODY — THE MOUNTAIN'S TALES
   Design system: ink-on-stone manuscript. Near-black ground,
   cinnabar seal red, brushed gold, jade accent. Signature motif
   is the carved ink seal ("chop") stamped beside every record.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,500;0,600;0,700;1,500&family=Spectral:ital,wght@0,400;0,500;0,600;1,400&family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --ink-black:#07080a;
  --panel:#0d0f12;
  --panel-2:#141821;
  --parchment:#f2ead9;
  --muted:#a89f8f;
  --soft:#6f6a60;
  --line:rgba(242,234,217,.09);
  --line-2:rgba(242,234,217,.17);
  --cinnabar:#c22a1d;
  --cinnabar-bright:#ff4630;
  --cinnabar-soft:rgba(194,42,29,.22);
  --gold:#c9a15a;
  --gold-soft:rgba(201,161,90,.22);
  --jade:#2f9e8f;
  --shadow:0 30px 120px rgba(0,0,0,.65);
  --shadow-sm:0 14px 44px rgba(0,0,0,.4);
  --display:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --serif:'Spectral',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --read:700px;
  --radius-lg:28px;
  --radius-md:20px;
  --radius-sm:13px;
  --reading-scale:1;
  --ease:cubic-bezier(.16,.9,.24,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--ink-black);color:var(--parchment);font-family:var(--serif);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body.no-scroll{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit}
::selection{background:var(--cinnabar-soft);color:var(--parchment)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:6px}

.skip{position:fixed;left:14px;top:14px;z-index:999;transform:translateY(-160%);padding:10px 16px;border-radius:999px;background:var(--parchment);color:var(--ink-black);font-family:var(--sans);font-weight:800;transition:transform .2s var(--ease)}
.skip:focus{transform:none}

/* ---------- progress ---------- */
.progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;background:rgba(255,255,255,.04)}
.progress__bar{height:100%;width:100%;transform:scaleX(0);transform-origin:left;background:linear-gradient(90deg,var(--cinnabar),var(--gold));box-shadow:0 0 22px rgba(194,42,29,.6);transition:transform .08s linear}

/* ---------- ambient bg ---------- */
.bg{position:fixed;inset:0;z-index:-3;background:radial-gradient(1000px 650px at 50% -20%,rgba(194,42,29,.09),transparent 65%),linear-gradient(180deg,#0a0a0b 0%,#07080a 48%,#020203 100%);pointer-events:none}
.bg__orb{position:absolute;border-radius:999px;filter:blur(30px);opacity:.22}
.bg__orb--one{width:480px;height:480px;left:-170px;top:120px;background:var(--cinnabar)}
.bg__orb--two{width:420px;height:420px;right:-160px;top:620px;background:var(--jade);opacity:.1}
.bg__grain{position:absolute;inset:-50%;opacity:.09;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='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.62'/%3E%3C/svg%3E");animation:grain 9s steps(10) infinite}
.bg__vignette{position:absolute;inset:0;background:radial-gradient(circle at center,transparent 0%,rgba(0,0,0,.5) 76%,rgba(0,0,0,.88) 100%)}
@keyframes grain{0%,100%{transform:translate(0,0)}10%{transform:translate(-3%,2%)}30%{transform:translate(2%,-4%)}60%{transform:translate(4%,3%)}80%{transform:translate(-2%,-2%)}}

/* ---------- seal / chop signature motif ---------- */
.seal{position:relative;display:inline-grid;place-items:center;flex:none;border-radius:9px;background:linear-gradient(155deg,var(--cinnabar),#8f1f14);box-shadow:0 8px 22px rgba(194,42,29,.35),inset 0 0 0 1px rgba(255,255,255,.14);color:#fff0ea}
.seal svg{display:block}
.seal--sm{width:34px;height:34px;transform:rotate(-3deg)}
.seal--md{width:52px;height:52px;transform:rotate(-2deg)}
.seal--lg{width:68px;height:68px;transform:rotate(-4deg)}

/* ---------- topbar ---------- */
.topbar{position:sticky;top:0;z-index:100;border-bottom:1px solid var(--line);background:rgba(7,8,10,.68);backdrop-filter:blur(18px)}
.topbar__inner{min-height:74px;display:flex;align-items:center;justify-content:space-between;gap:20px;width:min(1240px,calc(100% - 36px));margin:auto}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--sans)}
.brand__text{display:grid;line-height:1.05}
.brand__text b{font-size:14px;letter-spacing:2px}
.brand__text small{margin-top:4px;color:var(--muted);font-size:12px;letter-spacing:.8px}

.topbar__nav{display:flex;align-items:center;gap:3px}
.navlink{position:relative;display:flex;align-items:center;gap:7px;padding:9px 11px;border-radius:999px;color:rgba(242,234,217,.72);font-family:var(--sans);font-size:12px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;transition:.18s}
.navlink:hover,.navlink.is-active{color:var(--parchment);background:rgba(255,255,255,.07)}
.navlink.is-active{box-shadow:inset 0 0 0 1px var(--cinnabar-soft)}
.navdot{width:5px;height:5px;border-radius:99px;background:rgba(242,234,217,.28);transition:.18s}
.navlink.is-active .navdot,.navlink.is-read .navdot{background:var(--cinnabar-bright);box-shadow:0 0 8px rgba(255,70,48,.7)}

.topbar__tools{display:flex;align-items:center;gap:8px}
.iconbtn{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--parchment);cursor:pointer;transition:.16s}
.iconbtn:hover{background:rgba(255,255,255,.08);border-color:var(--line-2)}
.searchToggle{display:flex;align-items:center;gap:8px;width:40px;overflow:hidden;padding:0 11px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.03);transition:width .28s var(--ease),background .18s}
.searchToggle.is-open{width:230px;background:rgba(255,255,255,.06)}
.searchToggle input{flex:1;min-width:0;border:0;background:transparent;color:var(--parchment);font-family:var(--sans);font-size:13px;opacity:0;transition:opacity .18s}
.searchToggle.is-open input{opacity:1}
.searchToggle svg{flex:none}

.menu{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:15px;background:rgba(255,255,255,.04);color:var(--parchment);cursor:pointer}
.menu span{display:block;width:19px;height:2px;background:var(--parchment);margin:4px auto;border-radius:99px;transition:.2s}

/* ---------- mobile drawer ---------- */
.mobile{position:fixed;inset:0;z-index:220}
.mobile__scrim{position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(10px)}
.mobile__panel{position:absolute;right:14px;top:14px;bottom:14px;width:min(390px,calc(100vw - 28px));padding:18px;border-radius:28px;border:1px solid var(--line-2);background:linear-gradient(180deg,rgba(20,24,33,.98),rgba(6,7,9,.98));box-shadow:var(--shadow);font-family:var(--sans);display:flex;flex-direction:column;gap:10px;overflow-y:auto}
.mobile__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.mobile__top span{display:block;color:var(--cinnabar-bright);font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:800}
.mobile__top strong{font-size:18px;font-family:var(--display)}
.mobile__close{width:42px;height:42px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--parchment);cursor:pointer}
.mobile__search{display:flex;align-items:center;gap:9px;padding:11px 14px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.035);margin-bottom:4px}
.mobile__search input{flex:1;border:0;background:transparent;color:var(--parchment);font-family:var(--sans);font-size:14px}
.mobile__link{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px;border-radius:18px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);font-weight:700}
.mobile__link span{display:block;color:var(--cinnabar-bright);font-size:11px;letter-spacing:1.6px;text-transform:uppercase;margin-bottom:2px;font-family:var(--sans)}
.mobile__link .navdot{flex:none}
.mobile__foot{margin-top:auto;padding-top:10px;border-top:1px solid var(--line);color:var(--soft);font-size:12px}

/* ---------- hero ---------- */
.hero{position:relative;padding:38px 18px 30px}
.hero__inner{position:relative;width:min(1240px,100%);min-height:680px;margin:auto;border:1px solid var(--line);border-radius:34px;overflow:hidden;display:grid;grid-template-columns:1.1fr .72fr;align-items:end;gap:22px;padding:clamp(24px,5vw,64px);background:linear-gradient(90deg,rgba(0,0,0,.9),rgba(0,0,0,.4)),radial-gradient(900px 420px at 20% 10%,rgba(194,42,29,.16),transparent 65%),url('images/chpt6.webp') center/cover;box-shadow:var(--shadow)}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.35),transparent 40%)}
.eyebrow{display:flex;align-items:center;gap:9px;margin:0 0 14px;color:var(--cinnabar-bright);font-family:var(--sans);font-size:12px;font-weight:800;letter-spacing:2.2px;text-transform:uppercase}
.eyebrow:before{content:"";width:22px;height:1px;background:var(--cinnabar-bright)}
.hero h1{position:relative;margin:0;font-family:var(--display);font-weight:700;font-size:clamp(56px,9.5vw,128px);line-height:.86;letter-spacing:-.02em;text-wrap:balance;text-shadow:0 18px 60px rgba(0,0,0,.65)}
.hero h1 em{font-style:italic;color:transparent;-webkit-text-stroke:1px rgba(242,234,217,.86);text-shadow:none}
.hero__lede{position:relative;max-width:680px;margin:26px 0 0;color:rgba(242,234,217,.83);font-size:clamp(17px,1.8vw,21px);line-height:1.55}
.hero__actions{position:relative;display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 20px;border-radius:999px;font-family:var(--sans);font-weight:800;font-size:12px;letter-spacing:1.3px;text-transform:uppercase;border:1px solid transparent;transition:.18s;cursor:pointer}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--parchment);color:#07080a}
.btn--primary:hover{background:#fff}
.btn--ghost{border-color:var(--line-2);background:rgba(0,0,0,.35);color:var(--parchment)}
.btn--ghost:hover{background:rgba(0,0,0,.5)}
.hero__panel{position:relative;align-self:end;display:grid;gap:14px}
.hero-card{border:1px solid var(--line);background:rgba(6,7,9,.64);backdrop-filter:blur(14px);border-radius:24px;padding:18px;font-family:var(--sans)}
.hero-card span{display:block;color:var(--cinnabar-bright);font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:800}
.hero-card strong{display:block;margin-top:8px;font-size:clamp(21px,3vw,34px);line-height:1.05;font-family:var(--display);font-weight:700}
.hero-card p{margin:10px 0 0;color:var(--muted);font-size:13.5px;line-height:1.5}
.hero-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hero-card-grid strong{font-size:24px}
.hero-card--continue{display:none;border-color:var(--gold-soft);background:linear-gradient(160deg,rgba(201,161,90,.14),rgba(6,7,9,.7))}
.hero-card--continue.is-visible{display:block}
.hero-card--continue a{display:inline-flex;align-items:center;gap:6px;margin-top:10px;color:var(--gold);font-size:12px;font-weight:800;letter-spacing:.6px;text-transform:uppercase}

/* ---------- reading controls dock ---------- */
.dock{position:fixed;right:16px;top:50%;transform:translateY(-50%);z-index:90;display:flex;flex-direction:column;gap:8px;padding:8px;border-radius:20px;border:1px solid var(--line);background:rgba(9,10,12,.72);backdrop-filter:blur(14px);box-shadow:var(--shadow-sm)}
.dock__btn{width:38px;height:38px;border-radius:13px;border:1px solid transparent;background:transparent;color:var(--muted);display:grid;place-items:center;cursor:pointer;font-family:var(--sans);font-weight:800;font-size:13px;transition:.16s}
.dock__btn:hover{background:rgba(255,255,255,.06);color:var(--parchment)}
.dock__btn.is-active{background:var(--cinnabar-soft);color:var(--cinnabar-bright);border-color:rgba(194,42,29,.4)}
.dock__sep{height:1px;background:var(--line);margin:2px 4px}

/* ---------- page shell ---------- */
.page{width:min(1120px,calc(100% - 36px));margin:0 auto 34px;display:grid;gap:22px}
.panel,.quote-strip,.archive-grid,.chapter{border:1px solid var(--line);border-radius:30px;background:linear-gradient(180deg,rgba(20,24,33,.86),rgba(9,10,12,.92));box-shadow:0 24px 90px rgba(0,0,0,.28)}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}

.intro{display:grid;grid-template-columns:1fr .78fr;gap:24px;align-items:end;padding:32px}
.intro h2{margin:0;font-family:var(--display);font-weight:700;font-size:clamp(32px,4.6vw,58px);line-height:.98;letter-spacing:-.01em}
.intro p:last-child{margin:0;color:var(--muted);font-family:var(--sans);font-size:15.5px}

/* ---------- search ---------- */
.searchbar{display:none;align-items:center;gap:10px;padding:13px 16px;margin:0 2px 4px;border-radius:20px;border:1px solid var(--line-2);background:rgba(0,0,0,.35)}
.searchbar.is-active{display:flex}
.searchbar input{flex:1;border:0;background:transparent;color:var(--parchment);font-family:var(--sans);font-size:14px}
.searchbar__count{color:var(--soft);font-family:var(--sans);font-size:12px;white-space:nowrap}
.searchbar__clear{border:0;background:transparent;color:var(--muted);cursor:pointer;font-family:var(--sans);font-size:12px;font-weight:700}

.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;overflow:hidden;background:rgba(255,255,255,.07);padding:1px}
.archive-card{position:relative;min-height:172px;padding:22px;background:linear-gradient(180deg,rgba(20,24,33,.96),rgba(9,10,12,.96));transition:.18s;display:flex;flex-direction:column}
.archive-card:hover{transform:translateY(-2px);background:radial-gradient(480px 180px at 20% 0,rgba(194,42,29,.14),rgba(20,24,33,.98))}
.archive-card.is-hidden{display:none}
.archive-card__top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.archive-card__num{color:var(--cinnabar-bright);font-family:var(--sans);font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase}
.archive-card__time{color:var(--soft);font-family:var(--sans);font-size:11px;font-weight:700}
.archive-card strong{display:block;margin:11px 0 6px;font-family:var(--display);font-weight:700;font-size:24px;line-height:1.06;letter-spacing:-.01em}
.archive-card small{color:var(--muted);font-family:var(--sans);font-size:13px;line-height:1.5}
.archive-card__read{margin-top:auto;padding-top:12px;color:var(--gold);font-family:var(--sans);font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;opacity:0;transform:translateX(-4px);transition:.18s}
.archive-card:hover .archive-card__read{opacity:1;transform:none}

.quote-strip{padding:26px;text-align:center;background:radial-gradient(700px 220px at 50% 0,rgba(47,158,143,.09),transparent 70%),rgba(0,0,0,.32)}
.quote-strip p{max-width:76ch;margin:0 auto;color:rgba(242,234,217,.92);font-family:var(--display);font-size:clamp(21px,3vw,30px);line-height:1.3;font-style:italic;font-weight:600}

/* ---------- chapter ---------- */
.chapter{position:relative;overflow:hidden;padding:clamp(20px,3vw,34px);scroll-margin-top:90px}
.chapter:before{content:"";position:absolute;inset:0;background:radial-gradient(700px 220px at 0 0,rgba(194,42,29,.08),transparent 70%);pointer-events:none}
.chapter__rail{position:absolute;right:24px;top:14px;font-family:var(--display);font-size:132px;line-height:1;font-weight:700;letter-spacing:-.04em;color:rgba(242,234,217,.03);pointer-events:none}
.chapter__head{position:relative;display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}
.chapter__headline{display:flex;gap:16px;align-items:flex-start}
.chapter__kicker{display:flex;align-items:center;gap:8px;margin:0 0 9px;color:var(--cinnabar-bright);font-family:var(--sans);font-size:12px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase}
.chapter__title{margin:0;font-family:var(--display);font-weight:700;font-size:clamp(37px,5.6vw,72px);line-height:.96;letter-spacing:-.01em;text-wrap:balance}
.chapter__subtitle{margin:11px 0 0;color:var(--muted);font-family:var(--sans);font-size:14.5px}
.chapter__meta{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.chapter__jump{white-space:nowrap;padding:9px 13px;border:1px solid var(--line);border-radius:999px;color:var(--muted);font-family:var(--sans);font-size:11px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase}
.chapter__stats{display:flex;gap:12px;color:var(--soft);font-family:var(--sans);font-size:11.5px;font-weight:700;white-space:nowrap}

.figure{position:relative;margin:0 0 22px;border-radius:26px;overflow:hidden;border:1px solid var(--line);background:#000}
.figure__img{display:block;width:100%;aspect-ratio:16/8.2;object-fit:cover;filter:saturate(1.05) contrast(1.08);transition:transform .6s var(--ease),filter .5s;cursor:zoom-in;background-size:cover;background-position:center}
.figure:hover .figure__img{transform:scale(1.02)}
.figure figcaption{position:absolute;left:16px;right:16px;bottom:16px;padding:14px 16px;border-radius:18px;background:rgba(0,0,0,.58);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);color:rgba(242,234,217,.82);font-family:var(--sans);font-size:13.5px;line-height:1.45}

.story-layout{position:relative;display:grid;grid-template-columns:280px minmax(0,1fr);gap:28px;align-items:start}
.story-note{position:sticky;top:96px;padding:18px;border-radius:22px;border:1px solid var(--line);background:rgba(255,255,255,.03);font-family:var(--sans)}
.story-note__head{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.story-note span{color:var(--cinnabar-bright);font-size:11px;font-weight:800;letter-spacing:1.8px;text-transform:uppercase}
.story-note strong{display:block;margin:9px 0;font-family:var(--display);font-size:21px;font-weight:700;line-height:1.14}
.story-note p{margin:0 0 12px;color:var(--muted);font-size:13.5px;line-height:1.55}
.story-note__actions{display:flex;gap:8px}
.story-note__actions button{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 10px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--muted);font-family:var(--sans);font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:.16s}
.story-note__actions button:hover{background:rgba(255,255,255,.08);color:var(--parchment)}

.prose{max-width:var(--read);font-size:calc(1px*var(--reading-scale))}
.prose p{margin:0 0 16px;color:rgba(242,234,217,.92);font-size:calc(clamp(17px,1.9vw,20px) * var(--reading-scale));line-height:1.68;text-wrap:pretty}
.prose p:first-child:first-letter{float:left;font-family:var(--display);font-size:4.6em;line-height:.76;padding:.08em .12em 0 0;color:var(--cinnabar-bright);font-weight:700}
.quote{margin:26px 0 0;padding:22px;border-radius:22px;border:1px solid rgba(194,42,29,.26);background:radial-gradient(620px 190px at 20% 0,rgba(194,42,29,.15),transparent 64%),rgba(0,0,0,.26)}
.quote p{margin:0;font-style:italic;font-family:var(--display);font-size:calc(1.05em * var(--reading-scale))}
.quote cite{display:block;margin-top:10px;color:var(--muted);font-family:var(--sans);font-size:12px;font-style:normal;letter-spacing:1.1px;text-transform:uppercase}

.chapter__foot{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;margin-top:26px}
.chapter__foot span{height:1px;background:linear-gradient(90deg,transparent,rgba(194,42,29,.4))}
.chapter__foot span:last-child{background:linear-gradient(90deg,rgba(194,42,29,.4),transparent)}
.chapter__foot b{color:var(--cinnabar-bright);font-weight:400}

.chapter-nav{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:22px}
.chapter-nav__link{display:flex;flex-direction:column;gap:6px;padding:16px 18px;border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.025);font-family:var(--sans);transition:.16s}
.chapter-nav__link:hover{background:rgba(255,255,255,.06);border-color:var(--line-2)}
.chapter-nav__link--next{text-align:right;align-items:flex-end}
.chapter-nav__link span{color:var(--soft);font-size:10.5px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase}
.chapter-nav__link strong{font-family:var(--display);font-size:19px;font-weight:700}

/* ---------- scribe's mark ---------- */
.scribe{display:inline-flex;align-items:center;gap:10px;padding:10px 14px 10px 10px;border-radius:999px;border:1px solid var(--line-2);background:rgba(255,255,255,.03);font-family:var(--sans)}
.scribe__seal{width:28px;height:28px;border-radius:7px}
.scribe__body{display:grid;line-height:1.15}
.scribe__label{color:var(--soft);font-size:10px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase}
.scribe__name{font-family:var(--display);font-size:15px;font-weight:700;letter-spacing:.02em}
.scribe__name.is-clean{color:var(--gold)}

/* ---------- footer ---------- */
.footer{padding:30px 18px 40px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;color:rgba(242,234,217,.5);font-family:var(--sans);font-size:12.5px}
.footer__line{margin:0}

.toTop{position:fixed;right:16px;bottom:16px;z-index:80;width:48px;height:48px;border-radius:16px;border:1px solid var(--line-2);background:rgba(8,9,11,.72);backdrop-filter:blur(12px);color:var(--parchment);cursor:pointer;opacity:0;transform:translateY(10px);pointer-events:none;transition:.18s;box-shadow:var(--shadow-sm)}
.toTop--show{opacity:1;transform:translateY(0);pointer-events:auto}

.lightbox{position:fixed;inset:0;z-index:300}
.lightbox__bg{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(10px)}
.lightbox__frame{position:relative;width:min(1140px,94vw);margin:6vh auto 0;padding:12px;border-radius:28px;border:1px solid var(--line-2);background:rgba(11,13,16,.82);box-shadow:var(--shadow)}
.lightbox__img{display:block;width:100%;max-height:74vh;object-fit:contain;border-radius:20px}
.lightbox__caption{padding:14px 8px 4px;color:var(--muted);font-family:var(--sans);font-size:13.5px;text-align:center}
.lightbox__close{position:absolute;top:12px;right:12px;width:42px;height:42px;border-radius:14px;border:1px solid var(--line);background:rgba(0,0,0,.55);color:var(--parchment);cursor:pointer}
.lightbox__prev,.lightbox__next{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:1px solid var(--line-2);background:rgba(0,0,0,.5);color:var(--parchment);cursor:pointer;display:grid;place-items:center}
.lightbox__prev{left:-16px}
.lightbox__next{right:-16px}

.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,20px);z-index:400;padding:12px 20px;border-radius:999px;border:1px solid var(--line-2);background:rgba(10,11,14,.92);backdrop-filter:blur(12px);color:var(--parchment);font-family:var(--sans);font-size:13px;font-weight:600;opacity:0;pointer-events:none;transition:.22s var(--ease);box-shadow:var(--shadow-sm)}
.toast.is-visible{opacity:1;transform:translate(-50%,0)}

.no-results{display:none;padding:40px 20px;text-align:center;color:var(--muted);font-family:var(--sans);grid-column:1/-1}
.no-results.is-visible{display:block}

/* ---------- focus mode: dim chrome, spotlight the prose ---------- */
body.focus-mode .hero,body.focus-mode .intro,body.focus-mode .archive-grid,body.focus-mode .quote-strip,
body.focus-mode .searchbar,body.focus-mode .chapter__rail,body.focus-mode .bg__orb,body.focus-mode .figure{opacity:.28;transition:opacity .25s}
body.focus-mode .chapter:hover .figure,body.focus-mode .story-layout:hover .figure{opacity:1}
body.focus-mode .topbar{background:rgba(7,8,10,.92)}
body.focus-mode .prose,body.focus-mode .story-note{opacity:1}

.mobile__link{position:relative}
.mobile__link:before{content:"";position:absolute;left:6px;top:6px;width:6px;height:6px;border-radius:99px;background:rgba(242,234,217,.22)}
.mobile__link.is-read:before{background:var(--cinnabar-bright);box-shadow:0 0 8px rgba(255,70,48,.7)}

@media(max-width:980px){
  .topbar__nav,.dock{display:none}
  .menu{display:block}
  .hero__inner{grid-template-columns:1fr;min-height:720px;background-position:center}
  .intro{grid-template-columns:1fr}
  .archive-grid{grid-template-columns:repeat(2,1fr)}
  .story-layout{grid-template-columns:1fr}
  .story-note{position:relative;top:auto}
  .figure__img{aspect-ratio:16/10}
  .chapter__jump{display:none}
  .chapter-nav{grid-template-columns:1fr}
  .chapter-nav__link--next{text-align:left;align-items:flex-start}
}
@media(max-width:620px){
  .topbar__inner,.page{width:calc(100% - 24px)}
  .hero{padding:22px 12px}
  .hero__inner{min-height:660px;border-radius:26px;padding:24px}
  .hero h1{font-size:54px}
  .hero__lede{font-size:16.5px}
  .hero__actions{display:grid}
  .btn{width:100%}
  .hero-card-grid,.archive-grid{grid-template-columns:1fr}
  .intro,.chapter{padding:20px;border-radius:24px}
  .chapter__rail{display:none}
  .chapter__title{font-size:40px}
  .chapter__head{flex-direction:column}
  .chapter__meta{align-items:flex-start;flex-direction:row}
  .figure figcaption{position:static;border-radius:0;border-left:0;border-right:0;border-bottom:0}
  .prose p{font-size:calc(18px * var(--reading-scale))}
  .prose p:first-child:first-letter{font-size:3.5em}
  .quote-strip p{font-size:21px}
  .mobile__panel{left:12px;right:12px;top:12px;bottom:12px;width:auto}
  .searchToggle.is-open{width:170px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
}
