/* ═══════════════════════════════════════════════════════════════
   Leve Web — Brand CSS System
   Derived from FRONTEND-STYLE-GUIDE.md — the definitive reference.
   Every token, pattern, and animation here was earned through
   iterative prototyping. Follow it precisely.
   ═══════════════════════════════════════════════════════════════ */

*{margin:0;padding:0;box-sizing:border-box}

:root{
  --s0:#161310;--sc:#221F1C;--sch:#2D2926;--schh:#383431;
  --on:#E9E1DC;--onv:#D3C4B3;--onvv:#9C8F7F;--olv:#4F4538;
  --ll:#F4BD6B;--llc:#C89648;--ll-on:#4B3100;
  --blue:#9BCBFE;--rose:#E8A0BF;--sage:#A8C4A0;--amber:#E8B86D;
  --hl:rgba(156,143,127,0.1);
  --ease:cubic-bezier(0.22,0.61,0.36,1);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
}

html{scroll-behavior:smooth}
body{background:var(--s0);color:var(--on);font-family:'Geist',sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:rgba(244,189,107,0.2);color:var(--ll)}

/* ═══ Aurora — the living room ═══ */
.aurora{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.aurora-glow{position:absolute;border-radius:50%;filter:blur(100px);mix-blend-mode:screen;opacity:0}
.g1{width:800px;height:800px;background:radial-gradient(circle,rgba(244,189,107,0.14) 0%,transparent 60%);top:-180px;left:-140px;animation:drift1 24s ease-in-out infinite,breathe1 6s ease-in-out infinite alternate,fadeIn 2.5s ease 0.3s forwards}
.g2{width:600px;height:600px;background:radial-gradient(circle,rgba(232,160,191,0.08) 0%,transparent 60%);top:20%;right:-120px;animation:drift2 30s ease-in-out infinite,breathe2 8s ease-in-out infinite alternate,fadeIn 2.5s ease 0.6s forwards}
.g3{width:700px;height:700px;background:radial-gradient(circle,rgba(155,203,254,0.05) 0%,transparent 60%);bottom:-220px;left:35%;animation:drift3 36s ease-in-out infinite,breathe3 10s ease-in-out infinite alternate,fadeIn 2.5s ease 0.9s forwards}
.g4{width:500px;height:500px;background:radial-gradient(circle,rgba(168,196,160,0.04) 0%,transparent 60%);top:50%;left:5%;animation:drift4 28s ease-in-out infinite,breathe4 7s ease-in-out infinite alternate,fadeIn 2.5s ease 1.2s forwards}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1) rotate(0deg)}33%{transform:translate(80px,50px) scale(1.1) rotate(8deg)}66%{transform:translate(-40px,100px) scale(0.95) rotate(-5deg)}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1) rotate(0deg)}50%{transform:translate(-100px,70px) scale(1.15) rotate(-10deg)}}
@keyframes drift3{0%,100%{transform:translate(0,0) scale(1) rotate(0deg)}33%{transform:translate(-50px,-70px) scale(1.05) rotate(6deg)}66%{transform:translate(60px,-30px) scale(0.9) rotate(-8deg)}}
@keyframes drift4{0%,100%{transform:translate(0,0) scale(1) rotate(0deg)}50%{transform:translate(70px,-50px) scale(1.2) rotate(12deg)}}
@keyframes breathe1{0%{filter:blur(100px) brightness(0.8)}100%{filter:blur(100px) brightness(1.2)}}
@keyframes breathe2{0%{filter:blur(100px) brightness(0.7)}100%{filter:blur(100px) brightness(1.15)}}
@keyframes breathe3{0%{filter:blur(100px) brightness(0.6)}100%{filter:blur(100px) brightness(1.1)}}
@keyframes breathe4{0%{filter:blur(100px) brightness(0.7)}100%{filter:blur(100px) brightness(1.2)}}
@keyframes fadeIn{to{opacity:1}}
@keyframes rise{to{opacity:1;transform:translateY(0)}}
@keyframes lamplight{0%{opacity:0.4}100%{opacity:1}}

/* ═══ Nav ═══ */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;gap:24px;padding:16px 36px;background:transparent;transition:all 0.4s var(--ease)}
nav.scrolled{background:rgba(22,19,16,0.7);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border-bottom:0.5px solid var(--hl);padding:12px 36px}
.brand{font-family:'Fraunces',serif;font-weight:600;font-size:24px;color:var(--ll);letter-spacing:-0.035em;font-variation-settings:'opsz' 144;line-height:1;cursor:pointer;transition:filter 0.3s var(--ease);text-decoration:none}
.brand:hover{filter:drop-shadow(0 0 8px rgba(244,189,107,0.4))}
.nav-links{display:flex;gap:22px;margin-left:28px;list-style:none}
.nav-links a{font-size:12px;color:var(--onv);text-decoration:none;transition:color 0.2s;cursor:pointer;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--ll);transform:scaleX(0);transform-origin:left;transition:transform 0.3s var(--ease)}
.nav-links a:hover{color:var(--on)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-links a.active{color:var(--on)}
.nav-links a.active::after{transform:scaleX(1)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.nav-room-label{font-size:11px;color:var(--onvv);text-transform:uppercase;letter-spacing:0.1em}

/* ═══ Layout ═══ */
.page-wrap{position:relative;z-index:1}
.content-wrap{max-width:760px;margin:0 auto;padding:100px 24px 80px;position:relative;z-index:1}
.wide-wrap{max-width:1200px;margin:0 auto;padding:100px 24px 80px;position:relative;z-index:1}

/* ═══ Room Home (index) ═══ */
.home-header{margin-bottom:60px;opacity:0;animation:rise 1s var(--ease-out) 0.2s forwards}
.home-title{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(36px,6vw,56px);color:var(--on);letter-spacing:-0.03em;font-variation-settings:'opsz' 144;line-height:1.05;margin-bottom:16px}
.home-title em{font-style:italic;font-weight:300;color:var(--ll);position:relative}
.home-title em::after{content:'';position:absolute;bottom:-2px;left:-10%;right:-10%;height:70%;background:radial-gradient(ellipse 80% 100% at 50% 100%,rgba(244,189,107,0.2) 0%,transparent 70%);filter:blur(24px);z-index:-1;animation:lamplight 4s ease-in-out infinite alternate}
.home-subtitle{font-size:17px;color:var(--onv);max-width:520px;line-height:1.5}

/* Summary ledger */
.ledger{display:flex;gap:0;padding:20px 0;border-top:0.5px solid var(--hl);border-bottom:0.5px solid var(--hl);margin-bottom:60px;flex-wrap:wrap}
.ledger-item{flex:1;min-width:80px;text-align:center;padding:0 12px;border-right:0.5px solid var(--hl)}
.ledger-item:last-child{border-right:none}
.ledger-num{font-family:'Fraunces',serif;font-weight:600;font-size:28px;color:var(--ll);font-variation-settings:'opsz' 144;line-height:1}
.ledger-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.12em;color:var(--onvv);margin-top:6px}

/* Section headers */
.section-header{font-family:'Fraunces',serif;font-weight:500;font-size:24px;color:var(--on);letter-spacing:-0.02em;font-variation-settings:'opsz' 144;margin-bottom:28px;display:flex;align-items:center;gap:14px}
.section-header .accent-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.section-header .accent-dot.ll{background:var(--ll);box-shadow:0 0 8px rgba(244,189,107,0.3)}
.section-header .accent-dot.rose{background:var(--rose);box-shadow:0 0 8px rgba(232,160,191,0.3)}
.section-header .accent-dot.sage{background:var(--sage);box-shadow:0 0 8px rgba(168,196,160,0.3)}
.section-header .accent-dot.blue{background:var(--blue);box-shadow:0 0 8px rgba(155,203,254,0.3)}
.section-header .accent-dot.amber{background:var(--amber);box-shadow:0 0 8px rgba(232,184,109,0.3)}

/* Section spacing */
.home-section{margin-bottom:72px}
.home-section:last-child{margin-bottom:0}

/* ═══ Story list (open list, no cards) ═══ */
.story-list{list-style:none}
.story-item{padding:22px 0;border-bottom:0.5px solid var(--hl);transition:padding 0.3s var(--ease);position:relative;cursor:pointer}
.story-item::before{content:'';position:absolute;left:0;top:50%;width:2px;height:0;background:var(--ll);transition:height 0.4s var(--ease-out);transform:translateY(-50%);border-radius:1px}
.story-item:hover{padding-left:10px}
.story-item:hover::before{height:60%}
.story-item:first-child{border-top:0.5px solid var(--hl)}
.story-item-type{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.12em;color:var(--onvv);margin-bottom:6px}
.story-item-title{font-family:'Fraunces',serif;font-weight:500;font-size:20px;color:var(--on);font-variation-settings:'opsz' 48;letter-spacing:-0.01em;transition:color 0.2s var(--ease);margin-bottom:4px}
.story-item:hover .story-item-title{color:var(--ll)}
.story-item-teaser{font-size:14px;color:var(--onv);line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.story-item-meta{display:flex;gap:10px;align-items:center;font-size:11px;color:var(--onvv)}
.story-item-meta .chips{display:flex;gap:6px;flex-wrap:wrap}
.mini-chip{font-size:10px;color:var(--onvv);background:var(--schh);padding:2px 8px;border-radius:10px;white-space:nowrap}
.mini-chip.rose{color:var(--rose)}
.mini-chip.ll{color:var(--ll)}
.mini-chip.sage{color:var(--sage)}
.mini-chip.blue{color:var(--blue)}

/* ═══ Person / Place / Theme / Relationship lists ═══ */
.entity-list{list-style:none}
.entity-item{padding:18px 0;border-bottom:0.5px solid var(--hl);transition:padding 0.3s var(--ease);position:relative;cursor:pointer;text-decoration:none;display:block}
.entity-item::before{content:'';position:absolute;left:0;top:50%;width:2px;height:0;transition:height 0.4s var(--ease-out);transform:translateY(-50%);border-radius:1px}
.entity-item:hover{padding-left:10px}
.entity-item:hover::before{height:60%}
.entity-item:first-child{border-top:0.5px solid var(--hl)}
.entity-item.rose::before{background:var(--rose)}
.entity-item.sage::before{background:var(--sage)}
.entity-item.blue::before{background:var(--blue)}
.entity-item.amber::before{background:var(--amber)}
.entity-item.ll::before{background:var(--ll)}
.entity-item-title{font-family:'Fraunces',serif;font-weight:500;font-size:18px;color:var(--on);font-variation-settings:'opsz' 48;transition:color 0.2s var(--ease);margin-bottom:2px}
.entity-item:hover .entity-item-title{color:var(--ll)}
.entity-item.rose:hover .entity-item-title{color:var(--rose)}
.entity-item.sage:hover .entity-item-title{color:var(--sage)}
.entity-item.blue:hover .entity-item-title{color:var(--blue)}
.entity-item.amber:hover .entity-item-title{color:var(--amber)}
.entity-item-teaser{font-size:13px;color:var(--onvv);line-height:1.4}

/* ═══ Story page ═══ */
.story-wrap{max-width:680px;margin:0 auto;padding:100px 24px 80px;position:relative;z-index:1}
.page-type-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.14em;color:var(--onvv);margin-bottom:14px;display:block;opacity:0;animation:rise 0.6s var(--ease) 0.1s forwards}
.page-title{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(32px,5.5vw,46px);color:var(--on);letter-spacing:-0.02em;font-variation-settings:'opsz' 144;line-height:1.1;margin-bottom:22px;opacity:0;animation:rise 0.8s var(--ease-out) 0.2s forwards}
.page-quote{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:19px;color:var(--ll);border-left:2px solid var(--llc);padding-left:22px;margin-bottom:22px;line-height:1.4;opacity:0;animation:rise 0.8s var(--ease) 0.35s forwards;position:relative}
.page-quote::after{content:'';position:absolute;bottom:-4px;left:22px;right:0;height:50%;background:radial-gradient(ellipse 80% 100% at 50% 100%,rgba(244,189,107,0.12) 0%,transparent 70%);filter:blur(20px);z-index:-1;animation:lamplight 4s ease-in-out infinite alternate}
.page-meta{display:flex;gap:14px;flex-wrap:wrap;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:0.08em;color:var(--onvv);padding-bottom:36px;border-bottom:0.5px solid var(--hl);margin-bottom:44px;opacity:0;animation:rise 0.6s var(--ease) 0.45s forwards}
.meta-sep{color:var(--olv)}

/* Body text */
.story-body{font-size:17px;color:var(--on);line-height:1.7;letter-spacing:0.003em}
.story-body p{margin-bottom:22px}
.story-body h1,.story-body h2,.story-body h3{font-family:'Fraunces',serif;font-variation-settings:'opsz' 144;letter-spacing:-0.02em;color:var(--on);margin-top:48px;margin-bottom:20px}
.story-body h1{font-size:28px;font-weight:600}
.story-body h2{font-size:22px;font-weight:500}
.story-body h3{font-size:18px;font-weight:500;font-variation-settings:'opsz' 48}
.story-body ul,.story-body ol{margin-bottom:22px;padding-left:24px}
.story-body li{margin-bottom:8px;line-height:1.6}
.story-body blockquote{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:18px;color:var(--ll);border-left:2px solid var(--llc);padding-left:22px;margin:28px 0;line-height:1.5;position:relative}
.story-body blockquote::after{content:'';position:absolute;bottom:-4px;left:22px;right:0;height:50%;background:radial-gradient(ellipse 80% 100% at 50% 100%,rgba(244,189,107,0.1) 0%,transparent 70%);filter:blur(20px);z-index:-1}
.story-body hr{border:none;border-top:0.5px solid var(--hl);margin:48px 0}
.story-body pre{background:var(--sc);padding:20px 24px;border-radius:6px;overflow-x:auto;margin:24px 0;font-size:13px;line-height:1.5}
.story-body code{font-family:'SF Mono',Menlo,monospace;font-size:0.9em}
.story-body pre code{color:var(--onv)}
.story-body .pchip{background:none;color:#B8AC9E;font-size:inherit;padding:0;border-radius:0;cursor:pointer;transition:color 0.3s var(--ease),text-shadow 0.4s var(--ease);text-decoration:none}
.story-body .pchip:hover{color:var(--ll);text-shadow:0 0 16px rgba(244,189,107,0.4)}
.story-body .pchip.dead-link{color:var(--onvv);cursor:default}
.story-body .pchip.dead-link:hover{color:var(--onvv);text-shadow:none}
.story-body strong{color:var(--on);font-weight:600}
.story-body em{color:var(--onv)}

/* Tables */
.data-table{width:100%;border-collapse:collapse;margin:24px 0;font-size:14px}
.data-table th{text-align:left;font-family:'Geist',sans-serif;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--onvv);padding:10px 12px;border-bottom:1px solid var(--olv)}
.data-table td{padding:12px;color:var(--onv);border-bottom:0.5px solid var(--hl);line-height:1.5}
.data-table tr:last-child td{border-bottom:none}
.data-table .pchip{background:none;color:#B8AC9E;font-size:inherit;padding:0;border-radius:0;cursor:pointer;transition:color 0.3s var(--ease),text-shadow 0.4s var(--ease);text-decoration:none}
.data-table .pchip:hover{color:var(--ll);text-shadow:0 0 16px rgba(244,189,107,0.4)}

/* Details/summary (curator notes) */
details{margin-top:24px;padding:16px 20px;background:var(--sc);border-radius:6px}
details summary{cursor:pointer;font-size:13px;font-weight:500;color:var(--onvv);text-transform:uppercase;letter-spacing:0.08em;list-style:none}
details summary::-webkit-details-marker{display:none}
details summary::before{content:'→ ';color:var(--ll)}
details[open] summary::before{content:'↓ ';color:var(--ll)}
details p,details li,details ul{font-size:13px;color:var(--onv);line-height:1.6;margin-top:12px}
details ul{padding-left:20px}

/* ═══ Sections within a page ═══ */
.page-section{margin-top:72px;padding-top:28px;border-top:0.5px solid var(--hl)}
.page-section h2{font-family:'Fraunces',serif;font-weight:500;font-size:22px;color:var(--on);letter-spacing:-0.02em;font-variation-settings:'opsz' 144;margin-bottom:20px}

/* Cast list — bilateral bars on hover */
.cast-row{display:flex;align-items:baseline;gap:16px;padding:10px 0;border-bottom:0.5px solid var(--hl);transition:padding 0.3s var(--ease);position:relative;cursor:pointer}
.cast-row::before{content:'';position:absolute;left:0;top:50%;width:2px;height:0;background:var(--rose);transition:height 0.4s var(--ease-out);transform:translateY(-50%);border-radius:1px}
.cast-row::after{content:'';position:absolute;right:0;top:50%;width:2px;height:0;background:var(--rose);transition:height 0.4s var(--ease-out);transform:translateY(-50%);border-radius:1px}
.cast-row:hover{padding-left:8px}
.cast-row:hover::before{height:60%}
.cast-row:hover::after{height:60%}
.cast-row:last-child{border-bottom:none}
.cast-name{font-family:'Fraunces',serif;font-weight:500;font-size:17px;color:var(--on);min-width:100px;font-variation-settings:'opsz' 48;transition:color 0.2s var(--ease);text-decoration:none}
.cast-row:hover .cast-name{color:var(--rose)}
.cast-role{font-size:13px;color:var(--onv);font-style:italic}

/* Timeline */
.timeline{padding-left:20px;position:relative}
.timeline::before{content:'';position:absolute;left:3px;top:6px;bottom:6px;width:1px;background:var(--olv);opacity:0.4}
.tl-item{position:relative;padding:8px 0;font-size:13px;color:var(--onv);line-height:1.4}
.tl-item::before{content:'';position:absolute;left:-20px;top:14px;width:7px;height:7px;border-radius:50%;background:var(--ll);box-shadow:0 0 6px rgba(244,189,107,0.3)}
.tl-item strong{color:var(--on);font-weight:500}

/* Theories — italic Fraunces, bilateral sage bars */
.theory{padding:16px 0;border-bottom:0.5px solid var(--hl);position:relative;transition:padding 0.3s var(--ease)}
.theory:first-child{border-top:0.5px solid var(--hl)}
.theory::before{content:'';position:absolute;left:0;top:50%;width:2px;height:0;background:var(--sage);transition:height 0.4s var(--ease-out);transform:translateY(-50%);border-radius:1px}
.theory::after{content:'';position:absolute;right:0;top:50%;width:2px;height:0;background:var(--sage);transition:height 0.4s var(--ease-out);transform:translateY(-50%);border-radius:1px}
.theory:hover{padding-left:8px}
.theory:hover::before{height:60%}
.theory:hover::after{height:60%}
.theory p{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:15px;color:var(--onv);line-height:1.5;margin-bottom:8px;transition:color 0.2s var(--ease)}
.theory:hover p{color:var(--on)}
.theory-attr{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.12em;color:var(--onvv)}

/* Versions — expandable, blue bilateral bars */
.version{border-bottom:0.5px solid var(--hl);position:relative}
.version:first-child{border-top:0.5px solid var(--hl)}
.version::before{content:'';position:absolute;left:0;top:50%;width:2px;height:0;background:var(--blue);transition:height 0.4s var(--ease-out);transform:translateY(-50%);border-radius:1px}
.version::after{content:'';position:absolute;right:0;top:50%;width:2px;height:0;background:var(--blue);transition:height 0.4s var(--ease-out);transform:translateY(-50%);border-radius:1px}
.version:hover::before{height:50%}
.version:hover::after{height:50%}
.vp-header{display:flex;align-items:center;gap:12px;padding:14px 0;cursor:pointer;user-select:none}
.vp-arrow{font-size:9px;color:var(--onv);transition:transform 0.3s var(--ease);display:inline-block}
.version.open .vp-arrow{transform:rotate(90deg)}
.vp-name{font-family:'Fraunces',serif;font-weight:500;font-size:16px;color:var(--on);font-variation-settings:'opsz' 48}
.vp-role{font-size:11px;color:var(--onvv);margin-left:auto}
.vp-body{max-height:0;overflow:hidden;transition:max-height 0.5s var(--ease)}
.version.open .vp-body{max-height:2000px}
.vp-body-inner{padding:0 0 20px 24px;font-size:15px;color:var(--onv);line-height:1.6}

/* Connections list at bottom of pages */
.connections{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.conn-chip{font-size:11px;color:var(--onv);background:var(--schh);padding:4px 12px;border-radius:12px;text-decoration:none;transition:color 0.2s var(--ease),background 0.2s var(--ease);white-space:nowrap}
.conn-chip:hover{color:var(--ll);background:var(--sch)}
.conn-chip.rose{color:var(--rose)}
.conn-chip.rose:hover{color:var(--rose);background:rgba(232,160,191,0.1)}
.conn-chip.sage{color:var(--sage)}
.conn-chip.sage:hover{color:var(--sage);background:rgba(168,196,160,0.1)}
.conn-chip.blue{color:var(--blue)}
.conn-chip.blue:hover{color:var(--blue);background:rgba(155,203,254,0.1)}
.conn-chip.amber{color:var(--amber)}
.conn-chip.amber:hover{color:var(--amber);background:rgba(232,184,109,0.1)}

/* Warmth indicator */
.warmth{font-size:10px;color:var(--ll);letter-spacing:2px;opacity:0.6}
.warmth[data-level="1"]{opacity:0.2}
.warmth[data-level="2"]{opacity:0.35}
.warmth[data-level="3"]{opacity:0.5}
.warmth[data-level="4"]{opacity:0.65}
.warmth[data-level="5"]{opacity:0.7}

/* Back link */
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--onvv);text-decoration:none;transition:color 0.2s var(--ease);margin-bottom:32px}
.back-link:hover{color:var(--ll)}

/* ═══ Memory Map page ═══ */
.map-wrap{max-width:100%;height:100vh;padding:80px 0 0;position:relative;z-index:1}
#memory-map{width:100%;height:calc(100vh - 80px);display:block}
.map-preview{position:fixed;top:80px;right:0;width:340px;height:calc(100vh - 80px);background:var(--sc);border-left:2px solid var(--ll);box-shadow:-4px 0 30px rgba(0,0,0,0.3);transform:translateX(100%);transition:transform 0.4s var(--ease-spring);z-index:50;overflow-y:auto;padding:28px 24px}
.map-preview.open{transform:translateX(0)}
.map-preview-close{position:absolute;top:16px;right:16px;font-size:18px;color:var(--onvv);cursor:pointer;background:none;border:none;transition:color 0.2s}
.map-preview-close:hover{color:var(--ll)}
.map-preview-type{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.12em;color:var(--onvv);margin-bottom:8px}
.map-preview-title{font-family:'Fraunces',serif;font-weight:600;font-size:22px;color:var(--on);font-variation-settings:'opsz' 144;letter-spacing:-0.01em;margin-bottom:14px}
.map-preview-summary{font-size:14px;color:var(--onv);line-height:1.5;margin-bottom:18px}
.map-preview-connections{font-size:11px;color:var(--onvv);margin-bottom:18px}
.map-preview-btn{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--ll);text-decoration:none;border:1px solid var(--llc);padding:8px 18px;border-radius:3px;transition:all 0.2s var(--ease)}
.map-preview-btn:hover{background:var(--llc);color:var(--ll-on)}
.map-hint{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--onvv);background:rgba(22,19,16,0.7);backdrop-filter:blur(10px);padding:8px 20px;border-radius:20px;z-index:40;pointer-events:none}

/* ═══ Responsive ═══ */
@media(max-width:768px){
  nav{padding:14px 20px;gap:14px}
  .nav-links{display:none}
  .content-wrap,.story-wrap{padding:80px 16px 60px}
  .wide-wrap{padding:80px 16px 60px}
  .home-title{font-size:clamp(28px,8vw,42px)}
  .ledger{flex-wrap:wrap;gap:12px 0}
  .ledger-item{flex:1 1 33%;min-width:80px;border-right:none}
  .map-preview{width:100%;height:auto;max-height:50vh;bottom:0;top:auto;right:0;border-left:none;border-top:2px solid var(--ll);transform:translateY(100%)}
  .map-preview.open{transform:translateY(0)}
  .story-body{font-size:16px}
  .data-table{font-size:12px}
}