*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #faf6ee;--color-bg-alt: #f0e8d8;--color-surface: #fff8ee;--color-border: #d6c9a8;--color-text: #2c1810;--color-text-muted: #6b5a47;--color-accent: #b8860b;--color-accent-hover: #9a7209;--color-heading: #3e2c1a;--color-link: #8b6914;--color-link-hover: #6b5010;--font-heading: Georgia, "Times New Roman", serif;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--radius: 6px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--shadow-sm: 0 1px 3px rgba(44, 24, 16, .08);--shadow-md: 0 2px 8px rgba(44, 24, 16, .1);--max-width: 860px}html{font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);min-height:100vh}h1,h2,h3,h4{font-family:var(--font-heading);color:var(--color-heading);line-height:1.3}h1{font-size:2rem;margin-bottom:var(--space-md)}h2{font-size:1.5rem;margin-bottom:var(--space-sm)}h3{font-size:1.2rem;margin-bottom:var(--space-sm)}a{color:var(--color-link);text-decoration:none}a:hover{color:var(--color-link-hover);text-decoration:underline}img{max-width:100%;height:auto;display:block}p{margin-bottom:var(--space-md)}p:last-child{margin-bottom:0}.music-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9999;display:flex;flex-direction:column;align-items:center;gap:.25rem;pointer-events:none;animation:toast-fade 2s ease forwards}.music-toast-title{font-family:var(--font-heading);font-size:clamp(1.8rem,5vw,2.5rem);font-weight:700;color:var(--color-heading)}.music-toast-artist{font-size:clamp(1rem,2.5vw,1.25rem);color:var(--color-text-muted)}@keyframes toast-fade{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}15%{opacity:1;transform:translate(-50%,-50%) scale(1)}70%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1)}}.music-player{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1000;display:flex;flex-direction:column;align-items:center;gap:.5rem}.music-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--color-border);background:color-mix(in srgb,var(--color-surface) 90%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s,border-color .2s,background .2s;position:relative}.music-btn:hover{color:var(--color-accent);border-color:var(--color-accent);background:color-mix(in srgb,var(--color-surface) 95%,transparent)}.music-btn.playing{border-color:var(--color-accent);color:var(--color-accent);box-shadow:0 0 12px #b8860b4d}.music-volume{opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .2s,transform .2s,visibility .2s;padding:.75rem .5rem;background:color-mix(in srgb,var(--color-surface) 90%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius);display:flex;justify-content:center}.music-player:hover .music-volume,.music-volume.visible{opacity:1;visibility:visible;transform:translateY(0)}.volume-slider{-webkit-appearance:none;appearance:none;writing-mode:vertical-lr;direction:rtl;width:4px;height:100px;background:var(--color-border);border-radius:2px;outline:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-accent);border:none}.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--color-accent);border:none}.music-eq{display:flex;align-items:center;gap:3px;height:18px}.music-eq span{width:3px;height:100%;background:var(--color-accent);border-radius:1.5px;transform-origin:bottom;transform:scaleY(.15);transition:transform .08s linear}@media(max-width:640px){.music-player{bottom:1rem;right:1rem}.music-btn{width:40px;height:40px}}.site-nav{background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:10}.nav-inner{max-width:var(--max-width);margin:0 auto;padding:var(--space-sm) var(--space-md);display:flex;align-items:center;justify-content:space-between}.nav-brand{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--color-heading);display:flex;align-items:center;gap:.5rem}.nav-logo{height:28px;width:28px;border-radius:50%}.nav-brand:hover{text-decoration:none;color:var(--color-accent)}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:var(--space-xs);flex-direction:column;gap:4px}.nav-toggle-bar{display:block;width:22px;height:2px;background:var(--color-text);border-radius:1px}.nav-links{list-style:none;display:flex;gap:var(--space-lg)}.nav-links a{font-size:.9rem;color:var(--color-text-muted);padding:var(--space-xs) 0}.nav-links a:hover,.nav-links a.active{color:var(--color-accent);text-decoration:none}.nav-links a.active{border-bottom:2px solid var(--color-accent)}@media(max-width:640px){.nav-toggle{display:flex}.nav-links{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--space-md);gap:var(--space-sm)}.nav-links--open{display:flex}}.site-wrapper{display:flex;flex-direction:column;min-height:100vh}.site-main{max-width:var(--max-width);margin:0 auto;padding:var(--space-2xl) var(--space-md);flex:1;width:100%;box-sizing:border-box}.site-footer{border-top:1px solid var(--color-border);background:var(--color-bg-alt);margin-top:auto}.footer-inner{max-width:var(--max-width);margin:0 auto;padding:6px var(--space-md);display:flex;align-items:center;justify-content:space-between}.footer-text{text-align:center;flex:1}.footer-spacer{visibility:hidden;padding:6px 16px;font-size:.8rem}.footer-text p{margin:0;line-height:1.4}.footer-credit{font-size:.8rem;color:var(--color-text-muted)}.footer-tagline{font-size:.75rem;color:var(--color-border)}.footer-mode-btn{font-size:.8rem;font-weight:600;padding:6px 16px;background:var(--color-accent);color:var(--color-surface);border:none;border-radius:var(--radius);text-decoration:none;white-space:nowrap;cursor:pointer}.footer-mode-btn:hover{background:var(--color-accent-hover)}.hero{text-align:center;padding:var(--space-xl) 0 var(--space-2xl);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-2xl)}.hero h1{font-size:2.4rem;color:var(--color-accent)}.hero-sub{font-size:1.05rem;color:var(--color-text-muted);max-width:520px;margin:0 auto}.home-intro,.home-chapters{margin-bottom:var(--space-2xl)}.chapter-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-md);margin-top:var(--space-md)}.chapter-card a{display:block;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);color:var(--color-text);transition:border-color .15s ease}.chapter-card a:hover{border-color:var(--color-accent);text-decoration:none}.chapter-num{display:block;font-size:.8rem;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.chapter-title{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--color-heading)}.explore-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-md);margin-top:var(--space-md)}.explore-card{display:block;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-lg);color:var(--color-text);transition:border-color .15s ease}.explore-card:hover{border-color:var(--color-accent);text-decoration:none}.explore-card h3{margin-bottom:var(--space-xs);color:var(--color-accent)}.explore-card p{font-size:.9rem;color:var(--color-text-muted)}.lore-list{list-style:none;margin-top:var(--space-lg)}.lore-list-item{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.lore-list-item a{font-size:1.05rem}.lore-preview{font-size:.88rem;color:var(--color-text-muted);margin-top:var(--space-xs)}.page-lore-chapter .chapter-label{font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent);margin-bottom:var(--space-xs)}.chapter-body{margin-top:var(--space-lg);line-height:1.75}.chapter-body p{margin-bottom:var(--space-lg);text-indent:1.5em}.chapter-nav{display:flex;justify-content:space-between;margin-top:var(--space-2xl);padding-top:var(--space-lg);border-top:1px solid var(--color-border);gap:var(--space-md)}.chapter-nav-link{font-size:.9rem}.character-list{list-style:none;margin-top:var(--space-sm)}.character-entry{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.character-entry:first-child{padding-top:0}.character-entry h4{font-size:1.15rem;margin:0}.character-entry h4 a{color:var(--color-accent);text-decoration:underline}.character-entry h4 a:hover{color:var(--color-accent-hover)}.character-role{font-size:.88rem;color:var(--color-accent);font-style:italic;margin-bottom:var(--space-sm)}.world-list{margin-top:var(--space-sm);margin-bottom:var(--space-lg)}.world-entry{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.world-entry dt{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--color-heading)}.world-entry dt a{color:var(--color-accent);text-decoration:underline}.world-entry dt a:hover{color:var(--color-accent-hover)}.org-full{font-weight:400;font-size:.9rem;color:var(--color-text-muted)}.world-entry dd{margin-top:var(--space-xs);color:var(--color-text-muted);font-size:.95rem;line-height:1.5}.page-about section{margin-bottom:var(--space-2xl)}.about-credits{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-lg)}.credits-list{margin-top:var(--space-md)}.credit-entry{display:flex;gap:var(--space-lg);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);align-items:baseline}.credit-entry:last-child{border-bottom:none}.credit-entry dt{font-family:var(--font-heading);font-weight:700;min-width:180px;flex-shrink:0;font-size:1rem;color:var(--color-heading)}.credit-entry dd{font-size:.95rem;color:var(--color-text-muted)}.archive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-md);margin-top:var(--space-lg)}.archive-card{display:block;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-lg);color:var(--color-text);transition:border-color .15s ease}.archive-card:hover{border-color:var(--color-accent);text-decoration:none}.archive-card h2{font-size:1.2rem;margin-bottom:var(--space-xs);color:var(--color-text)}.archive-title-prefix,.archive-title-topic{color:var(--color-text)}.archive-card p{font-size:.9rem;color:var(--color-text-muted)}.page-lore>section{margin-top:var(--space-2xl)}.page-lore>section:first-of-type{margin-top:var(--space-lg)}.page-lore h2{margin-bottom:var(--space-sm)}.page-lore h3{margin-top:var(--space-md);margin-bottom:var(--space-xs)}.lore-section{margin-top:var(--space-lg)}.lore-section h3{font-size:1.15rem;margin-bottom:var(--space-xs)}.lore-section h3 a{color:var(--color-accent);text-decoration:none}.lore-section h3 a:hover{text-decoration:underline}.lore-facts{list-style:disc;padding-left:1.5em;margin:0}.lore-facts li{margin-bottom:.3em;line-height:1.5}.song-section{margin-top:var(--space-2xl);margin-bottom:0}.song-credit{font-size:.9rem;color:var(--color-text-muted);font-style:italic;margin-bottom:var(--space-md)}.song-lyrics{white-space:pre-wrap;font-family:var(--font-body);font-size:.95rem;line-height:1.7;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-lg);margin-bottom:0}.about-help{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-lg)}.help-list{list-style:none;margin-top:var(--space-md)}.help-list li{padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);line-height:1.6}.help-list li:last-child{border-bottom:none}.problem-context{margin-bottom:var(--space-lg);line-height:1.7;color:var(--color-text-muted)}.problem-list{list-style:decimal;padding-left:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.problem-list li{line-height:1.6}.slides-wrapper{margin:var(--space-lg) 0;position:relative;width:100%;max-width:960px;aspect-ratio:960 / 569;background:var(--color-bg-alt)}.slides-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--color-text-muted);font-size:.95rem}.slides-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:1px solid var(--color-border);border-radius:var(--radius)}.page-profile{max-width:720px}.page-profile .back-link{display:inline-block;font-size:.88rem;color:var(--color-text-muted);margin-bottom:var(--space-md)}.page-profile .back-link:hover{color:var(--color-accent)}.page-profile h1{margin-bottom:var(--space-xs)}.page-profile>.profile-role{font-size:1rem;color:var(--color-accent);font-style:italic;margin-bottom:var(--space-xs)}.profile-pronunciation{font-size:.9rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.page-profile .profile-bio{line-height:1.7;margin-bottom:var(--space-xl)}.page-profile section{margin-bottom:var(--space-xl)}.page-profile h2{font-size:1.25rem;margin-bottom:var(--space-sm);color:var(--color-heading)}.profile-facts{list-style:disc;padding-left:1.5em;margin:0}.profile-facts li{margin-bottom:.4em;line-height:1.6}.source-banner{font-size:.9rem;font-style:italic;padding:var(--space-sm) var(--space-md);border-radius:var(--radius);margin-bottom:var(--space-xl);line-height:1.5}.fan-banner{background:#f3e8d0;color:#6b4226}.unfinished-tag{color:#6b4226;font-style:italic;font-size:.85em}.mixed-banner{background:#e8ecf0;color:var(--color-text)}.source-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs);padding:2px 8px;border-radius:3px;display:inline-block}.canon-label{background:#ded;color:#2d5a2d}.fan-label{background:#f3e8d0;color:#6b4226}.page-profile section .source-label+.profile-facts{margin-bottom:var(--space-md)}.name-link{color:var(--color-accent);text-decoration:none;border-bottom:1px dotted var(--color-accent)}.name-link:hover{text-decoration:none;border-bottom-style:solid}.home-challenge{margin-top:2.5rem;padding:2rem;background:#fffdf7;border:2px solid var(--color-accent);border-radius:var(--radius)}.home-challenge h2{color:var(--color-heading);margin-bottom:.5rem}.challenge-intro{margin-bottom:1.2rem;font-style:italic;color:var(--color-text)}.challenge-problem{background:#faf6ee;padding:1rem;border-radius:var(--radius);margin-bottom:1rem;line-height:1.6}.challenge-input-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.challenge-input-row label{font-weight:600;color:var(--color-heading)}.challenge-input-row input{padding:.45rem .75rem;border:1px solid #c5b99a;border-radius:var(--radius);font-size:1rem;font-family:inherit}.challenge-input-row button{padding:.45rem 1.2rem;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:1rem;font-family:inherit}.challenge-input-row button:hover{opacity:.85}.challenge-input-row button:disabled,.challenge-input-row input:disabled{opacity:.5;cursor:not-allowed}.challenge-error{margin-top:.75rem;color:#a33;font-weight:600}.cp-fmt{font-size:0;line-height:0;color:transparent;display:inline;overflow:hidden;pointer-events:none}.challenge-reward h3{color:var(--color-heading);margin-bottom:.25rem}
