:root{--paper:#fbfbfa;--paper-2:#f3f3f1;--ink:#1a1a18;--ink-soft:#3d3d3a;--muted:#6e6e69;--line:#d9d9d4;--line-strong:#b9b9b3;--accent:#3a5a78;--accent-soft:#eef2f6;--map-path:#b9a06a;--map-not-taken:#8a9bb0;--sans:ui-sans-serif, system-ui, -apple-system, "Segoe UI", Helvetica, sans-serif;--mono:ui-monospace, "SF Mono", "JetBrains Mono", "Menlo", monospace;--s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s7:48px;--radius:10px;--radius-sm:6px;--shadow:0 1px 2px #1414120d, 0 2px 8px #1414120a;--shadow-lift:0 2px 4px #14141212, 0 8px 20px #14141214;--ease:cubic-bezier(.2, .6, .2, 1)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--sans);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;line-height:1.55}#root{max-width:920px;padding:var(--s7) var(--s5) 140px;margin:0 auto}h1{letter-spacing:-.02em;margin:0 0 var(--s3);font-size:1.9rem;font-weight:650;line-height:1.15}h3{letter-spacing:-.01em;margin:0 0 var(--s3);font-size:1.05rem;font-weight:600}p{margin:0 0 var(--s3);color:var(--ink-soft)}em{color:var(--muted);font-style:italic}.meta{font-family:var(--mono);color:var(--muted);letter-spacing:-.01em;font-size:.8rem}.screen-intro{color:var(--muted);margin-bottom:var(--s6)}button{font:inherit;color:var(--ink);border:1px solid var(--line-strong);border-radius:var(--radius-sm);padding:var(--s2) var(--s4);cursor:pointer;transition:border-color .15s var(--ease), background .15s var(--ease), box-shadow .15s var(--ease), transform 80ms var(--ease);background:#fff}button:hover{border-color:var(--ink-soft)}button:active{transform:translateY(1px)}button:disabled{color:var(--line-strong);border-color:var(--line);cursor:not-allowed}:where(button,a,[tabindex]):focus-visible{outline:2px solid var(--accent);outline-offset:2px}.link-btn{padding:var(--s1) 0;color:var(--muted);text-underline-offset:3px;background:0 0;border:none;text-decoration:underline}.link-btn:hover{color:var(--ink);border:none}.card-grid{gap:var(--s4);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));margin:0;padding:0;list-style:none;display:grid}.card-grid>li{display:flex}.card{align-items:flex-start;gap:var(--s2);text-align:left;width:100%;padding:var(--s4);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;flex-direction:column;display:flex}.card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-lift);transform:translateY(-2px)}.card:active{transform:translateY(0)}.card-title{letter-spacing:-.01em;font-size:1.05rem;font-weight:600;line-height:1.2}.card-edge{color:var(--muted);font-size:.9rem;font-style:italic}.card-count{font-family:var(--mono);color:var(--accent);background:var(--accent-soft);padding:2px var(--s2);border-radius:999px;font-size:.75rem}.mode-grid{gap:var(--s4);margin:var(--s6) 0 var(--s5);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.mode-card{align-items:flex-start;gap:var(--s2);padding:var(--s5);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;flex-direction:column;font-size:1.05rem;font-weight:600}.mode-card:hover{border-color:var(--accent);box-shadow:var(--shadow-lift);transform:translateY(-2px)}.pick-list{margin:0 0 var(--s5);gap:var(--s2);flex-direction:column;padding:0;list-style:none;display:flex}.pick-list>li{display:flex}.pick-row{text-align:left;align-items:baseline;gap:var(--s3);width:100%;padding:var(--s3) var(--s4);border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;flex-wrap:wrap;display:flex}.pick-row:hover{border-color:var(--line-strong);background:var(--paper-2)}.route-path{font-family:var(--mono);color:var(--ink-soft);font-size:.78rem}.journey{animation:fade-in .25s var(--ease);min-height:calc(100vh - var(--s7) - 140px);gap:var(--s4);flex-direction:column;display:flex}.node-card{min-height:0;padding:var(--s5);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;flex-direction:column;flex:1;display:flex}.node-card-head{padding-top:var(--s5);position:relative}.node-type{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:.72rem;position:absolute;top:0;right:0}.narration{border-left:2px solid var(--accent);padding:var(--s2) 0 var(--s2) var(--s4);color:var(--ink-soft);margin:0}.narration em{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:var(--s1);font-size:.72rem;font-style:normal;display:block}.node-image{min-height:180px;margin:var(--s5) 0;background:var(--paper-2);border:1px dashed var(--line-strong);border-radius:var(--radius-sm);flex:1;justify-content:center;align-items:center;display:flex}.node-image-label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--line-strong);font-size:.72rem}.node-card-foot{margin-top:auto}.node-year{margin:0 0 var(--s1);letter-spacing:-.02em;color:var(--ink);font-size:2.6rem;font-weight:650;line-height:1}.node-era{font-family:var(--mono);letter-spacing:.04em;color:var(--muted);font-size:.9rem;font-weight:500}.node-title{margin:0 0 var(--s2)}.node-desc{color:var(--muted);margin:0;font-style:italic}.swipe-hint{text-align:center;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0;font-size:.72rem}.step-controls{gap:var(--s3);display:flex}.back-btn{padding:var(--s2) var(--s4);flex:none}.next-btn{background:var(--accent);color:#fff;border-color:var(--accent);flex:1;font-weight:600}.next-btn:hover{border-color:var(--accent);filter:brightness(1.08)}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.bottom-bar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--line);background:#fbfbfaeb;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #1414120a}.bottom-bar-inner{max-width:920px;padding:var(--s3) var(--s5);align-items:center;gap:var(--s4);margin:0 auto;display:flex}.bottom-step{font-family:var(--mono);color:var(--muted);white-space:nowrap;flex:none;font-size:.75rem}.dots{flex:1;align-items:center;gap:9px;min-width:0;padding:3px 4px 3px 0;display:inline-flex;overflow:hidden}.bottom-bar-inner>button{flex:none}.dots-overflow{font-family:var(--mono);color:var(--muted);background:var(--paper-2);border:1px solid var(--line);border-radius:999px;flex:none;margin-right:2px;padding:1px 6px;font-size:.68rem}.dot{background:var(--line-strong);width:9px;height:9px;transition:background .15s var(--ease), border-color .15s var(--ease), transform .15s var(--ease);border:1.5px solid #0000;border-radius:999px;flex:none}.dot.is-decision{background:var(--accent);border-radius:2px;transform:rotate(45deg)}.dot.is-terminal{border-color:var(--line-strong);background:0 0;border-radius:2px}.dot.is-ahead{border-color:var(--line-strong);background:0 0}.dot.is-ahead.is-decision{border-color:var(--accent);background:0 0}.dot.is-current{border-color:var(--accent);background:0 0;border-width:2px;width:13px;height:13px}.dot.is-current.is-decision{transform:rotate(45deg)}.minimap{max-width:920px;padding:var(--s4) var(--s5);gap:var(--s3);border-bottom:1px solid var(--line);background:var(--paper-2);flex-direction:column;height:70vh;margin:0 auto;display:flex}.minimap-head{justify-content:space-between;align-items:baseline;display:flex}.minimap-title{margin:0}.minimap-count{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:.8rem}.minimap-svg{flex:1;width:100%;min-height:0}.map-edge{stroke-width:.8px;stroke-linecap:round}.map-edge.is-path{stroke:var(--map-path)}.map-edge.is-not-taken{stroke:var(--map-not-taken);stroke-dasharray:2 2}.map-node-dot{r:1.6;fill:var(--paper);stroke:var(--line-strong);stroke-width:.7px}.map-node.is-path .map-node-dot{fill:var(--map-path);stroke:var(--map-path)}.map-node.is-not-taken .map-node-dot{fill:none;stroke:var(--map-not-taken);stroke-dasharray:1.2 1}.map-node.is-current .map-node-dot{r:2.4;fill:var(--paper);stroke:var(--accent);stroke-width:1.1px}.map-node-label{font-family:var(--mono);fill:var(--muted);font-size:2.6px}.map-node.is-current .map-node-label{fill:var(--ink)}.minimap-legend{gap:var(--s4);font-family:var(--mono);color:var(--ink-soft);flex-wrap:wrap;font-size:.72rem;display:flex}.legend-item{align-items:center;gap:var(--s2);display:inline-flex}.legend-swatch{width:18px;height:0;display:inline-block}.legend-swatch.is-path{border-top:2px solid var(--map-path)}.legend-swatch.is-not-taken{border-top:2px dashed var(--map-not-taken)}.legend-swatch.is-here{border:2px solid var(--accent);border-radius:999px;width:11px;height:11px}
