:root{--wood-dark:#1a1209;--wood-mid:#2c1e0e;--wood-light:#3d2b14;--parchment:#d4c5a0;--parchment-dark:#b8a67e;--gold:#d4a34a;--gold-bright:#f0c45a;--amber:#c83;--ember:#e8621a;--text-light:#e8dcc8;--text-dim:#a09078;--shadow:#0009;--elara-color:#4a7c59;--grimjaw-color:#5a4a3a;--thalgrum-color:#b87333;--font-display:"Cinzel", serif;--font-body:"Crimson Text", Georgia, serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);color:var(--text-light);min-height:100vh;overflow:hidden}.tavern-bg{z-index:-1;background:url(/assets/tavern.webp) 50%/cover no-repeat;position:fixed;inset:0}#app{width:100vw;height:100vh;position:relative}.scene{opacity:0;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;transition:opacity .6s;display:flex;position:absolute;inset:0}.scene.active{opacity:1;pointer-events:auto}.title-scene{background:radial-gradient(#0006 0%,#000000bf 100%),url(/assets/tavern_exterior.webp) 50%/cover no-repeat}.title-content{text-align:center;z-index:1;position:relative}.title-content h1{font-family:var(--font-display);color:var(--gold);text-shadow:0 0 40px #d4a34a4d,0 2px 4px #000c;letter-spacing:.1em;margin-bottom:.25rem;font-size:3.5rem}.title-content .subtitle{font-family:var(--font-display);color:var(--text-dim);letter-spacing:.2em;text-transform:uppercase;margin-bottom:3rem;font-size:1.1rem}.title-content .premise{max-width:520px;color:var(--parchment-dark);margin:0 auto 2.5rem;font-size:1.35rem;font-style:italic;line-height:1.7}.title-content .timer-note{color:var(--text-dim);margin-bottom:2rem;font-size:1.05rem}.btn-enter{font-family:var(--font-display);color:var(--wood-dark);background:linear-gradient(180deg, var(--gold-bright) 0%, var(--gold) 100%);border:2px solid var(--amber);cursor:pointer;letter-spacing:.08em;text-shadow:none;padding:.85rem 2.5rem;font-size:1.1rem;transition:all .25s}.btn-enter:hover{background:linear-gradient(180deg, #f8d06b 0%, var(--gold-bright) 100%);transform:translateY(-1px);box-shadow:0 0 20px #d4a34a66}.btn-enter:active{transform:translateY(0)}.btn-enter:disabled{opacity:.6;cursor:not-allowed;transform:none}.cta-group{flex-direction:column;align-items:center;gap:.7rem;display:flex}.btn-enter-secondary{color:var(--parchment);border:1px solid var(--wood-light);text-shadow:none;background:0 0}.btn-enter-secondary:hover{border-color:var(--gold);color:var(--gold-bright);box-shadow:none;background:#d4a34a14}.comp-code-wrap{flex-direction:column;align-items:center;margin-top:1.25rem;display:flex}.comp-code-toggle{font-family:var(--font-body);color:var(--text-dim);border-bottom:1px dotted var(--text-dim);cursor:pointer;padding-bottom:1px;font-size:.95rem;text-decoration:none;transition:color .2s,border-color .2s}.comp-code-toggle:hover{color:var(--gold);border-bottom-color:var(--gold)}.comp-code-form{flex-direction:column;align-items:center;gap:.6rem;margin-top:.9rem;display:flex}.comp-code-input{font-family:var(--font-display);letter-spacing:.15em;color:var(--text-light);border:1px solid var(--wood-light);text-align:center;text-transform:uppercase;background:#00000073;outline:none;min-width:14rem;padding:.55rem .9rem;font-size:1rem;transition:border-color .2s}.comp-code-input:focus{border-color:var(--gold)}.comp-code-submit{font-family:var(--font-display);color:var(--parchment);border:1px solid var(--amber);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;background:0 0;padding:.45rem 1.4rem;font-size:.95rem;transition:background .2s,color .2s}.comp-code-submit:hover:not(:disabled){background:var(--amber);color:var(--wood-dark)}.comp-code-submit:disabled{opacity:.55;cursor:default}.tavern-scene{background:#00000073;justify-content:center;padding:0}.gold-display{font-family:var(--font-display);color:var(--gold-bright);z-index:100;text-shadow:0 1px 3px #000c;font-size:1.1rem;position:fixed;top:3.25rem;right:1.5rem}.gold-coin{background:radial-gradient(circle at 40% 35%, var(--gold-bright), var(--amber));vertical-align:middle;border:1px solid var(--amber);border-radius:50%;width:18px;height:18px;margin-right:6px;display:inline-block}.tavern-floor{justify-content:center;align-items:center;gap:3rem;width:100%;max-width:1000px;padding:0 2rem;display:flex}.character-card{cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000059;border:1px solid #ffffff0f;flex-direction:column;align-items:center;gap:1rem;width:200px;padding:1.5rem;transition:all .3s;display:flex}.character-card:hover{background:#00000080;border-color:#ffffff26;transform:translateY(-4px);box-shadow:0 8px 24px #00000080}.character-portrait{border:3px solid;border-radius:50%;justify-content:center;align-items:center;width:110px;height:110px;font-size:2.8rem;transition:box-shadow .3s;display:flex;overflow:hidden}.character-portrait img{object-fit:cover;width:100%;height:100%}.character-card:hover .character-portrait{box-shadow:0 0 20px #ffffff26}.character-name{font-family:var(--font-display);color:var(--text-light);text-align:center;font-size:.95rem}.character-role{color:var(--text-dim);text-align:center;font-size:.85rem;font-style:italic}.quest-log{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#00000073;border:1px solid #ffffff0f;max-width:320px;padding:.85rem 1.25rem;position:fixed;top:1rem;left:1.25rem}.quest-log-header{font-family:var(--font-display);color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem;font-size:1.1rem}.quest-list{flex-direction:column;gap:.5rem;display:flex}.quest-item{align-items:center;gap:.6rem;font-size:1.2rem;display:flex}.quest-item.active{color:var(--text-light)}.quest-item.completed{color:var(--text-dim);-webkit-text-decoration:line-through #a0907899;text-decoration:line-through #a0907899;text-decoration-thickness:2.5px}.quest-marker{text-align:center;flex-shrink:0;width:1rem;font-size:.8rem}.quest-item.active .quest-marker{color:var(--gold)}.quest-item.completed .quest-marker{color:var(--text-dim)}.quest-choice-group{border-left:2px solid var(--gold);flex-direction:column;gap:.35rem;margin-left:.25rem;padding-left:.75rem;display:flex}.quest-choice-label{color:var(--gold);opacity:.8;font-size:.85rem;font-style:italic}.quest-choice-group .quest-item{font-size:1.1rem}.audio-controls{z-index:100;align-items:center;gap:.75rem;display:flex;position:fixed;bottom:1.25rem;left:1.25rem}.btn-audio{font-family:var(--font-body);color:var(--text-dim);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;padding:.4rem .8rem;font-size:.85rem;transition:all .2s}.btn-audio:hover{color:var(--text-light);background:#ffffff1a}.volume-slider{appearance:none;cursor:pointer;background:#ffffff26;border-radius:2px;width:80px;height:4px}.volume-slider::-webkit-slider-thumb{appearance:none;background:var(--gold);cursor:pointer;border-radius:50%;width:14px;height:14px}.conversation-scene{background:#0000008c;justify-content:flex-end;align-items:center;gap:0;padding:0}.conversation-character{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.conversation-portrait{border:none;border-radius:0;justify-content:center;align-items:center;width:100%;height:100%;margin:0;font-size:5rem;display:flex;overflow:hidden}.conversation-portrait img{object-fit:cover;object-position:center 20%;width:100%;height:100%}.conversation-character:after{content:"";pointer-events:none;background:linear-gradient(#0000 40%,#000000b3 85%,#000000d9 100%);position:absolute;inset:0}.conversation-name{font-family:var(--font-display);color:var(--text-light);text-shadow:0 2px 8px #000c;z-index:2;white-space:nowrap;font-size:1.8rem;position:absolute;bottom:7.5rem;left:50%;transform:translate(-50%)}.conversation-desc{color:var(--text-dim);text-shadow:0 1px 4px #000c;z-index:2;white-space:nowrap;font-size:1rem;font-style:italic;position:absolute;bottom:6.3rem;left:50%;transform:translate(-50%)}#conversation-widget{z-index:10;justify-content:center;width:100%;max-width:400px;padding-bottom:1.5rem;display:flex;position:relative}.btn-leave{z-index:10;font-family:var(--font-display);color:var(--text-dim);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;letter-spacing:.05em;background:#0006;border:1px solid #ffffff1a;margin-bottom:1.5rem;padding:.6rem 1.8rem;font-size:.95rem;transition:all .25s;position:relative}.btn-leave:hover{color:var(--text-light);background:#0009;border-color:#fff3}.session-timer{font-family:var(--font-display);color:var(--text-dim);z-index:100;text-shadow:0 1px 3px #000c;letter-spacing:.05em;font-size:1.1rem;position:fixed;top:1.25rem;right:1.5rem}.session-timer.timer-paused{opacity:.4}.session-timer.timer-warning{color:var(--amber)}.session-timer.timer-critical{color:#e05555;animation:1s ease-in-out infinite timer-pulse}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.5}}.toast-container{z-index:99;pointer-events:none;flex-direction:column;gap:.6rem;display:flex;position:fixed;top:0;left:1.25rem}.toast{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid #ffffff14;border-left:3px solid var(--gold);pointer-events:auto;opacity:0;background:#140e08eb;align-items:flex-start;gap:.75rem;min-width:280px;max-width:360px;padding:.85rem 1.2rem;transition:opacity .4s,transform .4s cubic-bezier(.34,1.4,.64,1);display:flex;transform:translate(-40px)}.toast.show{opacity:1;transform:translate(0)}.toast.hide{opacity:0;transition:opacity .3s,transform .3s;transform:translate(-40px)}.toast-quest-complete{border-left-color:#5cb85c}.toast-secret{border-left-color:#c084fc}.toast-gold{border-left-color:var(--gold-bright)}.toast-warning{border-left-color:#e8621a}.toast-icon{flex-shrink:0;margin-top:.1rem;font-size:1.1rem;line-height:1}.toast-quest-new .toast-icon{color:var(--gold)}.toast-quest-complete .toast-icon{color:#5cb85c}.toast-secret .toast-icon{color:#c084fc}.toast-gold .toast-icon{color:var(--gold-bright)}.toast-warning .toast-icon{color:#e8621a}.toast-gold .toast-label{color:var(--gold)}.toast-body{flex-direction:column;gap:.15rem;display:flex}.toast-label{font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);font-size:.65rem}.toast-quest-complete .toast-label{color:#5cb85c}.toast-secret .toast-label{color:#c084fc}.toast-title{font-family:var(--font-body);color:var(--text-light);font-size:.95rem;line-height:1.3}.toast-desc{color:var(--text-dim);font-size:.8rem;font-style:italic;line-height:1.3}.time-up-modal{z-index:10000;background:#000c;justify-content:center;align-items:center;animation:.5s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.time-up-panel{border:1px solid var(--gold);text-align:center;background:#140e08f2;max-width:420px;padding:3rem}.time-up-title{font-family:var(--font-display);color:var(--gold);margin-bottom:1rem;font-size:2rem}.time-up-message{font-family:var(--font-body);color:var(--text-dim);margin-bottom:2rem;font-size:1.1rem;line-height:1.6}.about-link-wrap{text-align:center;margin-top:.85rem}.about-link{color:var(--text-dim);font-family:var(--font-body);text-underline-offset:3px;cursor:pointer;font-size:.9rem;-webkit-text-decoration:underline #fff3;text-decoration:underline #fff3}.about-link:hover{color:var(--gold);-webkit-text-decoration-color:var(--gold);text-decoration-color:var(--gold)}.about-btn-overlay{z-index:100;position:fixed;bottom:1.25rem;right:1.25rem}.btn-about{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-dim);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;background:#00000073;border:1px solid #ffffff1a;padding:.4rem .9rem;font-size:.85rem}.btn-about:hover{color:var(--gold);border-color:var(--gold)}.about-modal{z-index:10000;background:#000c;justify-content:center;align-items:center;animation:.25s fade-in;display:flex;position:fixed;inset:0}.about-panel{border:1px solid var(--gold);text-align:left;background:#140e08f7;width:calc(100% - 2rem);max-width:520px;max-height:calc(100vh - 4rem);padding:2.25rem 2.5rem;overflow-y:auto}.about-title{font-family:var(--font-display);color:var(--gold);text-align:center;margin:0 0 1.25rem;font-size:1.8rem}.about-section-heading{font-family:var(--font-display);color:var(--gold);letter-spacing:.08em;text-transform:uppercase;margin:1.25rem 0 .4rem;font-size:1rem}.about-section-body{font-family:var(--font-body);color:var(--text-dim);margin:0;font-size:.98rem;line-height:1.55}.btn-about-close{border:1px solid var(--gold);color:var(--gold);font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;background:0 0;margin:2rem auto 0;padding:.55rem 2rem;font-size:.95rem;display:block}.btn-about-close:hover{background:#d4af5a1a}@media (width<=700px){.title-content h1{font-size:2.2rem}.tavern-floor{flex-direction:column;gap:1.5rem}.character-card{flex-direction:row;width:100%;max-width:280px;padding:1rem}.character-portrait{width:60px;height:60px;font-size:1.5rem}.quest-log{max-width:100%;margin:0 1rem}.conversation-name{font-size:1.3rem;bottom:4.5rem}.btn-about{padding:.3rem .7rem;font-size:.75rem}.about-panel{padding:1.5rem}.about-title{font-size:1.4rem}}
