:root,[data-theme=light]{--bg-primary:#f5efe0;--bg-secondary:#e8daba;--bg-tertiary:#d4c9a8;--bg-code:#ede6d4;--bg-card:#faf6ec;--text-primary:#2c1810;--text-secondary:#6b5744;--text-muted:#9a8b78;--border:#c8b99a;--border-subtle:#e0d5be;--accent:#b8860b;--accent-hover:#d4a017;--accent-bg:#b8860b14;--shadow-sm:0 1px 2px #2c181014;--shadow-md:0 4px 12px #2c18101f;--shadow-lg:0 8px 24px #2c181029;--glass-bg:#f5efe0d9;--glass-border:#b8860b26;--glass-blur:16px;--sidebar-width:280px;--header-height:60px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--easing:cubic-bezier(.16, 1, .3, 1);--shelf-wood:#5c3a1e;--shelf-dark:#3d2008;--shelf-highlight:#7a5230;--gold:#b8860b;--gold-bright:#d4a017;--gold-dim:#8a6508}[data-theme=dark]{--bg-primary:#0f0b07;--bg-secondary:#1a1208;--bg-tertiary:#251c0e;--bg-code:#1a1408;--bg-card:#1e1610;--text-primary:#f5efe0;--text-secondary:#b8a88e;--text-muted:#6b5744;--border:#3d2c18;--border-subtle:#2a1e10;--accent:#d4a017;--accent-hover:#e8b830;--accent-bg:#d4a0171a;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 24px #0009;--glass-bg:#0f0b07e6;--glass-border:#b8860b26;--glass-blur:20px;--shelf-wood:#5c3a1e;--shelf-dark:#3d2008;--shelf-highlight:#7a5230;--gold:#b8860b;--gold-bright:#d4a017;--gold-dim:#8a6508}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);transition:background .5s var(--easing), color .3s var(--easing);word-break:keep-all;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;line-height:1.7}body:after{content:"";pointer-events:none;z-index:9999;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");position:fixed;inset:0}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-header{z-index:100;height:var(--header-height);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border-bottom:1px solid var(--glass-border);transition:background .5s var(--easing);justify-content:space-between;align-items:center;padding:0 20px;display:flex;position:sticky;top:0}.library-title{letter-spacing:.04em;font-family:Playfair Display,Georgia,serif}.library-subtitle{color:var(--text-muted);margin-left:8px;font-size:.8em;font-style:italic;font-weight:400}.header-left,.header-right{align-items:center;gap:12px;display:flex}.site-title{letter-spacing:-.02em;white-space:nowrap;font-size:1.05rem;font-weight:600}.menu-btn{color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px;display:none}.app-body{flex:1;display:flex}.app-sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);height:calc(100vh - var(--header-height));top:var(--header-height);transition:background .5s var(--easing);padding:16px 0;position:sticky;overflow-y:auto}.app-content{flex:1;min-width:0;max-width:900px;margin:0 auto;padding:32px 40px}.app-content.full-width{max-width:1000px}.sidebar-nav{padding:0 8px}.sidebar-group{margin-bottom:4px}.sidebar-category{width:100%;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.8rem;font-weight:600;display:flex;position:relative}.sidebar-category:hover{background:var(--bg-tertiary)}.chevron{font-size:.6rem;transition:transform .2s}.chevron.open{transform:rotate(90deg)}.sidebar-links{counter-reset:none;padding:0 4px;list-style:none}.sidebar-links a{color:var(--text-secondary);border-radius:var(--radius-sm);transition:all .3s var(--easing);text-overflow:ellipsis;white-space:nowrap;padding:7px 12px 7px 20px;font-size:.87rem;text-decoration:none;display:block;overflow:hidden}.sidebar-links a:hover{color:var(--text-primary);background:var(--bg-tertiary)}.sidebar-links a.active{color:var(--accent);background:var(--accent-bg);font-weight:500}.sidebar-links li{animation:fadeInUp .3s var(--easing) both}.sidebar-links li:first-child{animation-delay:0s}.sidebar-links li:nth-child(2){animation-delay:20ms}.sidebar-links li:nth-child(3){animation-delay:40ms}.sidebar-links li:nth-child(4){animation-delay:60ms}.sidebar-links li:nth-child(5){animation-delay:80ms}.sidebar-links li:nth-child(n+6){animation-delay:.1s}.search-wrapper{position:relative}.search-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);width:180px;color:var(--text-primary);transition:all .4s var(--easing);outline:none;padding:7px 14px;font-family:Pretendard,sans-serif;font-size:.87rem}.search-input:focus{border-color:var(--accent);width:260px;box-shadow:0 0 0 3px var(--accent-bg)}.search-results{background:var(--glass-bg);width:340px;max-height:420px;-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;margin-top:6px;list-style:none;position:absolute;top:100%;right:0;overflow-y:auto}.search-results li{cursor:pointer;border-bottom:1px solid var(--border);padding:10px 14px;transition:background .1s}.search-results li:last-child{border-bottom:none}.search-results li.selected,.search-results li:hover{background:var(--accent-bg)}.result-title{font-size:.9rem;font-weight:500}.theme-toggle{border:1px solid var(--border);color:var(--text-primary);cursor:pointer;transition:all .4s var(--easing);background:0 0;border-radius:6px;align-items:center;padding:6px;display:flex}.theme-toggle:hover,.menu-btn:hover{background:var(--bg-tertiary);transform:scale(1.05)}.theme-toggle:active,.copy-btn:active,.menu-btn:active{transform:scale(.95)}.markdown-body h1{letter-spacing:-.03em;word-break:keep-all;text-wrap:balance;background:linear-gradient(135deg, var(--text-primary) 0%, var(--accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;border-bottom:none;margin:48px 0 20px;padding-bottom:14px;font-size:2.2rem;font-weight:700;line-height:1.3;position:relative}.markdown-body h1:after{content:"";background:linear-gradient(90deg, var(--accent), transparent);border-radius:2px;width:60px;height:3px;margin-top:14px;display:block}.markdown-body h2{letter-spacing:-.02em;border-left:3px solid var(--accent);margin:44px 0 14px;padding-left:16px;font-size:1.6rem;font-weight:600;line-height:1.35;position:relative}.markdown-body h3{letter-spacing:-.01em;color:var(--text-secondary);margin:32px 0 10px;font-size:1.3rem;font-weight:600;position:relative}.markdown-body ul{padding-left:20px;list-style:none}.markdown-body ul>li{padding-left:12px;position:relative}.markdown-body ul>li:before{content:"";background:var(--accent);border-radius:50%;width:5px;height:5px;position:absolute;top:11px;left:0}.markdown-body ol{padding-left:20px}.markdown-body ol>li::marker{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:600}.markdown-body li{margin-bottom:4px}.markdown-body hr{background:linear-gradient(90deg, transparent, var(--border), transparent);border:none;height:1px;margin:40px 0}.inline-code{background:var(--accent-bg);border:1px solid var(--border-subtle);color:var(--accent);border-radius:6px;padding:2px 7px;font-family:JetBrains Mono,monospace;font-size:.85em}.md-blockquote{border-left:3px solid var(--accent);background:var(--accent-bg);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-secondary);margin:20px 0;padding:14px 20px;font-style:normal}.markdown-body h1 a,.markdown-body h2 a,.markdown-body h3 a,.markdown-body h4 a{color:inherit;-webkit-text-fill-color:inherit;text-decoration:none}.markdown-body h1 a:hover,.markdown-body h2 a:hover,.markdown-body h3 a:hover,.markdown-body h4 a:hover{text-decoration:none}.markdown-body h1:hover:before,.markdown-body h2:hover:before,.markdown-body h3:hover:before{content:"#";color:var(--accent);opacity:.5;-webkit-text-fill-color:var(--accent);margin-left:-1.2em;font-weight:400;position:absolute}.table-wrapper{margin:20px 0;overflow-x:auto}.markdown-body table{border-collapse:collapse;border-radius:var(--radius-md);border:1px solid var(--border);width:100%;font-size:.9rem;overflow:hidden}.markdown-body th{background:var(--bg-tertiary);text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);border-bottom:2px solid var(--border);padding:12px 16px;font-size:.82rem;font-weight:600}.markdown-body td{border-bottom:1px solid var(--border-subtle);padding:10px 16px}.markdown-body tr:nth-child(2n) td{background:var(--bg-secondary)}.markdown-body tr:hover td{background:var(--accent-bg);transition:background .2s var(--easing)}.code-block{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);box-shadow:var(--shadow-md);transition:box-shadow .3s var(--easing);margin:20px 0;overflow:hidden}.code-block:hover{box-shadow:var(--shadow-lg)}.code-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.code-language{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:600}.copy-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all .3s var(--easing);background:0 0;border-radius:6px;padding:3px 10px;font-size:.72rem}.copy-btn:hover{background:var(--accent-bg);color:var(--accent);border-color:var(--accent)}.md-figure{text-align:center;margin:20px 0}.md-figure img{border-radius:var(--radius-md);border:1px solid var(--border);max-width:100%}.md-figure figcaption{color:var(--text-secondary);margin-top:8px;font-size:.85rem}.ascii-diagram{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow .3s var(--easing);margin:20px 0;overflow-x:auto}.ascii-diagram:hover{box-shadow:var(--shadow-md)}.ascii-diagram pre{color:var(--text-primary);white-space:pre;margin:0;padding:20px;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;line-height:1.6;overflow-x:auto}.admonition{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-sm);transition:box-shadow .3s var(--easing);margin:20px 0;overflow:hidden}.admonition:hover{box-shadow:var(--shadow-md)}.admonition-header{letter-spacing:.02em;align-items:center;gap:8px;padding:10px 16px;font-size:.85rem;font-weight:600;display:flex}.admonition-icon{font-size:1.1rem}.admonition-content{padding:0 16px 14px;font-size:.92rem;line-height:1.7}.admonition-content p:last-child{margin-bottom:0}.admonition-note .admonition-header{color:#60a5fa;background:#3b82f614;border-bottom:1px solid #3b82f61f}.admonition-tip .admonition-header{color:#4ade80;background:#22c55e14;border-bottom:1px solid #22c55e1f}.admonition-warning .admonition-header{color:#fbbf24;background:#f59e0b14;border-bottom:1px solid #f59e0b1f}.admonition-info .admonition-header{color:#a78bfa;background:#8b5cf614;border-bottom:1px solid #8b5cf61f}.admonition-prerequisite .admonition-header{color:#f472b6;background:#ec489914;border-bottom:1px solid #ec48991f}[data-theme=light] .admonition-note .admonition-header{color:#2563eb}[data-theme=light] .admonition-tip .admonition-header{color:#16a34a}[data-theme=light] .admonition-warning .admonition-header{color:#d97706}[data-theme=light] .admonition-info .admonition-header{color:#7c3aed}[data-theme=light] .admonition-prerequisite .admonition-header{color:#db2777}.phase-banner{background:linear-gradient(135deg, var(--accent-bg), transparent);border:1px solid var(--accent);border-left:4px solid var(--accent);border-radius:var(--radius-md);margin:0 0 24px;padding:14px 20px;font-size:.92rem}.phase-banner p{margin:0}.phase-banner strong{color:var(--accent)}.doc-page-wrapper{gap:24px;display:flex;position:relative}.doc-page{flex:1;min-width:0}.toc-floating{width:220px;min-width:220px;top:calc(var(--header-height) + 24px);max-height:calc(100vh - var(--header-height) - 48px);padding:16px 0;display:none;position:sticky;overflow-y:auto}@media (width>=1200px){.toc-floating{display:block}}.toc-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0 0 12px;padding:0 8px;font-size:.75rem;font-weight:600}.toc-list{border-left:1px solid var(--border-subtle);margin:0;padding:0;list-style:none}.toc-item a{color:var(--text-muted);transition:all .3s var(--easing);text-overflow:ellipsis;white-space:nowrap;border-left:2px solid #0000;margin-left:-1px;padding:4px 12px;font-size:.8rem;text-decoration:none;display:block;overflow:hidden}.toc-level-3 a{padding-left:24px;font-size:.76rem}.toc-item a:hover{color:var(--text-primary)}.toc-item a.toc-active{color:var(--accent);border-left-color:var(--accent);font-weight:500}.back-to-top{background:var(--bg-card);border:1px solid var(--border);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow-md);z-index:50;transition:all .4s var(--easing);animation:fadeInUp .3s var(--easing);border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;bottom:32px;right:32px}.back-to-top:hover{box-shadow:var(--shadow-lg);color:var(--accent);border-color:var(--accent);transform:translateY(-2px)}.back-to-top:active{transform:scale(.92)}.scroll-progress{background:var(--accent);z-index:200;border-radius:0 2px 2px 0;height:3px;transition:width .1s linear;position:fixed;top:0;left:0}@keyframes fadeInUp{0%{opacity:0;filter:blur(4px);transform:translateY(1.5rem)}to{opacity:1;filter:blur();transform:translateY(0)}}.animate-in{animation:fadeInUp .6s var(--easing) both}.loading{flex-direction:column;gap:16px;min-height:200px;padding:40px;display:flex}.loading:before,.loading:after{content:"";border-radius:var(--radius-sm);background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-secondary) 50%, var(--bg-tertiary) 75%);background-size:200% 100%;height:20px;animation:1.5s infinite shimmer;display:block}.loading:before{width:60%}.loading:after{width:85%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}[data-rmiz-modal-overlay]{background:var(--bg-primary)!important}.interactive-diagram{border:1px solid var(--border);background:var(--bg-code);border-radius:12px;outline:none;margin:24px 0;overflow:hidden}.interactive-diagram-canvas{justify-content:center;padding:20px;display:flex;position:relative;overflow-x:auto}.interactive-diagram-canvas svg{max-width:100%;height:auto}.interactive-diagram .step-dimmed{opacity:.12;transition:opacity .4s var(--easing)}.interactive-diagram .step-active{opacity:1;filter:drop-shadow(0 0 8px color-mix(in srgb, var(--accent) 50%, transparent));transition:opacity .4s var(--easing), filter .4s var(--easing)}.interactive-diagram .step-completed{opacity:.65;transition:opacity .4s var(--easing)}.interactive-ascii-canvas{padding:20px;overflow-x:auto}.interactive-ascii-pre{white-space:pre;margin:0;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;line-height:1.5}.ascii-line{transition:opacity .4s var(--easing), color .4s var(--easing)}.ascii-line-dimmed{opacity:.12;color:var(--text-muted)}.ascii-line-active{opacity:1;color:var(--accent);text-shadow:0 0 8px color-mix(in srgb, var(--accent) 30%, transparent)}.ascii-line-completed{opacity:.65;color:var(--text-primary)}.excalidraw-step-img{object-fit:contain;opacity:0;max-width:100%;max-height:500px;transition:opacity .5s var(--easing);pointer-events:none;position:absolute}.excalidraw-step-img.active{opacity:1;pointer-events:auto;position:relative}.stepper-controls{border-top:1px solid var(--border);background:var(--bg-secondary);padding:12px 16px}.stepper-progress-track{background:var(--bg-tertiary);cursor:pointer;border-radius:2px;height:4px;margin-bottom:10px;position:relative}.stepper-progress-fill{background:var(--accent);height:100%;transition:width .3s var(--easing);border-radius:2px}.stepper-progress-thumb{background:var(--accent);border:2px solid var(--bg-secondary);width:12px;height:12px;transition:left .3s var(--easing);border-radius:50%;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 0 4px #0003}.stepper-btn{border:1px solid var(--border);color:var(--text-primary);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;padding:6px 8px;transition:all .15s;display:flex}.stepper-btn-play{background:var(--accent);border-color:var(--accent);color:#fff;border-radius:8px;padding:8px 12px}.stepper-speed-btn.active{background:var(--accent);color:#fff}.stepper-label{background:var(--bg-tertiary);color:var(--text-secondary);border-radius:6px;margin-top:8px;padding:8px 12px;font-size:.85rem;line-height:1.4}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (width<=768px){.menu-btn{display:flex}.app-sidebar{left:0;top:var(--header-height);height:calc(100vh - var(--header-height));z-index:50;transition:transform .25s;position:fixed;transform:translate(-100%)}.app-sidebar.open{transform:translate(0)}.sidebar-overlay{inset:0;top:var(--header-height);z-index:40;background:#0006;position:fixed}.app-content{padding:20px 16px}.search-input{width:140px}.search-input:focus{width:180px}.search-results{width:calc(100vw - 32px);right:-60px}.stepper-buttons{flex-wrap:wrap;gap:8px}.stepper-speed{order:3;justify-content:center;width:100%}.stepper-counter{order:2}.stepper-nav{order:1}}.lr{width:100%;max-width:1400px;image-rendering:pixelated;position:fixed;top:0;bottom:0;left:50%;overflow:hidden;transform:translate(-50%)}html{background:#0a0704}.lr-floor{image-rendering:pixelated;background:url(/developer-open-book/sprites/tile-floor.png) 0 0/64px 64px;position:absolute;inset:6vmin 6vmin 5vmin}.lr-wall{image-rendering:pixelated;z-index:1;background:url(/developer-open-book/sprites/tile-wall.png) 0 0/64px 64px;position:absolute}.lr-wall-t{height:6vmin;top:0;left:0;right:0}.lr-wall-b{height:5vmin;bottom:0;left:0;right:0}.lr-wall-l{background:linear-gradient(#00000026 0%,#0000 50%,#00000026 100%),url(/developer-open-book/sprites/tile-wall.png) 0 0/64px 64px;width:6vmin;top:0;bottom:0;left:0}.lr-wall-r{background:linear-gradient(#00000026 0%,#0000 50%,#00000026 100%),url(/developer-open-book/sprites/tile-wall.png) 0 0/64px 64px;width:6vmin;top:0;bottom:0;right:0}.lr-shelf-wrap{z-index:5;flex-direction:column;align-items:center;display:flex;position:absolute}.lr-shelf-top-left{width:20%;top:8vmin;left:8%}.lr-shelf-top-center{width:20%;top:8vmin;left:40%}.lr-shelf-top-right{width:20%;top:8vmin;right:8%}.lr-shelf-bot-left{flex-direction:column-reverse;width:20%;bottom:7vmin;left:14%}.lr-shelf-bot-right{flex-direction:column-reverse;width:20%;bottom:7vmin;right:14%}.lr-shelf-left{width:8%;top:28%;left:5vmin}.lr-shelf-right{width:8%;top:28%;right:5vmin}.lr-shelf-img{width:100%;height:auto;image-rendering:pixelated;display:block}.lr-shelf{cursor:pointer;background:linear-gradient(#5c3a1e 0%,#4a2e14 50%,#3d2008 100%);border:none;border-radius:3px;width:100%;padding:0;transition:transform .2s,box-shadow .3s;overflow:hidden;box-shadow:0 4px 12px #0009,inset 0 1px #ffc86414}.lr-shelf:hover{transform:scale(1.03);box-shadow:0 0 20px #d4a0174d,0 6px 20px #0009,inset 0 1px #ffc8641a}.lr-shelf-books{flex-direction:column;width:100%;display:flex}.lr-shelf-bookrow{height:clamp(14px,3.5vmin,28px);image-rendering:pixelated;background-color:#0000;background-image:repeating-linear-gradient(90deg,#6b1c2a 0 6px,#1b4f72 6px 11px,#1a3a2a 11px 16px,#4a1942 16px 20px,#8b2635 20px 27px,#2c5f2d 27px 32px,#935116 32px 36px,#1a5276 36px 42px,#7d3c98 42px 46px,#6b3a2a 46px 52px,#285f5c 52px 57px,#703030 57px 62px,#5c3d6b 62px 67px,#6b4f1a 67px 72px),linear-gradient(#00000026 0%,#0000 30%);background-position:0 0;background-repeat:repeat;background-size:72px 100%,100% 100%;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;gap:1px;padding:2px 3px;display:flex}.lr-shelf-bookrow-short{background-position:12px 0,0 0;height:clamp(10px,2.5vmin,20px)}.lr-shelf-plank{background:linear-gradient(#7a5230 0%,#5c3a1e 40%,#4a2e14 100%);height:clamp(3px,.7vmin,6px);position:relative;box-shadow:0 1px 2px #0000004d}.lr-shelf:before,.lr-shelf:after{content:"";z-index:1;background:linear-gradient(#7a5230,#5c3a1e,#3d2008);width:4px;position:absolute;top:0;bottom:0}.lr-shelf:before{left:0}.lr-shelf:after{right:0}.lr-sign{pointer-events:none;background:linear-gradient(#5c3a1e,#3d2008);border:1px solid #7a523099;border-radius:2px;align-items:center;gap:clamp(2px,.5vmin,6px);margin-top:clamp(3px,.8vmin,8px);padding:clamp(2px,.4vmin,5px) clamp(6px,1.2vmin,14px);display:flex;box-shadow:0 2px 6px #00000080}.lr-shelf-bot-left .lr-sign,.lr-shelf-bot-right .lr-sign{margin-top:0;margin-bottom:clamp(3px,.8vmin,8px)}.lr-sign-icon{font-size:clamp(10px,1.8vmin,18px);line-height:1}.lr-sign-text{color:#d4a017;letter-spacing:.06em;text-shadow:0 1px 3px #000c;font-family:Playfair Display,Georgia,serif;font-size:clamp(8px,1.2vmin,14px);font-weight:600}.lr-sign-count{color:#fff6;margin-left:2px;font-family:monospace;font-size:clamp(7px,.9vmin,11px)}.lr-sign-soon{color:#b8860b59;font-family:Georgia,serif;font-size:clamp(6px,.8vmin,10px);font-style:italic}.lr-sprite{image-rendering:pixelated;pointer-events:none;z-index:3;position:absolute}.lr-sprite.pixel-candle{z-index:4}.lr-obj{image-rendering:pixelated;pointer-events:none;z-index:3;position:absolute}.lr-center{z-index:3;position:absolute;top:44%;left:50%;transform:translate(-50%,-50%)}.lr-chair-l{width:4.5vmin;height:4.5vmin;top:55%;left:40%}.lr-chair-r{width:4.5vmin;height:4.5vmin;top:55%;right:40%}.lr-plant{z-index:4;width:5vmin;height:5vmin}.lr-lamp{z-index:4;width:3.5vmin;height:5vmin}.lr-side-candle{z-index:4;width:3vmin;height:3vmin}.lr-wallmap{z-index:4;width:7vmin;height:7vmin;top:1%;left:8%}.lr-npc-wrap{pointer-events:auto}.lr-npc{image-rendering:pixelated;pointer-events:none;z-index:6;animation:3s ease-in-out infinite npc-idle}.lr-npc-clickable{pointer-events:auto;cursor:pointer}.lr-shelf-empty{opacity:.4;cursor:not-allowed;filter:grayscale(.4)brightness(.7)}.lr-shelf-empty:hover{transform:none;box-shadow:0 4px 12px #0009,inset 0 1px #ffc86414}.lr-deco-shelf{z-index:2;pointer-events:none;background:linear-gradient(#5c3a1e 0%,#3d2008 100%);border-radius:3px;position:absolute;overflow:hidden;box-shadow:0 3px 10px #00000080}.lr-deco-shelf:before{content:"";opacity:.7;background:repeating-linear-gradient(90deg,#6b1c2a 0,#1b4f72 5px,#1a3a2a 10px,#935116 15px,#4a1942 20px,#285f5c 25px,#703030 30px) 0 0/30px 100%;position:absolute;inset:3px}.lr-deco-left{width:7%;height:18%;top:62%;left:5vmin}.lr-deco-right{width:7%;height:18%;top:62%;right:5vmin}.lr-carpet{width:50%;height:55%;image-rendering:pixelated;opacity:.75;z-index:1;background:url(/developer-open-book/sprites/tile-carpet.png) 0 0/48px 48px;border-radius:4px;position:absolute;top:25%;left:25%}.lr-glow{pointer-events:none;z-index:2;background:radial-gradient(#ffb43c1f 0%,#0000 70%);position:absolute}.lr-vignette{pointer-events:none;z-index:10;background:radial-gradient(75% 65% at 50% 45%,#0000 25%,#0a07048c 100%);position:absolute;inset:0}.lr-title{text-align:center;z-index:20;pointer-events:none;position:absolute;top:4px;left:0;right:0}.lr-title h1{color:#d4a017;letter-spacing:.08em;text-shadow:0 2px 16px #000000e6,0 0 40px #b8860b26;font-family:Playfair Display,Georgia,serif;font-size:clamp(1.2rem,2.5vmin,2rem)}.lr-title p{color:#b8860b73;font-family:Georgia,serif;font-size:clamp(.65rem,1.2vmin,.85rem)}.lr-progress{z-index:20;position:absolute;top:12px;right:16px}.speech-bubble-backdrop{z-index:1500;position:fixed;inset:0}.speech-bubble{color:#e8daba;z-index:1600;background:#1a1208;border:2px solid #b8860b66;border-radius:8px;min-width:220px;max-width:320px;padding:14px 16px;font-size:.85rem;line-height:1.6;animation:.25s ease-out bubble-in;position:absolute;bottom:calc(100% + 16px);left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0009}@keyframes bubble-in{0%{opacity:0;transform:translate(-50%)scale(.5)}60%{opacity:1;transform:translate(-50%)scale(1.05)}to{transform:translate(-50%)scale(1)}}.speech-bubble-tail{border-top:8px solid #1a1208;border-left:8px solid #0000;border-right:8px solid #0000;width:0;height:0;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}.speech-bubble-text{margin-bottom:8px;font-family:Georgia,serif}.speech-bubble-options{flex-direction:column;gap:6px;display:flex}.speech-bubble-option{color:#d4a017;cursor:pointer;text-align:left;background:#b8860b1f;border:1px solid #b8860b4d;border-radius:4px;padding:6px 12px;font-family:Georgia,serif;font-size:.8rem;transition:background .2s,border-color .2s}.speech-bubble-option:hover{background:#b8860b40;border-color:#d4a017}.speech-bubble-close{color:#b8860b80;cursor:pointer;background:0 0;border:1px solid #b8860b33;border-radius:4px;margin-top:4px;padding:4px 12px;font-size:.75rem;transition:color .2s}.speech-bubble-close:hover{color:#d4a017}.npc-marker{text-shadow:0 1px 4px #000c;pointer-events:none;z-index:8;font-family:Georgia,serif;font-size:18px;font-weight:900;animation:1s ease-in-out infinite marker-bounce;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.npc-marker-complete{color:#f5c542}.npc-marker-available{color:silver}@keyframes marker-bounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(-6px)}}.world-map-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1200;background:#0a0704d9;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.world-map{background:linear-gradient(#1a1208 0%,#0f0b07 100%);border:1px solid #b8860b40;border-radius:12px;width:600px;max-width:90vw;overflow:hidden;box-shadow:0 24px 64px #0009}.world-map-header{border-bottom:1px solid #b8860b26;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.world-map-header h2{color:#d4a017;letter-spacing:.06em;font-family:Playfair Display,Georgia,serif;font-size:1.1rem}.world-map-close{color:#b8860b80;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:1.5rem}.world-map-close:hover{color:#d4a017}.world-map-grid{height:360px;padding:20px;position:relative}.world-map-room{cursor:pointer;text-align:center;background:#b8860b14;border:1px solid #b8860b33;border-radius:8px;flex-direction:column;align-items:center;gap:4px;width:26%;padding:16px 12px;transition:background .2s,border-color .2s,box-shadow .2s;display:flex;position:absolute}.world-map-room.unlocked:hover{background:#b8860b26;border-color:#d4a017;box-shadow:0 0 20px #b8860b26}.world-map-room.locked{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}.world-map-room.current{border-color:#d4a017;box-shadow:0 0 12px #b8860b33}.world-map-lock{font-size:1.2rem}.world-map-marker{background:#d4a017;border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite marker-pulse}@keyframes marker-pulse{0%,to{opacity:1}50%{opacity:.3}}.world-map-room-name{color:#d4a017;letter-spacing:.04em;font-family:Playfair Display,Georgia,serif;font-size:.9rem}.world-map-room-info{color:#b8860b80;font-size:.7rem}.world-map-path{background:#b8860b26;border-radius:2px;position:absolute}.world-map-path-h{height:3px}.world-map-path-v{width:3px}.sound-toggle{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:4px 8px;font-size:1rem;transition:border-color .2s}.sound-toggle:hover{border-color:var(--accent)}.lr-flash{z-index:15;pointer-events:none;background:#fff;animation:.3s ease-out forwards flash-out;position:absolute;inset:0}@keyframes flash-out{0%{opacity:.4}to{opacity:0}}.streak-pulse{animation:.5s ease-out streak-pulse}@keyframes streak-pulse{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.lr-npc-clickable{animation:3s ease-in-out infinite npc-idle,5s ease-in-out infinite npc-sway}@keyframes npc-sway{0%,to{transform:rotate(0)}50%{transform:rotate(1deg)}}.shelf-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0a0704d9;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.shelf-modal{background:linear-gradient(#1a1208 0%,#0f0b07 100%);border:1px solid #b8860b33;border-radius:12px;min-width:400px;max-width:90vw;max-height:80vh;animation:.4s cubic-bezier(.16,1,.3,1) modalAppear;overflow:hidden;box-shadow:0 24px 64px #0009,0 0 80px #b8860b0d}@keyframes modalAppear{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.shelf-modal-header{border-bottom:1px solid #b8860b1a;align-items:center;gap:12px;padding:20px 24px 12px;display:flex}.shelf-modal-header h2{color:#d4a017;letter-spacing:.06em;flex:1;font-family:Playfair Display,Georgia,serif;font-size:1.3rem}.shelf-modal-count{color:#b8860b80;font-family:Georgia,serif;font-size:.8rem}.shelf-modal-close{color:#b8860b80;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:1.5rem;transition:color .2s,background .2s}.shelf-modal-close:hover{color:#d4a017;background:#b8860b1a}.shelf-modal-books{max-height:60vh;padding:24px;overflow-y:auto}.modal-shelf-unit{margin-bottom:24px}.modal-shelf-unit:last-child{margin-bottom:0}.modal-shelf-row{align-items:flex-end;gap:2px;min-height:180px;padding-bottom:8px;display:flex}.modal-shelf-plank{background:repeating-linear-gradient(90deg,#0000 0 40px,#00000008 40px 41px);border-radius:0 0 3px 3px;height:14px;box-shadow:0 4px 12px #00000080}.modal-book{cursor:pointer;flex-shrink:0;transition:transform .3s cubic-bezier(.16,1,.3,1),margin .3s;animation:.4s cubic-bezier(.16,1,.3,1) both bookAppear}.modal-book:hover{z-index:5;margin:0 4px;transform:translateY(-8px)}.modal-book-spine{width:var(--thickness);height:var(--height);background-image:linear-gradient(90deg,#0000004d 0%,#0000000d 15%,#ffffff0f 35%,#ffffff14 50%,#00000005 65%,#00000026 100%);border-radius:2px 0 0 2px;flex-direction:column;justify-content:center;align-items:center;padding:10px 3px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff1a,inset 0 -1px #0003,2px 2px 6px #0000004d}.modal-book-spine:before,.modal-book-spine:after{content:"";background:linear-gradient(90deg,#0000,#d4a01759,#0000);height:1px;position:absolute;left:15%;right:15%}.modal-book-spine:before{top:8%}.modal-book-spine:after{bottom:8%}.modal-spine-title{writing-mode:vertical-rl;text-orientation:mixed;color:#ffffffe0;max-height:calc(var(--height) - 50px);text-overflow:ellipsis;text-shadow:0 1px 2px #00000080;letter-spacing:.04em;font-family:Georgia,serif;font-size:10px;font-weight:500;line-height:1.3;overflow:hidden}.modal-spine-badge{writing-mode:vertical-rl;color:#fff6;letter-spacing:.1em;margin-top:4px;font-family:monospace;font-size:7px;transform:rotate(180deg)}.book-reader-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;background:#0a0704e0;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.book-reader{background:var(--bg-card,#faf6ec);color:var(--text-primary,#2c1810);border-radius:12px;flex-direction:column;width:90vw;max-width:900px;height:85vh;animation:.4s cubic-bezier(.16,1,.3,1) modalAppear;display:flex;overflow:hidden;box-shadow:0 24px 80px #000000b3}.book-reader-header{border-bottom:1px solid var(--border,#c8b99a);background:var(--bg-secondary,#e8daba);flex-shrink:0;align-items:center;padding:16px 24px;display:flex}.book-reader-title{color:var(--accent,#b8860b);letter-spacing:.03em;flex:1;font-family:Playfair Display,Georgia,serif;font-size:1.1rem}.book-reader-close{color:var(--text-muted,#9a8b78);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:0 8px;font-size:1.8rem;line-height:1;transition:color .2s,background .2s}.book-reader-close:hover{color:var(--accent,#b8860b);background:var(--accent-bg,#b8860b14)}.book-reader-body{flex:1;padding:32px 40px;overflow-y:auto}.book-reader-loading{text-align:center;color:var(--text-muted);padding:60px;font-family:Georgia,serif;font-style:italic}.shelf-modal-empty{text-align:center;color:#b8860b80;padding:48px 24px;font-family:Georgia,serif}.shelf-modal-empty p{margin-top:12px;font-size:1rem}@media (width<=768px){.book-reader{border-radius:8px;width:96vw;height:92vh}.book-reader-body{padding:20px 16px}}.bookshelf-home{min-height:calc(100vh - var(--header-height));background:var(--bg-primary);padding-bottom:40px}.library-banner{text-align:center;padding:48px 20px 24px}.library-banner-title{color:var(--accent);letter-spacing:.06em;text-shadow:0 0 30px #b8860b26;font-family:Playfair Display,Georgia,serif;font-size:2rem;font-weight:700}.library-banner-sub{color:var(--text-muted);letter-spacing:.08em;margin-top:4px;font-family:Georgia,serif;font-size:.9rem;font-style:italic}.shelf-filter{flex-wrap:wrap;justify-content:center;gap:20px;margin-top:20px;display:flex}.shelf-filter button{color:var(--text-muted);cursor:pointer;transition:color .3s var(--easing);letter-spacing:.03em;background:0 0;border:none;padding:4px 0;font-family:Georgia,serif;font-size:.9rem;position:relative}.shelf-filter button:after{content:"";background:var(--accent);width:0;height:1px;transition:width .4s var(--easing);position:absolute;bottom:0;left:0}.shelf-filter button:hover{color:var(--accent)}.shelf-filter button:hover:after,.shelf-filter button.active:after{width:100%}.shelf-filter button.active{color:var(--accent);font-weight:600}.shelf-section{margin-top:8px}.shelf-label{color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;align-items:center;gap:16px;margin-top:40px;margin-bottom:12px;padding:0 60px;font-family:Playfair Display,Georgia,serif;font-size:1rem;font-weight:600;display:flex}.shelf-label:after{content:"";background:linear-gradient(90deg, var(--border) 0%, transparent 80%);flex:1;height:1px}.shelf-row{flex-wrap:wrap;align-items:flex-end;gap:2px;min-height:260px;padding:12px 60px 0;display:flex;position:relative}.shelf-row:after{content:"";background:linear-gradient(180deg, var(--shelf-highlight) 0%, var(--shelf-wood) 30%, var(--shelf-dark) 100%);z-index:2;background-image:repeating-linear-gradient(90deg,#0000 0 40px,#00000008 40px 41px);border-radius:0 0 2px 2px;height:18px;position:absolute;bottom:0;left:40px;right:40px;box-shadow:0 4px 16px #00000080,0 8px 32px #00000040,inset 0 2px 3px #ffc86414}.shelf-row:before{content:"";filter:blur(4px);z-index:0;background:linear-gradient(#0000004d 0%,#0000 100%);height:50px;position:absolute;bottom:18px;left:40px;right:40px}.book{cursor:pointer;transform-style:preserve-3d;transition:transform .5s var(--easing), margin .4s var(--easing), z-index 0s .5s;z-index:1;animation:bookAppear .5s var(--easing) both;flex-shrink:0;position:relative}@keyframes bookAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.book:hover{z-index:10;transition:transform .5s var(--easing), margin .4s var(--easing), z-index 0s 0s;margin:0 8px;transform:rotateY(-28deg)translateZ(24px)translateY(-6px)}.book-spine{width:var(--thickness);height:var(--height);background-image:linear-gradient(90deg,#0000004d 0%,#0000000d 15%,#ffffff0f 35%,#ffffff14 50%,#00000005 65%,#00000026 100%);border-radius:2px 0 0 2px;flex-direction:column;justify-content:center;align-items:center;padding:12px 3px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff1a,inset 0 -1px #0003}.book-spine:before,.book-spine:after{content:"";background:linear-gradient(90deg,#0000,#d4a01766,#0000);height:1px;position:absolute;left:15%;right:15%}.book-spine:before{top:10%}.book-spine:after{bottom:10%}.spine-title{writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.06em;color:#ffffffe0;max-height:calc(var(--height) - 60px);text-overflow:ellipsis;text-shadow:0 1px 2px #0006;font-family:Georgia,serif;font-size:10.5px;font-weight:500;line-height:1.3;overflow:hidden}.spine-badge{writing-mode:vertical-rl;color:#ffffff73;letter-spacing:.1em;margin-top:6px;font-family:monospace;font-size:7.5px;font-weight:500;transform:rotate(180deg)}.book-top{width:var(--thickness);transform-origin:top;background:linear-gradient(#ffffff1f,#00000014);height:10px;position:absolute;top:0;left:0;transform:rotateX(90deg)}.book-cover-peek{width:80px;height:var(--height);background:var(--cover-color,#2a1a0e);transform-origin:100%;border-radius:0 2px 2px 0;flex-direction:column;justify-content:center;align-items:center;padding:16px 8px;display:flex;position:absolute;top:0;right:0;overflow:hidden;transform:rotateY(90deg)}.book-cover-peek:before{content:"";background:linear-gradient(135deg,#ffffff0d 0%,#0000 50%),linear-gradient(#0000 0%,#0000004d 100%);position:absolute;inset:0}.cover-title{color:#ffffffe6;text-align:center;z-index:1;font-family:Playfair Display,Georgia,serif;font-size:11px;font-weight:600;line-height:1.4;position:relative}.cover-category{letter-spacing:.15em;text-transform:uppercase;color:var(--gold,#b8860b);z-index:1;margin-top:8px;font-family:Georgia,serif;font-size:8px;position:relative}.book:after{content:"";z-index:-1;background:radial-gradient(at bottom,#00000080 0%,#0000 70%);height:12px;transition:opacity .3s;position:absolute;bottom:-2px;left:-2px;right:-2px}.book:hover:after{opacity:.3}.library-floor-decor{border-top:1px solid var(--border-subtle);justify-content:center;align-items:center;height:60px;margin-top:40px;display:flex}.library-floor-decor span{letter-spacing:.12em;color:var(--text-muted);text-transform:uppercase;opacity:.5;font-family:Georgia,serif;font-size:.7rem}.doc-page{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:48px 44px;position:relative}.doc-page:before{content:"";border-radius:var(--radius-md);opacity:.02;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}@media (width<=768px){.shelf-row{min-height:200px;padding:12px 20px 0}.shelf-row:after,.shelf-row:before{left:12px;right:12px}.shelf-label{padding:0 20px;font-size:.85rem}.book-cover-peek{display:none}.library-banner-title{font-size:1.4rem}.shelf-filter{gap:12px}}.pixel-diorama{height:224px;image-rendering:pixelated;image-rendering:crisp-edges;border-bottom:1px solid var(--border);position:relative;overflow:hidden}.pixel-floor{height:128px;image-rendering:pixelated;image-rendering:crisp-edges;background:url(/developer-open-book/sprites/tile-floor.png) 0 0/64px 64px;position:absolute;bottom:0;left:0;right:0}.pixel-wall{height:128px;image-rendering:pixelated;image-rendering:crisp-edges;background:url(/developer-open-book/sprites/tile-wall.png) 0 0/64px 64px;position:absolute;top:0;left:0;right:0}.pixel-wall-edge{z-index:1;background:linear-gradient(#00000080 0%,#0000 100%);height:16px;position:absolute;top:128px;left:0;right:0}.pixel-carpet{width:320px;height:96px;image-rendering:pixelated;image-rendering:crisp-edges;background:url(/developer-open-book/sprites/tile-carpet.png) 0 0/64px 64px;border-radius:2px;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.pixel-sprite{image-rendering:pixelated;image-rendering:crisp-edges;pointer-events:none;z-index:3;position:absolute}.pixel-sprite img{image-rendering:pixelated;image-rendering:crisp-edges;display:block}.pixel-npc{z-index:4;pointer-events:none;animation:3s ease-in-out infinite npc-idle;position:absolute}.pixel-npc img{image-rendering:pixelated;image-rendering:crisp-edges;display:block}@keyframes npc-idle{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.pixel-npc:after{content:"";background:radial-gradient(#0006 0%,#0000 70%);border-radius:50%;width:70%;height:4px;position:absolute;bottom:-2px;left:50%;transform:translate(-50%)}.pixel-candle{animation:2s ease-in-out infinite alternate candle-flicker}@keyframes candle-flicker{0%{filter:brightness();transform:scale(1)}25%{filter:brightness(1.15);transform:scale(1.03)}50%{filter:brightness(.95);transform:scale(.97)}75%{filter:brightness(1.1);transform:scale(1.02)}to{filter:brightness(1.05);transform:scale(1)}}.pixel-glow{pointer-events:none;z-index:2;background:radial-gradient(#ffb43c26 0%,#0000 70%);width:80px;height:40px;position:absolute}.pixel-diorama:after{content:"";pointer-events:none;z-index:5;background:linear-gradient(#0a0a0a80 0%,#0000 25% 75%,#0a0a0a99 100%),linear-gradient(90deg,#0a0a0a66 0%,#0000 15% 85%,#0a0a0a66 100%);position:absolute;inset:0}.pixel-diorama-label{letter-spacing:.15em;color:#b8860b4d;text-transform:uppercase;z-index:6;font-family:monospace;font-size:8px;position:absolute;bottom:8px;right:16px}@media (width<=768px){.pixel-diorama{height:160px}.pixel-floor,.pixel-wall{height:96px}.pixel-wall-edge{top:96px}.pixel-carpet{width:200px;height:64px;bottom:8px}}.breadcrumb{color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);white-space:nowrap;align-items:center;gap:.4rem;padding:.5rem 1.2rem;font-size:.82rem;display:flex;overflow-x:auto}.breadcrumb-item{align-items:center;gap:.3rem;display:inline-flex}.breadcrumb-home{color:var(--accent);cursor:pointer;font-size:inherit;background:0 0;border:none;border-radius:4px;align-items:center;gap:.25rem;padding:.15rem .3rem;display:inline-flex}.breadcrumb-home:hover{background:var(--accent-bg)}.breadcrumb-sep{opacity:.4;font-size:.75rem}.breadcrumb-current{color:var(--text-primary);text-overflow:ellipsis;max-width:300px;font-weight:500;overflow:hidden}.book-nav{border-top:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:1rem;margin-top:3rem;padding:1rem 0;display:flex}.book-nav-btn{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;background:0 0;max-width:40%;padding:.5rem 1rem;font-size:.85rem;transition:border-color .2s,color .2s;overflow:hidden}.book-nav-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.book-nav-btn:disabled{opacity:0;cursor:default;pointer-events:none}.book-nav-pos{color:var(--text-muted);flex-shrink:0;font-size:.8rem}.progress-indicator{position:relative}.progress-indicator-btn{border:1px solid var(--border-subtle);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;background:0 0;align-items:center;gap:8px;padding:4px 10px;font-size:.8rem;transition:border-color .2s,background .2s;display:flex}.progress-indicator-btn:hover{border-color:var(--accent);background:var(--accent-bg)}.progress-indicator-books,.progress-indicator-streak{font-variant-numeric:tabular-nums}.progress-panel-overlay{z-index:99;position:fixed;inset:0}.progress-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);width:320px;max-height:480px;box-shadow:var(--shadow-lg);z-index:100;animation:fadeInUp .25s var(--easing);padding:20px;position:absolute;top:calc(100% + 8px);right:0;overflow-y:auto}.progress-tabs{border-bottom:1px solid var(--border-subtle);gap:4px;margin-bottom:14px;padding-bottom:8px;display:flex}.progress-tab{color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;padding:4px 10px;font-size:.8rem;transition:color .2s,background .2s}.progress-tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.progress-tab.active{color:var(--accent);background:var(--accent-bg);font-weight:600}.progress-quest-list{max-height:300px;overflow-y:auto}.progress-quest{border-radius:var(--radius-sm);background:var(--bg-secondary);margin-bottom:6px;padding:8px 10px}.progress-quest.completable{border-left:3px solid #f5c542}.progress-quest.completed{opacity:.6;padding:4px 10px}.progress-quest.available{border-left:3px solid var(--text-muted)}.progress-quest-header{margin-bottom:2px}.progress-quest-title{color:var(--text-primary);font-size:.82rem;font-weight:600}.progress-quest-desc{color:var(--text-muted);font-size:.75rem;line-height:1.4}.progress-quest-hint{color:#f5c542;margin-top:4px;font-size:.72rem;font-style:italic}.progress-quest-empty{text-align:center;color:var(--text-muted);padding:20px;font-size:.85rem}.progress-panel-title{color:var(--text-primary);margin:0 0 16px;font-family:Playfair Display,Georgia,serif;font-size:1rem}.progress-panel-subtitle{color:var(--text-secondary);margin:16px 0 10px;font-size:.85rem}.progress-bar-container{background:var(--bg-tertiary);border-radius:12px;height:24px;position:relative;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent), var(--accent-hover));height:100%;transition:width .5s var(--easing);border-radius:12px;min-width:2px}.progress-bar-label{color:var(--text-primary);mix-blend-mode:difference;filter:invert();justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex;position:absolute;inset:0}.progress-stats{grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;display:grid}.progress-stat{background:var(--bg-secondary);border-radius:var(--radius-sm);flex-direction:column;gap:2px;padding:8px 10px;display:flex}.progress-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.progress-stat-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:.95rem;font-weight:600}.progress-badges{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;display:grid}.progress-badge{border-radius:var(--radius-sm);text-align:center;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;transition:background .2s;display:flex}.progress-badge.earned{background:var(--accent-bg)}.progress-badge.locked{opacity:.35}.progress-badge-icon{justify-content:center;align-items:center;width:32px;height:32px;display:flex}.progress-badge-icon svg{width:32px;height:32px;image-rendering:pixelated}.progress-badge.locked .progress-badge-icon{background:var(--bg-tertiary);border-radius:4px;width:32px;height:32px}.progress-badge-name{color:var(--text-secondary);font-size:.65rem;line-height:1.2}@media (width<=768px){.progress-indicator-btn{gap:4px;padding:4px 6px;font-size:.75rem}.progress-panel{width:calc(100vw - 32px);right:-60px}}.ai-chat-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;background:#0a0704d9;justify-content:center;align-items:center;animation:.25s fadeIn;display:flex;position:fixed;inset:0}.ai-chat{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:100%;max-width:700px;height:80vh;animation:.35s cubic-bezier(.16,1,.3,1) modalAppear;display:flex;overflow:hidden;box-shadow:0 24px 64px #0009,0 0 80px #b8860b0f}.ai-chat-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;align-items:center;gap:12px;padding:16px 20px;display:flex}.ai-chat-avatar{width:48px;height:48px;image-rendering:pixelated;border:2px solid var(--accent);object-fit:cover;border-radius:4px;flex-shrink:0}.ai-chat-npc-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.ai-chat-npc-name{color:var(--accent);white-space:nowrap;text-overflow:ellipsis;font-family:Playfair Display,Georgia,serif;font-size:1.05rem;font-weight:600;overflow:hidden}.ai-chat-npc-role{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.ai-chat-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:1.25rem;line-height:1;transition:color .2s,background .2s}.ai-chat-close:hover{color:var(--accent);background:var(--accent-bg)}.ai-chat-body{scroll-behavior:smooth;flex-direction:column;flex:1;gap:12px;padding:20px;display:flex;overflow-y:auto}.ai-chat-welcome{color:var(--text-muted);text-align:center;flex:1;justify-content:center;align-items:center;padding:40px 20px;font-size:.95rem;font-style:italic;display:flex}.ai-chat-msg{border-radius:var(--radius-sm);word-break:break-word;max-width:85%;padding:10px 14px;font-size:.9rem;line-height:1.6}.ai-chat-msg.user{background:var(--accent-bg);border:1px solid var(--accent);color:var(--text-primary);border-bottom-right-radius:2px;align-self:flex-end}.ai-chat-msg.assistant{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-bottom-left-radius:2px;align-self:flex-start}.ai-chat-msg.assistant .markdown-body{font-size:.9rem}.ai-chat-msg.assistant .markdown-body p:first-child{margin-top:0}.ai-chat-msg.assistant .markdown-body p:last-child{margin-bottom:0}.ai-chat-cursor{color:var(--accent);vertical-align:text-bottom;margin-left:2px;line-height:1;animation:.8s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.ai-chat-thinking{opacity:.6;font-style:italic;animation:1.5s ease-in-out infinite pulse;color:var(--text-muted)!important}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.ai-chat-error{border-radius:var(--radius-sm);color:#e07070;background:#b428281f;border:1px solid #b4282859;align-self:flex-start;max-width:85%;padding:10px 14px;font-size:.88rem;line-height:1.5}.ai-chat-input-area{border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;align-items:flex-end;gap:8px;padding:12px 16px;display:flex}.ai-chat-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);resize:none;outline:none;flex:1;padding:8px 12px;font-family:inherit;font-size:.9rem;line-height:1.5;transition:border-color .2s,box-shadow .2s}.ai-chat-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.ai-chat-input:disabled{opacity:.6;cursor:not-allowed}.ai-chat-input::placeholder{color:var(--text-muted);font-size:.85rem}.ai-chat-send{background:var(--accent);border-radius:var(--radius-sm);color:#0f0b07;cursor:pointer;white-space:nowrap;border:none;align-self:flex-end;height:36px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:background .2s,opacity .2s}.ai-chat-send:hover:not(:disabled){background:var(--accent-hover)}.ai-chat-send:disabled{opacity:.45;cursor:not-allowed}@media (width<=768px){.ai-chat{border-radius:8px;max-width:96vw;height:92vh}.ai-chat-msg{max-width:95%}.ai-chat-npc-role{display:none}}.api-settings{padding-top:4px}.api-settings-field{margin-bottom:12px}.api-settings-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.75rem;display:block}.api-settings-row{gap:6px;display:flex}.api-settings-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);flex:1;padding:6px 10px;font-family:monospace;font-size:.8rem}.api-settings-input:focus{border-color:var(--accent);outline:none}.api-settings-delete{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:4px 8px;font-size:.9rem}.api-settings-models{flex-direction:column;gap:6px;display:flex}.api-settings-model{color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;font-size:.8rem;display:flex}.api-settings-model input{accent-color:var(--accent)}.api-settings-save{border:1px solid var(--accent);background:var(--accent-bg);width:100%;color:var(--accent);border-radius:var(--radius-sm);cursor:pointer;padding:6px;font-size:.8rem;transition:background .2s}.api-settings-save:hover{background:#b8860b26}.speech-bubble-option.locked{opacity:.5;cursor:not-allowed}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--room-bg:#0f0b07;--room-wall:#1a1208;--shelf-wood:#5c3a1e;--shelf-dark:#3d2008;--shelf-highlight:#7a5230;--paper:#f5efe0;--paper-dark:#e8daba;--paper-edge:#d4c9a8;--ink:#2c1810;--ink-light:#6b5744;--ink-faded:#9a8b78;--gold:#b8860b;--gold-bright:#d4a017;--gold-dim:#8a6508;--burgundy:#6b1c2a;--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1)}html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--shelf-wood) var(--room-bg)}body{background:var(--room-bg);color:var(--paper);-webkit-font-smoothing:antialiased;min-height:100dvh;font-family:Lora,Georgia,serif;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:100;background:radial-gradient(90% 50% at 50% -5%,#ffc85012 0%,#0000 65%),radial-gradient(40% 30% at 20% 10%,#ffb43c08 0%,#0000 50%),radial-gradient(40% 30% at 80% 10%,#ffb43c08 0%,#0000 50%);position:fixed;inset:0}body:after{content:"";pointer-events:none;opacity:.04;z-index:101;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:fixed;inset:0}@keyframes shelf-fade-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes book-rise{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=768px){.library-header{padding:14px 20px!important}.library-title{font-size:1.15rem!important}.library-title span{display:none}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.reading-view{z-index:200;opacity:0;pointer-events:none;transition:opacity .6s var(--ease-out-expo);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.reading-view.visible{opacity:1;pointer-events:auto}.reading-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0805eb;position:absolute;inset:0}.open-book.single-page{opacity:0;width:820px;max-width:95vw;height:85vh;max-height:88vh;transition:transform .8s var(--ease-out-expo), opacity .6s var(--ease-out-expo);filter:drop-shadow(0 24px 70px #0009);flex-direction:column;display:flex;position:relative;transform:perspective(1400px)rotateY(-30deg)scale(.4)}.reading-view.visible .open-book.single-page{opacity:1;transform:perspective(1400px)rotateY(0)scale(1)}.book-page.full{background:var(--paper);scroll-behavior:smooth;color:var(--ink);scrollbar-width:thin;scrollbar-color:var(--paper-dark) transparent;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E"),radial-gradient(at 50% 0,#ffffff1a 0%,#0000 60%);background-color:var(--paper);border-radius:4px;flex:1;padding:48px 56px 32px;font-size:15px;line-height:1.85;position:relative;overflow-y:auto;box-shadow:inset 0 0 60px #64461e08,0 4px 24px #0000004d}.book-page.full::-webkit-scrollbar{width:6px}.book-page.full::-webkit-scrollbar-thumb{background:var(--paper-dark);border-radius:3px}.book-page.full::-webkit-scrollbar-thumb:hover{background:var(--ink-faded)}.book-page-header{border-bottom:1px solid #2c181014;margin-bottom:32px;padding-bottom:24px}.book-page-footer{text-align:center;border-top:1px solid #2c181014;margin-top:40px;padding-top:20px}.page-category{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faded);font-family:Crimson Pro,serif;font-size:.75rem}.reading-chapter{letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-family:Playfair Display,serif;font-size:.75rem;font-weight:400}.reading-title{color:var(--ink);letter-spacing:-.01em;font-family:Playfair Display,serif;font-size:1.65rem;font-weight:700;line-height:1.3}.reading-title:after{content:"";background:var(--gold);width:40px;height:2px;margin-top:16px;display:block}.markdown-body{color:var(--ink-light);word-break:keep-all}.markdown-body h1{color:var(--ink);letter-spacing:-.01em;border-bottom:1px solid #2c181014;margin:40px 0 16px;padding-bottom:8px;font-family:Playfair Display,serif;font-size:1.8rem;font-weight:700;line-height:1.3}.markdown-body h2{color:var(--ink);border-left:3px solid var(--gold);margin:36px 0 12px;padding-left:14px;font-family:Playfair Display,serif;font-size:1.4rem;font-weight:600;line-height:1.35}.markdown-body h3{color:var(--ink);margin:28px 0 10px;font-family:Playfair Display,serif;font-size:1.15rem;font-weight:600;line-height:1.35}.markdown-body h4{color:var(--ink);margin:24px 0 8px;font-family:Lora,serif;font-size:1rem;font-weight:600}.markdown-body p{max-width:72ch;margin:0 0 16px;line-height:1.85}.markdown-body a{color:var(--gold);transition:border-color .3s var(--ease-out-expo);border-bottom:1px solid #0000;text-decoration:none}.markdown-body a:hover{border-bottom-color:var(--gold)}.markdown-body ul,.markdown-body ol{margin:0 0 16px;padding-left:24px}.markdown-body li{margin-bottom:6px;line-height:1.7}.markdown-body li::marker{color:var(--gold-dim)}.markdown-body strong{color:var(--ink);font-weight:600}.markdown-body hr{border:none;border-top:1px solid #2c18101a;margin:32px 0}.markdown-body img{border-radius:4px;max-width:100%;margin:16px 0}.inline-code{color:var(--ink);background:#2c181012;border:1px solid #2c18100f;border-radius:3px;padding:1px 6px;font-family:JetBrains Mono,monospace;font-size:.85em}.ascii-diagram{border-left:3px solid var(--gold-dim);background:#1e1a14;border-radius:4px;margin:16px 0;padding:16px 20px;overflow-x:auto}.ascii-diagram pre{color:#d4c9a8;margin:0;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.5}.ascii-diagram code{font-family:inherit}.table-wrapper{border:1px solid #2c181014;border-radius:4px;margin:16px 0;overflow-x:auto}.markdown-body table{border-collapse:collapse;width:100%;font-size:.9em}.markdown-body th{color:var(--ink);text-align:left;letter-spacing:.02em;background:#2c18100a;border-bottom:2px solid #2c181014;padding:10px 14px;font-size:.85em;font-weight:600}.markdown-body td{vertical-align:top;border-bottom:1px solid #2c18100d;padding:8px 14px}.markdown-body tr:hover td{background:#b8860b08}.reading-note{border-left:3px solid var(--gold);background:#b8860b0f;border-radius:0 6px 6px 0;margin:18px 0;padding:14px 18px;font-size:.92em}.reading-note.warning{background:#dc78140f;border-left-color:#d4780a}.reading-note.tip{background:#22a0500f;border-left-color:#22a050}.reading-note-label{color:var(--gold);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;font-family:Crimson Pro,serif;font-size:.85em;font-weight:600}.reading-note.warning .reading-note-label{color:#d4780a}.reading-note.tip .reading-note-label{color:#22a050}.reading-note p{margin:4px 0}.loading-state{height:200px;color:var(--ink-faded);letter-spacing:.06em;flex-direction:column;justify-content:center;align-items:center;gap:16px;font-family:Crimson Pro,serif;display:flex}.loading-spinner{border:2px solid #2c18101a;border-top-color:var(--gold);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.close-book{z-index:10;color:var(--paper-edge);cursor:pointer;letter-spacing:.06em;transition:all .3s var(--ease-out-expo);z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:0 0;border:1px solid #ffffff26;border-radius:20px;padding:6px 18px;font-family:Crimson Pro,serif;font-size:.85rem;position:absolute;top:12px;right:12px}.close-book:hover{border-color:var(--gold-dim);color:var(--gold);background:#ffffff14}.close-book:focus-visible{outline-offset:2px;border-color:var(--gold-dim);color:var(--gold);background:#ffffff14;outline:2px solid #d4a017}@media (width<=900px){.open-book.single-page{width:98vw;height:92vh}.book-page.full{padding:32px 24px 24px;font-size:14px}}@media (width<=768px){.reading-title{font-size:1.3rem}.close-book{padding:8px;font-size:.8rem;top:8px;right:8px}.book-page.full{padding:24px 16px 20px}.reading-content{padding:32px 20px}.reading-scroll{max-height:calc(100vh - 120px)}.markdown-body h1{font-size:1.4rem}.markdown-body h2{font-size:1.2rem}}.interactive-diagram{background:#1a1610;border:1px solid #8a65084d;border-radius:8px;outline:none;margin:24px 0;overflow:hidden}.interactive-diagram:focus-within{border-color:#8a6508;box-shadow:0 0 0 2px #8a650833}.interactive-excalidraw-canvas{justify-content:center;align-items:center;min-height:300px;padding:16px;display:flex;position:relative;overflow:hidden}.excalidraw-step-img{object-fit:contain;opacity:0;pointer-events:none;max-width:100%;max-height:500px;transition:opacity .5s,transform .4s;position:absolute;transform:translate(8px)}.excalidraw-step-img.active{opacity:1;pointer-events:auto;position:relative;transform:translate(0)}.stepper-controls{background:#1e1a14;border-top:1px solid #8a65084d;padding:12px 16px}.stepper-progress-track{cursor:pointer;-webkit-user-select:none;user-select:none;background:#2a2520;border-radius:2px;height:4px;margin-bottom:10px;position:relative}.stepper-progress-fill{background:#8a6508;border-radius:2px;height:100%;transition:width .3s}.stepper-progress-thumb{background:#8a6508;border:2px solid #1e1a14;border-radius:50%;width:12px;height:12px;transition:left .3s;position:absolute;top:50%;transform:translate(-50%,-50%)}.stepper-buttons{justify-content:space-between;align-items:center;gap:12px;display:flex}.stepper-nav{align-items:center;gap:4px;display:flex}.stepper-btn{color:#c4b78a;cursor:pointer;background:0 0;border:1px solid #8a650866;border-radius:6px;justify-content:center;align-items:center;padding:6px 8px;transition:all .15s;display:flex}.stepper-btn:hover:not(:disabled){background:#8a650826;border-color:#8a6508}.stepper-btn:disabled{opacity:.3;cursor:not-allowed}.stepper-btn:focus-visible{outline-offset:2px;outline:2px solid #d4a017}.stepper-progress-track:focus-visible{outline-offset:2px;border-radius:2px;outline:2px solid #d4a017}.stepper-btn-play{color:#1e1a14;background:#8a6508;border-color:#8a6508;border-radius:8px;padding:8px 12px}.stepper-btn-play:hover{background:#a07a0a!important;border-color:#a07a0a!important}.stepper-counter{color:#b8a070;font-variant-numeric:tabular-nums;text-align:center;min-width:80px;font-size:.8rem}.stepper-speed{background:#2a2520;border-radius:6px;gap:2px;padding:2px;display:flex}.stepper-speed-btn{color:#6a5a3a;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:3px 8px;font-size:.7rem;transition:all .15s}.stepper-speed-btn:hover{color:#c4b78a}.stepper-speed-btn.active{color:#1e1a14;background:#8a6508}.stepper-label{color:#8a7a5a;background:#2a2520;border-radius:6px;margin-top:8px;padding:8px 12px;font-size:.85rem;line-height:1.4}.stepper-label-num{color:#1e1a14;background:#8a6508;border-radius:4px;margin-right:8px;padding:1px 8px;font-size:.75rem;font-weight:600;display:inline-block}.diagram-fullscreen-btn{color:#c4b78a;cursor:pointer;z-index:5;background:#1e1a14b3;border:1px solid #8a65084d;border-radius:4px;padding:4px 8px;font-size:1rem;transition:all .15s;position:absolute;top:8px;right:8px}.diagram-fullscreen-btn:hover{background:#8a65084d;border-color:#8a6508}.interactive-diagram:fullscreen{background:#0f0b07}.interactive-diagram:fullscreen .interactive-excalidraw-canvas{min-height:calc(100vh - 120px)}.interactive-diagram:fullscreen .excalidraw-step-img{max-height:calc(100vh - 160px)}@media (width<=768px){.stepper-buttons{flex-wrap:wrap;gap:8px}.stepper-speed{order:3;justify-content:center;width:100%}.stepper-counter{order:2}.stepper-nav{order:1}}@media (width<=480px){.stepper-buttons{flex-direction:column;gap:8px}.stepper-nav{justify-content:center;width:100%}.stepper-counter{text-align:center}.stepper-speed{justify-content:center;width:100%}}.reading-nav-bar{background:var(--paper-dark,#2a2318);border-top:1px solid #8a650840;border-radius:0 0 4px 4px;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 20px;display:flex}.reading-nav-btn{color:#c4b78a;cursor:pointer;background:0 0;border:1px solid #8a65084d;border-radius:6px;align-items:center;gap:6px;max-width:40%;padding:8px 14px;font-family:inherit;font-size:.82rem;transition:all .2s;display:flex}.reading-nav-btn:hover{color:#e8d5a0;background:#8a650826;border-color:#b8860b}.reading-nav-btn:focus-visible{outline-offset:2px;outline:2px solid #d4a017}.reading-nav-arrow{flex-shrink:0;font-size:1.1rem}.reading-nav-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.reading-nav-btn.next .reading-nav-label{text-align:right}.reading-nav-spacer{flex:1}.reading-nav-indicator{color:#c4b78a80;font-variant:small-caps;letter-spacing:.05em;flex-shrink:0;font-size:.75rem}@media (width<=768px){.reading-nav-bar{padding:8px 12px}.reading-nav-btn{max-width:42%;padding:6px 10px;font-size:.75rem}.reading-nav-indicator{display:none}}
