@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=DM+Sans:ital,wght@0,400;0,500;0,600;1,400&display=swap";:root{--page:#151320;--page-soft:#1b1928;--page-deep:#0d0c14;--page-lift:#201e2e;--page-shelf:#252338;--ink:#ede0c8;--ink-soft:#d4c49c;--ink-fade:#8a7c6c;--ink-ghost:#58503e;--gold:#d4a84a;--gold-soft:#d4a84a8c;--gold-glow:#d4a84a1f;--stone:#4a5d74;--stone-soft:#4a5d742e;--stone-dim:#4a5d7414;--bio:#5aa898;--bio-dim:#50a0911f;--bio-ghost:#50a0910d;--edge:#5a6e9124;--edge-soft:#5a6e9112;--npc-default:#9ab4bc;--whisper:#c8a060;--bg-abyss:var(--page-deep);--bg-stone:var(--page);--bg-cave:var(--page-soft);--bg-shelf:var(--page-shelf);--bg-inset:var(--page-deep);--text-body:var(--ink);--text-soft:var(--ink-soft);--text-muted:var(--ink-fade);--glow-green:#8ac48a;--glow-blue:#b8ccd8;--glow-cyan:#a0c8be;--glow-gold:var(--gold);--border-dim:var(--edge);--font-book:"Cormorant Garamond", "Palatino Linotype", "Book Antiqua", Palatino, Georgia, serif;--font-note:"DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-world:var(--font-book);--font-voice:var(--font-note)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-note);background:var(--page-deep);color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#5a6e912e;border-radius:2px}input,textarea,button{font-family:var(--font-note)}@keyframes fade-up{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-in-slow{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-narration{0%{opacity:0}to{opacity:1}}@keyframes breathe{0%,to{opacity:.5}50%{opacity:.85}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}@keyframes cave-breathe{0%{opacity:0;transform:scaleX(.3)}30%{opacity:1}50%{transform:scaleX(1)}70%{opacity:1}to{opacity:0;transform:scaleX(.3)}}@keyframes spore-drift{0%{opacity:0;transform:translateY(0)scale(1)}20%{opacity:.7}80%{opacity:.3}to{opacity:0;transform:translateY(-24px)scale(.2)}}.app-container{background:linear-gradient(#1d1a2a 0%,#151320 35%,#111020 70%,#0d0c18 100%);flex-direction:column;max-width:480px;height:100%;margin:0 auto;display:flex;position:relative;overflow:hidden}.app-container:before{content:"";pointer-events:none;z-index:0;opacity:.55;mix-blend-mode:overlay;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.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");background-size:140px 140px;position:absolute;inset:0}.app-container:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 50% -10%,#b478281a 0%,#0000 55%),radial-gradient(#0000 50%,#08060e52 100%),radial-gradient(at 50% 110%,#3c826e12 0%,#0000 55%);position:absolute;inset:0}.app-container>*{z-index:1;position:relative}.chat-header{border-bottom:1px solid var(--edge);-webkit-user-select:none;user-select:none;cursor:default;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14121eeb;flex-shrink:0;align-items:baseline;gap:10px;padding:16px 24px 14px;display:flex;position:relative}.chat-header:after{content:"";background:linear-gradient(90deg,#0000 0%,#d4a84a33 50%,#0000 100%);height:1px;position:absolute;bottom:0;left:15%;right:15%}.chat-header-title{font-family:var(--font-book);color:#ede0c8;text-shadow:0 0 22px #d4a84a29;letter-spacing:.5px;margin:0;font-size:22px;font-weight:500}.chat-header-campaign{color:var(--ink-fade);text-transform:uppercase;letter-spacing:2px;font-size:10px;font-weight:500}.chat-header-secure{color:var(--stone);opacity:.4;align-items:center;margin-left:auto;display:flex}.chat-header-version{font-family:var(--font-note);letter-spacing:1px;color:var(--ink-fade);opacity:.5;background:var(--stone-dim);border-radius:4px;margin-left:4px;padding:2px 6px;font-size:9.5px;font-weight:600}.chat-header-logout{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;transition:color .2s,opacity .2s}.chat-header-logout:hover,.chat-header-logout:active{opacity:.9;color:var(--gold)}.chat-header-refresh{color:var(--ink-fade);opacity:.45;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;margin-left:4px;padding:4px 6px;transition:opacity .2s,color .2s;display:flex}.chat-header-refresh:hover,.chat-header-refresh:active{opacity:.95;color:var(--gold)}.send-error-banner{color:#d4906c;font-family:var(--font-note);background:#b43c321a;border-bottom:1px solid #c8504440;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:8px 18px;font-size:12px;display:flex}.send-error-banner button{color:#d4906c;cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1}.message-list{flex-direction:column;flex:1;gap:6px;padding:20px 0 60px;display:flex;overflow-y:auto}.narration-text{border-left:2px solid #50a09114;margin-left:2px;padding:14px;animation:1.2s ease-out fade-in}@media (width>=420px){.narration-text{padding:14px 22px}}.narration-text p{font-family:var(--font-book);color:var(--ink);text-align:left;white-space:pre-wrap;margin-bottom:0;font-size:20px;font-weight:400;line-height:1.9}.narration-text p+p{margin-top:10px}.narration-text.with-ornament:before{content:"✦";text-align:center;color:var(--gold-soft);opacity:.7;margin-bottom:8px;font-size:14px;display:block}.player-voice{text-align:right;padding:6px 14px 6px 44px;animation:.5s cubic-bezier(.22,.8,.36,1) both player-in}@keyframes player-in{0%{opacity:0;transform:translate(10px)translateY(3px)}to{opacity:1;transform:none}}@media (width>=420px){.player-voice{padding:6px 22px 6px 64px}}.player-voice-text{font-family:var(--font-book);color:var(--gold);word-break:break-word;text-shadow:0 0 22px #d4a84a2e;white-space:pre-wrap;letter-spacing:.1px;margin:0;font-size:19px;font-style:italic;font-weight:500;line-height:1.6}.player-voice-says{font-family:var(--font-note);letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-ghost);text-align:right;margin-bottom:2px;font-size:10px;font-style:normal;font-weight:600;display:block}.player-voice.is-action{text-align:center;padding:10px 28px}.player-voice.is-action .player-voice-text{color:var(--gold-soft);text-shadow:0 0 18px #d4a84a24;font-size:16.5px;font-style:italic}.npc-voice{padding:10px 14px}@media (width>=420px){.npc-voice{padding:10px 26px}}.npc-voice-text{font-family:var(--font-book);color:var(--ink);word-break:break-word;white-space:pre-wrap;margin:0;font-size:20px;font-style:italic;line-height:1.85}.npc-voice-quote{color:var(--ink-fade);padding:0 1px;font-weight:600}.npc-voice-attribution{color:var(--ink-fade);letter-spacing:.5px;font-size:15px;font-style:normal;font-family:var(--font-book)}.roll-message{justify-content:center;padding:10px 24px;animation:.6s ease-out fade-up;display:flex}.roll-card{font-family:var(--font-book);color:var(--ink-fade);letter-spacing:.3px;align-items:baseline;gap:8px;font-size:15px;font-style:italic;display:inline-flex}.roll-card:before,.roll-card:after{content:"·";color:var(--gold-soft);letter-spacing:4px;font-size:14px}.roll-who{color:var(--ink-soft);font-style:normal;font-weight:500}.roll-die{color:var(--ink-fade);font-style:normal}.roll-value{color:var(--gold);text-shadow:0 0 14px #d4a84a59;padding:0 2px;font-size:22px;font-style:normal;font-weight:600}.roll-math{color:var(--ink-fade);font-size:13px;font-style:normal}.choice-prompt{flex-direction:column;gap:10px;padding:8px 24px 10px;animation:.6s ease-out fade-up;display:flex}.choice-prompt-text{font-family:var(--font-book);color:var(--ink-soft);margin-bottom:4px;font-size:17px;font-style:italic;line-height:1.6}.choice-option{background:var(--stone-dim);border:1px solid var(--edge);width:100%;color:var(--ink);font-family:var(--font-book);text-align:left;cursor:pointer;border-radius:10px;align-items:flex-start;gap:12px;padding:13px 18px;font-size:16.5px;line-height:1.45;transition:background .3s,border-color .3s,box-shadow .3s,color .3s;display:flex}.choice-option:hover,.choice-option:active{background:#d4a84a12;border-color:#d4a84a38;box-shadow:0 0 18px #d4a84a14}.choice-option-number{background:var(--stone-soft);width:22px;height:22px;color:var(--ink-soft);font-family:var(--font-note);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:3px;font-size:11px;font-weight:600;display:flex}.choice-option.chosen{color:var(--gold);background:#d4a84a1f;border-color:#d4a84a61;box-shadow:0 0 22px #d4a84a1f}.choice-option.dimmed{opacity:.25;cursor:default;pointer-events:none}.health-message{justify-content:center;padding:10px 22px;animation:.6s ease-out fade-up;display:flex}.health-card{font-family:var(--font-book);border-radius:14px;align-items:center;gap:10px;padding:9px 18px;font-size:16px;font-style:italic;display:inline-flex}.health-message.is-damage .health-card{color:#deb4ac;background:#b437301a;border:1px solid #d25a5052;box-shadow:0 0 16px #d25a501a}.health-message.is-heal .health-card{color:#a8d4cc;background:#50a0911a;border:1px solid #5aa89847;box-shadow:0 0 16px #5aa8981a}.health-icon{font-size:18px}.health-message.is-damage .health-icon{color:#d07060;text-shadow:0 0 10px #d25a5080}.health-message.is-heal .health-icon{color:#80c8bc;text-shadow:0 0 10px #5aa89880}.health-number{padding:0 3px;font-size:22px;font-style:normal;font-weight:600}.health-message.is-damage .health-number{color:#e89088;text-shadow:0 0 14px #d25a5066}.health-message.is-heal .health-number{color:#a0d8d0;text-shadow:0 0 14px #5aa89866}.health-source{opacity:.7;margin-left:4px;font-size:12px}@keyframes typing-pulse{0%,80%,to{opacity:.3;transform:scale(.85)}40%{opacity:1;transform:scale(1)}}.typing-indicator{pointer-events:none;align-items:center;gap:10px;height:36px;padding:12px 28px 8px;transition:opacity .6s,height .5s;display:flex;overflow:hidden}.typing-indicator.hidden{opacity:0;height:0;padding-top:0;padding-bottom:0}.typing-label{font-family:var(--font-book);color:var(--gold);text-shadow:0 0 14px #d4a84a47;letter-spacing:.5px;opacity:.85;font-size:15px;font-style:italic}.typing-dots{align-items:center;gap:6px;display:inline-flex}.typing-dot{background:var(--gold);border-radius:50%;width:6px;height:6px;animation:1.3s ease-in-out infinite typing-pulse;box-shadow:0 0 8px #d4a84a73}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-spinner{border:2px solid #50a09126;border-top-color:#50a091bf;border-radius:50%;width:28px;height:28px;animation:.9s linear infinite spin}.bottom-bar{padding:10px 20px calc(env(safe-area-inset-bottom,8px) + 12px);border-top:1px solid var(--edge);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#12101cf0;flex-shrink:0;position:relative}.bottom-bar:before{content:"";background:linear-gradient(90deg,#0000 0%,#d4a84a2e 50%,#0000 100%);height:1px;position:absolute;top:0;left:15%;right:15%}.bottom-bar-form{align-items:center;gap:12px;display:flex}.bottom-bar-glyphs{align-items:center;gap:2px;display:flex}.bottom-bar-input{border:none;border-bottom:1px solid var(--edge);color:var(--gold);font-family:var(--font-book);caret-color:var(--gold);letter-spacing:.2px;resize:none;field-sizing:content;background:0 0;outline:none;flex:1;min-height:24px;max-height:40vh;padding:10px 4px;font-size:18px;font-style:italic;line-height:1.5;transition:border-color .3s,box-shadow .3s;overflow-y:auto}.bottom-bar-input:focus{border-bottom-color:#d4a84a59}.bottom-bar-input::placeholder{color:var(--ink-ghost);font-style:italic;font-family:var(--font-book);letter-spacing:.3px;font-size:17px}.mode-selector{gap:4px;padding:2px 0 4px;display:flex}.mode-pill{border:1px solid var(--edge);color:var(--ink-fade);font-family:var(--font-book);cursor:pointer;letter-spacing:.5px;background:0 0;border-radius:14px;padding:4px 14px;font-size:14px;font-style:italic;transition:all .2s}.mode-pill:hover,.mode-pill:active{color:var(--ink-soft);border-color:var(--stone-soft)}.mode-pill.active{color:var(--gold);background:#d4a84a1a;border-color:#d4a84a42;box-shadow:0 0 10px #d4a84a14}.bottom-bar-input.mode-say{color:#ece0bc}.bottom-bar-input.mode-say:before{content:"\""}.intro-bleed{pointer-events:none;z-index:120;background:linear-gradient(160deg,#f2d98a 0%,#e8c060 30%,#c88030 65%,#7a4a18 100%);position:fixed;inset:0}.intro-bleed-edge{background:var(--page-deep);clip-path:circle(0% at 50% 52%);will-change:clip-path;animation:1.1s cubic-bezier(.22,.61,.36,1) 50ms forwards dark-bleed-in;display:block;position:absolute;inset:0}@keyframes dark-bleed-in{0%{clip-path:circle(0% at 50% 52%)}to{clip-path:circle(160% at 50% 52%)}}.app-container.opening-reveal>header,.app-container.opening-reveal>.bottom-bar,.app-container.opening-reveal>.send-error-banner{animation:.7s ease-out .2s both opening-ui-fade}@keyframes opening-ui-fade{0%{opacity:0}to{opacity:1}}@keyframes msg-cascade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@keyframes word-stream{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:none}}@keyframes word-in{0%{opacity:0}to{opacity:1}}@keyframes skill-shimmer{0%,to{border-bottom-color:#d4a84a59;box-shadow:0 2px 8px -2px #d4a84a1a}50%{border-bottom-color:#d4a84abf;box-shadow:0 2px 18px -2px #d4a84a66}}.bottom-bar-input.has-skill{color:#e8c86a;text-shadow:0 0 10px #d4a84a4d;animation:2.2s ease-in-out infinite skill-shimmer}.skill-suggestions{flex-wrap:wrap;gap:6px;padding:6px 2px 8px;animation:.35s ease-out fade-up;display:flex}.skill-chip{background:var(--stone-dim);border:1px solid var(--edge);color:var(--ink-soft);font-family:var(--font-book);cursor:pointer;border-radius:14px;align-items:baseline;gap:6px;padding:5px 11px;font-size:14.5px;font-style:italic;line-height:1.2;transition:all .2s;display:inline-flex}.skill-chip:hover,.skill-chip:active{color:var(--gold);background:#d4a84a1a;border-color:#d4a84a47;box-shadow:0 0 12px #d4a84a24}.skill-chip-mod{font-family:var(--font-book);color:var(--ink-fade);font-size:12.5px;font-style:normal;font-weight:600}.bottom-bar-btn{width:38px;height:38px;color:var(--ink-fade);cursor:pointer;font-family:var(--font-book);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:all .25s;display:flex}.bottom-bar-btn:hover,.bottom-bar-btn:active{color:var(--gold);text-shadow:0 0 14px #d4a84a4d}.bottom-bar-btn.active{color:var(--gold);text-shadow:0 0 14px #d4a84a59}.bottom-bar-btn.send{color:var(--gold-soft)}.bottom-bar-btn.send:hover,.bottom-bar-btn.send:active{color:var(--gold);transform:translate(2px)}
