:root{--bg: #0a0a0a;--surface: #151515;--surface-alt: #1d1a16;--border: #3a3227;--gold: #c7a86b;--muted-gold: #8f7a4f;--text: #e8e0d0;--text-muted: #8a8377;--danger: #8a2f2f;--success: #5d7a47;--font-head: "Cinzel", "Cormorant Garamond", serif;--font-body: "Inter", "Manrope", system-ui, sans-serif;--nav-h: 64px}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;background-image:radial-gradient(120% 90% at 50% -10%,rgba(199,168,107,.05),transparent 55%)}.app{max-width:520px;margin:0 auto;min-height:100%;padding:20px 16px calc(var(--nav-h) + 28px)}h1,h2,h3{font-family:var(--font-head);font-weight:600;letter-spacing:.06em;margin:0}.overline{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.22em;font-size:11px;color:var(--muted-gold)}.muted{color:var(--text-muted)}.gold{color:var(--gold)}.danger{color:#c56a6a}.center{text-align:center}.panel{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:16px;margin-bottom:14px}.panel.alt{background:var(--surface-alt)}.panel-title{font-family:var(--font-head);letter-spacing:.14em;text-transform:uppercase;font-size:12px;color:var(--muted-gold);margin-bottom:12px;border-bottom:1px solid var(--border);padding-bottom:8px}.divider{height:1px;background:var(--border);margin:12px 0}.char-name{font-family:var(--font-head);font-size:30px;letter-spacing:.14em;text-transform:uppercase;color:var(--text);text-shadow:0 0 18px rgba(199,168,107,.15)}.char-title{font-family:var(--font-head);font-style:italic;color:var(--gold);letter-spacing:.08em}.stat-row{margin-bottom:12px}.stat-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}.stat-name{font-family:var(--font-head);letter-spacing:.1em;font-size:13px}.stat-level{font-size:12px;color:var(--muted-gold)}.bar{height:8px;background:#0d0d0d;border:1px solid var(--border);border-radius:2px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,var(--muted-gold),var(--gold));box-shadow:0 0 10px #c7a86b59;transition:width .5s ease}.seg-bar{display:flex;gap:3px}.seg{flex:1;height:10px;background:#0d0d0d;border:1px solid var(--border)}.seg.on{background:linear-gradient(180deg,var(--gold),var(--muted-gold));box-shadow:0 0 8px #c7a86b4d;border-color:var(--muted-gold)}.quest{display:flex;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid rgba(58,50,39,.5);cursor:pointer;-webkit-user-select:none;user-select:none}.quest:last-child{border-bottom:none}.quest .box{width:22px;height:22px;border:1px solid var(--muted-gold);border-radius:2px;display:grid;place-items:center;color:var(--gold);flex:0 0 auto;font-size:14px}.quest.done .box{background:#c7a86b1f}.quest.done .quest-name{color:var(--text-muted);text-decoration:line-through;text-decoration-color:var(--muted-gold)}.quest-name{font-size:15px}.quest-reward{margin-left:auto;font-size:11px;color:var(--muted-gold);white-space:nowrap}label.field{display:block;margin-bottom:12px}label.field .lbl{display:block;font-size:12px;letter-spacing:.08em;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase}input,select,textarea{width:100%;background:#0d0d0d;border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:3px;font-family:var(--font-body);font-size:15px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--muted-gold)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;background:transparent;border:1px solid var(--muted-gold);color:var(--gold);font-family:var(--font-head);letter-spacing:.12em;text-transform:uppercase;font-size:13px;padding:12px 14px;border-radius:3px;cursor:pointer;transition:background .2s,box-shadow .2s}.btn:hover{background:#c7a86b14;box-shadow:0 0 14px #c7a86b26}.btn:disabled{opacity:.4;cursor:default}.btn.solid{background:#c7a86b24}.btn.danger{border-color:var(--danger);color:#c56a6a}.btn.small{width:auto;padding:7px 12px;font-size:11px}.row{display:flex;gap:10px}.row>*{flex:1}.chip{display:inline-block;padding:4px 10px;border:1px solid var(--border);border-radius:999px;font-size:12px;color:var(--text-muted);cursor:pointer;margin:0 6px 6px 0}.chip.on{border-color:var(--gold);color:var(--gold);background:#c7a86b14}.figure{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(58,50,39,.4)}.figure .amt{font-family:var(--font-head);letter-spacing:.04em}.nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:#0a0a0af5;border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:20}.nav a{flex:1;text-align:center;text-decoration:none;color:var(--text-muted);font-family:var(--font-head);letter-spacing:.08em;font-size:10px;text-transform:uppercase;padding:6px 0}.nav a .ic{display:block;font-size:18px;margin-bottom:2px;line-height:1}.nav a.active{color:var(--gold);text-shadow:0 0 10px rgba(199,168,107,.4)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#050505eb;display:grid;place-items:center;z-index:50;animation:fade .4s ease}.levelup{text-align:center;animation:rise .6s ease}.levelup h1{font-size:34px;letter-spacing:.3em;color:var(--gold);text-shadow:0 0 26px rgba(199,168,107,.5)}.levelup .gains{margin-top:14px;color:var(--text);letter-spacing:.12em}@keyframes fade{0%{opacity:0}}@keyframes rise{0%{opacity:0;transform:translateY(14px)}}.loading,.error{text-align:center;padding:40px 0;color:var(--text-muted);font-family:var(--font-head);letter-spacing:.1em}.error{color:#c56a6a}.lead{color:var(--text);line-height:1.55;font-size:15px}.guide-p{color:var(--text-muted);line-height:1.55;font-size:14px;margin:6px 0 0}.guide-key{color:var(--gold)}.guide-step{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid rgba(58,50,39,.4)}.guide-step:last-child{border-bottom:none}.guide-step .gi{font-size:18px;color:var(--gold);flex:0 0 22px;text-align:center;line-height:1.4}.guide-time{font-family:var(--font-head);letter-spacing:.1em;font-size:12px;color:var(--muted-gold);text-transform:uppercase}.awaken{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 90% at 50% 20%,#0e0c09,#050505 70%,#000);overflow-y:auto;z-index:40}.awaken-stage{position:relative;z-index:2;min-height:100%;max-width:520px;margin:0 auto;padding:32px 22px 40px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.awaken-passage{font-family:var(--font-head);font-size:26px;line-height:1.7;letter-spacing:.06em;color:var(--text);white-space:pre-line;text-shadow:0 0 24px rgba(199,168,107,.12)}.awaken-title{font-family:var(--font-head);font-size:44px;letter-spacing:.32em;color:var(--gold);text-shadow:0 0 34px rgba(199,168,107,.4);margin-bottom:16px}.awaken-sub{color:var(--text-muted);font-family:var(--font-head);font-style:italic;letter-spacing:.05em;max-width:320px;margin:0 auto 28px;line-height:1.6}.awaken-begin{width:auto;padding:12px 40px}.caret{display:inline-block;width:8px;margin-left:2px;border-bottom:2px solid var(--gold);animation:blink 1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.awaken-stage.book{justify-content:flex-start;text-align:left}.book-progress{align-self:center;font-family:var(--font-head);letter-spacing:.22em;text-transform:uppercase;font-size:11px;color:var(--muted-gold);margin-bottom:22px}.book-chapter{width:100%}.book-title{font-family:var(--font-head);font-size:26px;letter-spacing:.14em;color:var(--text)}.book-sub{color:var(--text-muted);font-size:13px;margin:6px 0 20px;line-height:1.5}.book-item{margin-bottom:22px}.book-item .lbl{font-size:14px;text-transform:none;letter-spacing:.02em;color:var(--text);margin-bottom:10px}.scale-ends{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted);margin-top:4px}.choices{display:flex;flex-direction:column;gap:8px}.choice{display:flex;align-items:center;gap:12px;text-align:left;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);padding:11px 14px;border-radius:3px;font-family:var(--font-body);font-size:14px;cursor:pointer;transition:border-color .2s,color .2s,background .2s}.choice .choice-dot{width:12px;height:12px;border-radius:50%;border:1px solid var(--muted-gold);flex:0 0 auto}.choice.on{border-color:var(--gold);color:var(--text);background:#c7a86b12}.choice.on .choice-dot{background:var(--gold);box-shadow:0 0 10px #c7a86b80}.book-nav{display:flex;gap:10px;margin-top:12px}.book-nav .btn{flex:1}.awaken-stage.reveal{justify-content:center}.reveal-inner{width:100%;text-align:center}.assess-note{margin:18px 0 4px;color:var(--text-muted);font-family:var(--font-head);font-style:italic;letter-spacing:.04em;line-height:1.7;font-size:13px}.app-reveal{animation:reveal-fade 1.4s ease}@keyframes reveal-fade{0%{opacity:0}to{opacity:1}}.embers{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;overflow:hidden}.ember{position:absolute;bottom:-10px;border-radius:50%;background:var(--gold);opacity:0;filter:blur(.5px);box-shadow:0 0 6px #c7a86b99;animation-name:ember-rise;animation-timing-function:ease-out;animation-iteration-count:infinite}@keyframes ember-rise{0%{transform:translateY(0) translate(0);opacity:0}15%{opacity:.7}70%{opacity:.5}to{transform:translateY(-100vh) translate(var(--drift, 0));opacity:0}}.tree{display:flex;flex-direction:column;gap:4px;margin-top:6px;padding-left:6px;border-left:1px solid var(--border)}.node{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted);padding:3px 0}.node-dot{width:9px;height:9px;border-radius:50%;border:1px solid var(--border);flex:0 0 auto}.node.on{color:var(--text)}.node.on .node-dot{background:var(--gold);border-color:var(--muted-gold);box-shadow:0 0 8px #c7a86b73}.node.on .node-name{font-family:var(--font-head);letter-spacing:.04em}#root{zoom:var(--ui-scale, 1)}.btn,.chip,.choice,.seg,.quest,.node{transition:transform .12s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease,color .2s ease,opacity .2s ease}.btn:active,.chip:active,.choice:active{transform:scale(.97)}.quest{border-radius:3px}.quest:active{transform:scale(.99);background:#c7a86b0d}.box{transition:background .2s ease,border-color .2s ease,box-shadow .25s ease}.quest.done .box{box-shadow:0 0 10px #c7a86b40}.panel{animation:panel-in .32s ease both}@keyframes panel-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.panel{animation:none}*{transition-duration:.01ms!important}}.meal{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid rgba(58,50,39,.5)}.meal:last-of-type{border-bottom:none}.meal-name{font-size:15px}.meal-badges{display:flex;gap:6px;margin-top:5px;flex-wrap:wrap}.meal-badges .q{font-size:11px;letter-spacing:.04em;color:var(--muted-gold);border:1px solid var(--border);border-radius:3px;padding:1px 6px}.meal-badges .q.bad{color:#c56a6a;border-color:var(--danger)}.meal-badges .q.muted-q{color:var(--text-muted)}.eff-row{display:flex;flex-wrap:wrap;gap:6px}.eff{font-size:12px;letter-spacing:.03em;color:var(--gold);border:1px solid var(--muted-gold);border-radius:3px;padding:2px 8px;background:#c7a86b0f}.eff.bad{color:#c56a6a;border-color:var(--danger);background:#8a2f2f14}.eff.new{color:var(--text);border-color:var(--gold)}.buff-chips{display:flex;flex-wrap:wrap;gap:8px}.buff-chip{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;border-radius:999px;border:1px solid rgba(199,168,107,.4);background:#c7a86b14;color:var(--text);font-size:13px;text-decoration:none}.buff-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px #c7a86bb3}.pixel-canvas{image-rendering:pixelated;image-rendering:crisp-edges}.effigy{display:block;filter:drop-shadow(0 2px 10px rgba(0,0,0,.6))}.effigy.vanquished{filter:grayscale(.7) brightness(.5);opacity:.6}.scene-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;image-rendering:pixelated;image-rendering:crisp-edges;opacity:.5;z-index:0;pointer-events:none}.combat:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(120% 80% at 50% 30%,transparent 40%,rgba(3,3,5,.72) 100%)}.bar-fill.foe{background:linear-gradient(90deg,#5a1f1f,#a83b3b);box-shadow:0 0 10px #8a2f2f66}.combat{position:fixed;top:0;right:0;bottom:0;left:0;z-index:45;background:radial-gradient(120% 90% at 50% 25%,#100c09,#050505 70%,#000);overflow:hidden}.combat-stage{position:relative;z-index:2;max-width:520px;margin:0 auto;height:100%;display:flex;flex-direction:column;padding:24px 18px calc(env(safe-area-inset-bottom,0px) + 18px)}.combat-top{text-align:center}.combat-foe-name{font-family:var(--font-head);font-size:22px;letter-spacing:.1em;color:var(--text);margin:2px 0 8px;text-shadow:0 0 18px rgba(138,47,47,.3)}.combat-effigy{flex:0 0 auto;display:grid;place-items:center;padding:10px 0}.combat-log{flex:1 1 auto;overflow-y:auto;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:10px 4px;margin:8px 0;min-height:90px}.cl{font-size:13px;line-height:1.5;margin-bottom:5px}.cl-you{color:var(--text)}.cl-foe{color:#c56a6a}.cl-sys{color:var(--muted-gold);font-style:italic}.cl-keeper{color:var(--gold);font-family:var(--font-head);font-style:italic;letter-spacing:.03em}.combat-bottom{flex:0 0 auto}.combat-menu{display:grid;grid-template-columns:1fr 1fr;gap:8px}.btn.ghost{background:transparent;border-color:var(--border);color:var(--muted-gold)}.combat-tags{display:flex;gap:6px;justify-content:center;min-height:20px;margin-top:6px}.ctag{font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:2px 8px;border-radius:999px;border:1px solid}.ctag.rage{color:#d98a8a;border-color:#a83b3b99;background:#8a2f2f24}.ctag.exp{color:var(--gold);border-color:#c7a86b80;background:#c7a86b1f}.ach-toast{position:fixed;top:calc(env(safe-area-inset-top,0px) + 14px);left:50%;transform:translate(-50%);z-index:60;width:min(360px,calc(100vw - 28px));display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;border:1px solid rgba(199,168,107,.55);background:linear-gradient(180deg,#17130c,#0c0a07);box-shadow:0 10px 30px #0009,0 0 22px #c7a86b2e;overflow:hidden;cursor:pointer}.ach-shine{position:absolute;top:0;left:-60%;width:45%;height:100%;background:linear-gradient(100deg,transparent,rgba(216,196,138,.35),transparent);animation:ach-sweep 1.6s ease-in-out .25s}@keyframes ach-sweep{0%{left:-60%}to{left:130%}}.ach-badge{flex:0 0 auto;width:52px;height:52px;display:grid;place-items:center;border-radius:50%;border:1px solid rgba(199,168,107,.5);background:radial-gradient(circle,rgba(199,168,107,.16),transparent 70%);box-shadow:0 0 14px #c7a86b40}.ach-body{min-width:0}.ach-over{font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}.ach-name{font-family:var(--font-head);font-size:16px;color:var(--text);margin:1px 0}.ach-desc{font-size:11px;color:var(--muted);line-height:1.35}.trophies{display:grid;grid-template-columns:repeat(auto-fit,minmax(58px,1fr));gap:10px}.trophy{text-align:center}.trophy-badge{display:grid;place-items:center;height:52px;border-radius:10px;border:1px solid rgba(199,168,107,.4);background:radial-gradient(circle,rgba(199,168,107,.1),transparent 70%)}.trophy.locked .trophy-badge{border-color:var(--border);background:#00000040}.trophy.locked .trophy-badge canvas{filter:grayscale(1) brightness(.32)}.trophy-name{font-size:9px;letter-spacing:.04em;color:var(--gold);margin-top:5px;line-height:1.2}.trophy.locked .trophy-name{color:var(--muted)}
