:root{--bg-page: #0e0a06;--bg-surface: #1a1008;--bg-raised: #221508;--parchment: #f0deb8;--parchment-dark: #e0c898;--parchment-aged: #d4b882;--parchment-ink: #2c1a0e;--parchment-faint:#8a6040;--crimson: #8b1a1a;--crimson-bright: #b52020;--crimson-deep: #5c0f0f;--gold: #c9a84c;--gold-bright: #e8c060;--gold-dim: #8a6b28;--text-primary: #e8d5b0;--text-muted: #8a7055;--text-faint: #4a3828;--border-gold: #6b501a;--border-stone: #2a1e10;--border-parchment: #c4a060;--open-green: #2d6a35;--open-text: #a8e0b0;--locked-brown: #6b4a20;--locked-text: #e0c090;--bg-nav: #120d07;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 14px;--font-display: "Cinzel Decorative", "Palatino Linotype", serif;--font-heading: "Cinzel", "Palatino Linotype", serif;--font-body: "IM Fell English", "Georgia", serif;--font-ui: "Segoe UI", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{background-color:var(--bg-page);background-image:radial-gradient(ellipse at 30% 20%,rgba(139,90,43,.04) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(139,26,26,.03) 0%,transparent 60%);color:var(--text-primary);font-family:var(--font-body);font-size:16px;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--border-gold);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}h1,h2,h3,h4{font-family:var(--font-heading);font-weight:600}.display-title{font-family:var(--font-display);letter-spacing:.05em}.parchment-card{background-color:var(--parchment);background-image:radial-gradient(ellipse at 15% 85%,rgba(139,90,43,.18) 0%,transparent 55%),radial-gradient(ellipse at 85% 15%,rgba(160,100,30,.12) 0%,transparent 55%),radial-gradient(ellipse at 50% 50%,rgba(200,160,80,.06) 0%,transparent 70%);color:var(--parchment-ink);border:1px solid var(--border-parchment);border-radius:var(--radius-lg);box-shadow:0 4px 20px #00000080,inset 0 1px #fff0b466,inset 0 -1px #8b5a2b33;position:relative;overflow:hidden}.parchment-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;border-radius:inherit;opacity:.6}.parchment-card .card-content{position:relative;z-index:1}.stone-card{background:linear-gradient(135deg,var(--bg-raised) 0%,var(--bg-surface) 100%);border:1px solid var(--border-stone);border-radius:var(--radius-lg);box-shadow:0 4px 24px #0009;color:var(--text-primary)}.rune-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--gold-dim);font-family:var(--font-heading);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase}.rune-divider:before,.rune-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border-gold),transparent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:none;border-radius:var(--radius-md);font-family:var(--font-heading);font-size:.88rem;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:all .15s ease;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-crimson{background:linear-gradient(180deg,var(--crimson-bright) 0%,var(--crimson) 100%);color:#f0e0c0;border:1px solid var(--crimson-deep);box-shadow:0 2px 8px #8b1a1a66,inset 0 1px #ffb48c26}.btn-crimson:hover:not(:disabled){background:linear-gradient(180deg,#cc2424 0%,var(--crimson-bright) 100%);box-shadow:0 4px 14px #8b1a1a8c;transform:translateY(-1px)}.btn-crimson:active:not(:disabled){transform:translateY(0)}.btn-gold{background:linear-gradient(180deg,var(--gold-bright) 0%,var(--gold) 100%);color:#2c1a0e;border:1px solid var(--gold-dim);box-shadow:0 2px 8px #c9a84c4d,inset 0 1px #ffffc833}.btn-gold:hover:not(:disabled){background:linear-gradient(180deg,#f0cc70 0%,var(--gold-bright) 100%);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border-stone)}.btn-ghost:hover:not(:disabled){border-color:var(--gold-dim);color:var(--text-primary)}.btn-parchment{background:transparent;color:var(--parchment-faint);border:1px solid var(--border-parchment);font-size:.8rem}.btn-parchment:hover:not(:disabled){background:#8b5a2b14;color:var(--parchment-ink)}.btn-danger{background:transparent;color:var(--crimson-bright);border:1px solid rgba(139,26,26,.4);font-size:.78rem;padding:6px 12px}.btn-danger:hover:not(:disabled){background:#8b1a1a1f}.field{margin-bottom:18px}.field label{display:block;font-family:var(--font-heading);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-dim);margin-bottom:6px}.field label.parchment-label{color:var(--parchment-faint)}.field input,.field select,.field textarea{width:100%;background:#00000059;border:1px solid var(--border-gold);color:var(--text-primary);padding:10px 14px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.95rem;outline:none;transition:border-color .15s,box-shadow .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c9a84c26}.field input::placeholder{color:var(--text-faint)}.field input.parchment-input,.field select.parchment-input{background:#fff0c866;border-color:var(--border-parchment);color:var(--parchment-ink)}.field input.parchment-input:focus,.field select.parchment-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c9a84c33}.field input.parchment-input::placeholder{color:var(--parchment-faint)}.field select.parchment-input option{background:var(--parchment);color:var(--parchment-ink)}.field .hint{font-size:.75rem;color:var(--text-faint);margin-top:4px;font-family:var(--font-ui);font-style:italic}.field .field-error{font-size:.78rem;color:#e05050;margin-top:4px;font-family:var(--font-ui)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-family:var(--font-heading);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.badge-open{background:#2d6a3540;color:var(--open-text);border:1px solid rgba(45,106,53,.4)}.badge-locked{background:#6b4a2040;color:var(--locked-text);border:1px solid rgba(107,74,32,.4)}.badge-full{background:#64323240;color:#e0a0a0;border:1px solid rgba(100,50,50,.4)}.badge-active{background:#8b1a1a33;color:#f0b0a0;border:1px solid rgba(139,26,26,.35)}.route-tag{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:5px}.route-BRAIN{background:#53348366;color:#d4b8ff;border:1px solid rgba(83,52,131,.6)}.route-MOUTH{background:#1e563166;color:#a8e6cf;border:1px solid rgba(30,86,49,.6)}.route-FIST{background:#8b000066;color:#ffb3b3;border:1px solid rgba(139,0,0,.6)}.route-LEGS{background:#5d4e3766;color:#ffe0b2;border:1px solid rgba(93,78,55,.6)}.route-WORLD{background:#2a485866;color:#80cbc4;border:1px solid rgba(42,72,88,.6)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#050301d1;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-box{width:100%;max-width:680px;max-height:90vh;overflow-y:auto}.page-container{max-width:1100px;margin:0 auto;padding:0 24px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;display:flex;align-items:center;gap:10px}.section-title:before{content:"";display:inline-block;width:3px;height:1em;background:var(--crimson);border-radius:2px}.spinner{width:20px;height:20px;border:2px solid rgba(201,168,76,.2);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:12px 16px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9rem;font-style:italic}.alert-error{background:#8b1a1a33;border:1px solid rgba(139,26,26,.4);color:#f0b0a0}.alert-info{background:#2a48584d;border:1px solid rgba(42,72,88,.5);color:#90cac8}.top-nav{background:linear-gradient(180deg,var(--bg-page) 0%,var(--bg-nav) 100%);border-bottom:1px solid var(--border-gold);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:0 2px 20px #0009}.dashboard-tabs{display:flex;gap:0;background:var(--bg-surface);border-bottom:1px solid var(--border-stone);padding:0 24px;position:sticky;top:60px;z-index:49}.dashboard-tab{font-family:var(--font-heading);font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;padding:12px 20px;cursor:pointer;transition:color .2s,border-color .2s}.dashboard-tab:hover{color:var(--text-primary)}.dashboard-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.nav-logo{font-family:var(--font-display);font-size:1.3rem;color:var(--gold);text-decoration:none;letter-spacing:.08em;text-shadow:0 0 20px rgba(201,168,76,.4)}.nav-logo span{color:var(--crimson-bright);font-size:.75em;vertical-align:super}.nav-right{display:flex;align-items:center;gap:16px}.nav-user{font-family:var(--font-heading);font-size:.82rem;color:var(--text-muted);letter-spacing:.05em}.empty-state{text-align:center;padding:40px 24px;color:var(--text-faint);font-family:var(--font-body);font-style:italic}.empty-state .empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.4}.empty-state p{font-size:.95rem;line-height:1.6}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes flickerIn{0%{opacity:0}20%{opacity:.8}40%{opacity:.4}60%{opacity:.9}80%{opacity:.6}to{opacity:1}}.fade-in{animation:fadeIn .3s ease forwards}.slide-up{animation:slideUp .4s ease forwards}.flicker-in{animation:flickerIn .6s ease forwards}.game-page{height:100vh;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-page)}.game-topbar{height:42px;background:linear-gradient(180deg,var(--bg-page) 0%,var(--bg-nav) 100%);border-bottom:1px solid var(--border-gold);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0;box-shadow:0 2px 12px #00000080;z-index:10}.game-topbar-left{display:flex;align-items:center;gap:10px}.game-back-link{font-family:var(--font-heading);font-size:.75rem;color:var(--text-muted);text-decoration:none;letter-spacing:.05em}.game-back-link:hover{color:var(--gold)}.game-topbar-divider{width:1px;height:14px;background:var(--border-stone)}.game-party-name{font-family:var(--font-heading);font-size:.85rem;color:var(--text-primary);font-weight:600}.game-topbar-right{display:flex;align-items:center;gap:8px}.game-topbar-invite{display:flex;align-items:center;gap:6px;margin-right:12px;padding-right:12px;border-right:1px solid var(--border-stone)}.game-topbar-invite-label{font-family:var(--font-ui);font-size:.68rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em}.game-topbar-invite-code{font-family:var(--font-display);font-size:.85rem;color:var(--gold-bright);letter-spacing:.1em}.game-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.game-status-text{font-family:var(--font-ui);font-size:.7rem}.game-layout{flex:1;display:flex;overflow:hidden;position:relative}.game-tools-wrapper{position:absolute;top:8px;left:0;display:flex;flex-direction:row;z-index:20;pointer-events:auto}.game-tools{background:linear-gradient(180deg,#2a1f10,#1a1308);border:1px solid var(--border-gold);border-left:none;border-radius:0 8px 8px 0;display:flex;flex-direction:column;padding:8px 4px;gap:4px;transition:width .2s ease,padding .2s ease,opacity .2s ease;width:56px}.game-tools--collapsed{width:0;padding:0;border:none;overflow:hidden;opacity:0}.game-tools-toggle{align-self:center;background:linear-gradient(180deg,#2a1f10,#1a1308);border:1px solid var(--border-gold);border-left:none;border-radius:0 6px 6px 0;color:var(--gold);font-size:.7rem;cursor:pointer;padding:14px 5px;transition:background .15s;display:flex;align-items:center}.game-tools-toggle:hover{background:#c9a84c40}.game-tools-toggle--collapsed{padding:18px 6px;font-size:.8rem}.game-tool-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 4px;margin:0 4px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);cursor:pointer;border-radius:6px;transition:background .15s,border-color .15s}.game-tool-btn:hover{background:#c9a84c1a;border-color:#c9a84c4d}.game-tool-active{background:#c9a84c2e!important;border-color:var(--gold)!important}.game-tool-active .game-tool-icon,.game-tool-active .game-tool-label{color:var(--gold)}.game-tool-icon{font-size:1.3rem;line-height:1}.game-tool-label{font-family:var(--font-ui);font-size:.55rem;color:var(--text-muted);letter-spacing:.02em;text-transform:uppercase}.dice-tray{position:fixed;left:56px;top:42px;width:220px;background:linear-gradient(180deg,#1e1610,#120e08);border:1px solid var(--border-gold);border-left:none;border-radius:0 10px 10px 0;display:flex;flex-direction:column;z-index:15;transform:translate(-300px);visibility:hidden;transition:transform .25s ease,visibility .25s;box-shadow:6px 4px 24px #0009,inset 0 1px #c9a84c14;max-height:calc(100vh - 52px)}.dice-tray--open{transform:translate(0);visibility:visible}.dice-tray-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border-stone)}.dice-tray-title{font-family:var(--font-heading);font-size:.9rem;color:var(--gold);text-transform:uppercase;letter-spacing:.04em}.dice-tray-close{background:none;border:none;color:var(--text-faint);font-size:1.3rem;cursor:pointer;padding:2px 6px;line-height:1}.dice-tray-close:hover{color:var(--text-primary)}.dice-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:12px 14px}.dice-btn{display:flex;align-items:center;justify-content:center;height:40px;background:#c9a84c14;border:1px solid rgba(201,168,76,.25);border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s,transform .1s}.dice-btn:hover{background:#c9a84c33;border-color:var(--gold)}.dice-btn:active{transform:scale(.92)}.dice-btn--rolling{animation:diceShake .3s ease}@keyframes diceShake{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg) scale(1.05)}75%{transform:rotate(8deg) scale(1.05)}}.dice-btn-label{font-family:var(--font-heading);font-size:.85rem;color:var(--gold);text-transform:lowercase;font-weight:700}.dice-modifier{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 14px;border-top:1px solid rgba(255,255,255,.04)}.dice-mod-btn{width:32px;height:32px;background:#ffffff0a;border:1px solid rgba(201,168,76,.15);border-radius:6px;color:var(--text-primary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.dice-mod-btn:hover{background:#c9a84c1a;border-color:var(--gold)}.dice-mod-value{font-family:var(--font-heading);font-size:.9rem;color:var(--gold);min-width:36px;text-align:center}.dice-mod-reset{background:none;border:none;color:var(--text-faint);font-family:var(--font-ui);font-size:.6rem;cursor:pointer;text-transform:uppercase}.dice-mod-reset:hover{color:var(--gold)}.dice-history-header{font-family:var(--font-ui);font-size:.6rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;padding:10px 14px 4px;border-top:1px solid rgba(255,255,255,.04)}.dice-history{overflow-y:auto;max-height:180px;padding:4px 12px 10px}.dice-history-empty{color:var(--text-faint);font-style:italic;font-size:.72rem;text-align:center;padding:12px 0}.dice-history-entry{display:flex;flex-wrap:wrap;gap:4px;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.03);font-family:var(--font-ui);font-size:.68rem}.dice-history-name{color:var(--gold);font-weight:600}.dice-history-notation{color:var(--text-muted)}.dice-history-rolls{color:var(--text-faint)}.dice-history-total{color:var(--text-primary);font-weight:700}.game-stage{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-page);position:relative;overflow:hidden}.game-stage-empty{text-align:center;opacity:.3}.game-stage-logo{font-family:var(--font-display);font-size:3rem;color:var(--gold);text-shadow:0 0 40px rgba(201,168,76,.2);letter-spacing:.1em}.game-stage-hint{font-family:var(--font-heading);font-size:.75rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.15em;margin-top:8px}.game-stage-map{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;display:flex;align-items:center;justify-content:center}.game-stage-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0;animation:bgFadeIn .8s ease-out}@keyframes bgFadeIn{0%{opacity:0}to{opacity:1}}.npc-portrait-overlay{position:absolute;left:24px;bottom:0;display:flex;flex-direction:column;align-items:center;z-index:2;pointer-events:none;animation:npcSlideIn .4s ease-out}@keyframes npcSlideIn{0%{opacity:0;transform:translate(-60px)}to{opacity:1;transform:translate(0)}}@keyframes npcSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-60px)}}.npc-portrait-overlay.dismissing{animation:npcSlideOut .4s ease-in forwards}.npc-portrait-img{min-height:168px;max-height:42vh;max-width:24vw;object-fit:contain;object-position:bottom;filter:drop-shadow(0 4px 20px rgba(0,0,0,.8))}.npc-portrait-placeholder{width:120px;height:156px;background:var(--bg-raised);border:2px solid var(--gold-dim);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:3rem;color:var(--gold)}.npc-portrait-name{font-family:var(--font-heading);font-size:1.1rem;color:var(--gold);text-transform:capitalize;letter-spacing:.05em;padding:6px 0;background:#0009;border:1px solid var(--gold-dim);border-radius:4px;margin-top:8px;margin-bottom:12px;text-shadow:0 1px 3px rgba(0,0,0,.8);width:100%;text-align:center;box-sizing:border-box}.game-right-panel{width:320px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border-gold);background:var(--bg-surface)}.game-right-tabs{display:flex;justify-content:space-evenly;border-bottom:1px solid var(--border-stone);flex-shrink:0}.game-right-tab{font-size:1.35rem;color:var(--text-faint);background:none;border:none;border-bottom:2px solid transparent;padding:8px 0;flex:1;text-align:center;cursor:pointer;transition:color .15s,border-color .15s}.game-right-tab:hover{color:var(--text-primary);transform:scale(1.25)}.game-right-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.game-right-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.game-chat-tab{flex:1;display:flex;flex-direction:column;overflow:hidden}.game-chat-scroll{flex:1;overflow-y:auto}.game-chat-input{border-top:1px solid var(--border-stone);padding:10px;display:flex;gap:8px;align-items:flex-end;flex-shrink:0}.game-textarea{flex:1;background:#0006;border:1px solid var(--border-gold);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.88rem;padding:8px 12px;resize:none;outline:none;line-height:1.4}.game-textarea:focus{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold-dim)}.game-send-btn{padding:8px 16px;font-size:.82rem;min-width:60px}.game-mic-btn{padding:8px 10px;font-size:.82rem;min-width:44px;display:inline-flex;align-items:center;justify-content:center;gap:4px;background:#0006;border:1px solid var(--border-gold);color:var(--text-primary);cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none}.game-mic-btn:hover:not(:disabled){border-color:var(--gold)}.game-mic-btn:disabled{opacity:.4;cursor:not-allowed}.game-mic-btn-recording{background:#b4323240;border-color:#e05050;color:#f5a5a5;animation:aidm-mic-pulse 1.2s ease-in-out infinite}.game-mic-btn-transcribing{background:#c8a84c1f;border-color:var(--gold-dim)}.game-mic-btn-error{background:#b4323226;border-color:#e05050;color:#f5a5a5}.game-mic-btn-timer{font-family:var(--font-ui);font-size:.68rem;font-variant-numeric:tabular-nums}@keyframes aidm-mic-pulse{0%,to{box-shadow:0 0 #e0505099}50%{box-shadow:0 0 0 4px #e0505000}}.game-input-hint{font-family:var(--font-ui);font-size:.62rem;color:var(--text-faint);text-align:center;padding:3px 0 6px;flex-shrink:0}.game-notepad-tab{flex:1;display:flex;padding:10px}.game-notepad{flex:1;background:#0000004d;border:1px solid var(--border-stone);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.85rem;padding:12px;resize:none;outline:none;line-height:1.6}.game-notepad:focus{border-color:var(--gold-dim)}.game-notepad-counter{font-family:var(--font-ui);font-size:.62rem;text-align:right;padding:4px 2px 0;transition:color .2s}.game-maps-tab{padding:14px;display:flex;flex-direction:column;height:100%;box-sizing:border-box}.game-map-thumbnail{border:1px solid var(--border-stone);border-radius:var(--radius-md);overflow:hidden;min-height:200px}.game-inventory-tab{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.inventory-gold{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#c9a84c14;border:1px solid var(--border-gold, #6b5a2e);border-radius:6px}.inventory-gold-icon{font-size:1.1rem}.inventory-gold-amount{font-family:var(--font-heading);font-size:1rem;color:var(--gold, #c9a84c)}.inventory-list{display:flex;flex-direction:column;gap:6px}.inventory-item{background:#ffffff08;border:1px solid var(--border-stone, #333);border-radius:6px;padding:8px 10px}.inventory-item-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.inventory-item-name{font-family:var(--font-heading);font-size:.8rem;color:var(--text-primary)}.inventory-item-rarity{font-family:var(--font-ui);font-size:.62rem;text-transform:capitalize;flex-shrink:0}.inventory-item-stat{font-family:var(--font-ui);font-size:.68rem;color:var(--text-faint);margin-right:10px}.inventory-empty-text{font-family:var(--font-ui);font-size:.78rem;color:var(--text-faint);font-style:italic;text-align:center;padding:30px 20px}.inventory-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px}.inventory-toolbar-actions{display:flex;align-items:center;gap:6px;margin-left:auto}.inventory-add-btn{font-size:1.1rem;width:30px;height:30px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:6px;flex-shrink:0;line-height:1}.inventory-refresh-btn{font-size:.9rem;width:30px;height:30px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:6px;flex-shrink:0}.inventory-section{margin-bottom:4px}.inventory-section-header{display:flex;align-items:center;gap:6px;padding:6px 4px 4px;border-bottom:1px solid rgba(201,168,76,.15);margin-bottom:4px}.inventory-section-icon{font-size:1.1rem}.inventory-section-label{font-family:var(--font-heading);font-size:1.1rem;color:var(--gold);text-transform:uppercase;letter-spacing:.08em}.inventory-section-count{font-family:var(--font-ui);font-size:.6rem;color:var(--text-faint);margin-left:auto}.inventory-backpack{margin-top:8px}.inventory-backpack-header{border-bottom:1px solid rgba(201,168,76,.25);padding-bottom:6px;margin-bottom:6px}.inventory-subsection{margin-bottom:4px;padding-left:8px}.inventory-subsection-header{display:flex;align-items:center;gap:5px;padding:4px 4px 3px;margin-bottom:3px}.inventory-subsection-icon{font-size:.72rem}.inventory-subsection-label{font-family:var(--font-ui);font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.inventory-item-stats{display:flex;gap:10px;margin-top:2px}.inventory-item-stat-dim{font-family:var(--font-ui);font-size:.62rem;color:var(--text-faint);opacity:.6}.inventory-info-btn{font-size:.6rem;width:20px;height:20px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;font-style:italic}.inventory-equip-btn{font-size:.6rem;padding:2px 8px;flex-shrink:0}.inventory-item-details{margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.05)}.inventory-item-props{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}.inventory-item-prop-tag{font-family:var(--font-ui);font-size:.6rem;color:var(--text-muted);background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:3px;padding:1px 6px}.inventory-item-subcat{font-family:var(--font-ui);font-size:.62rem;color:var(--text-faint);margin:2px 0;text-transform:capitalize}.inventory-item-desc{font-family:var(--font-ui);font-size:.7rem;color:var(--text-muted);margin:4px 0 0;line-height:1.4}.inventory-item-equipped{border-color:#c9a84c4d;background:#c9a84c0a}.additem-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;display:flex;align-items:center;justify-content:center;z-index:1000}.additem-popup{background:linear-gradient(160deg,#1a1108,#0e0a04);border:1px solid var(--border-gold);border-radius:12px;padding:0;max-width:680px;width:95%;max-height:68vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #0009,inset 0 1px #c9a84c1a;animation:slideUp .25s ease}.additem-header{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border-gold)}.additem-title{font-family:var(--font-heading);font-size:1rem;color:var(--gold);margin:0}.additem-close{margin-left:auto;background:none;border:none;color:var(--text-faint);font-size:1.4rem;cursor:pointer;padding:4px 8px;line-height:1}.additem-close:hover{color:var(--text-primary)}.additem-filters{display:flex;gap:8px;padding:10px 16px;border-bottom:1px solid rgba(201,168,76,.1);flex-wrap:wrap}.additem-search{flex:1;min-width:120px;background:#ffffff0a;border:1px solid var(--border-stone);border-radius:4px;color:var(--text-primary);font-family:var(--font-ui);font-size:.78rem;padding:6px 10px;outline:none}.additem-search:focus{border-color:var(--gold-dim, #6b5a2e)}.additem-search::placeholder{color:var(--text-faint)}.additem-select{background:#ffffff0a;border:1px solid var(--border-stone);border-radius:4px;color:var(--text-primary);font-family:var(--font-ui);font-size:.72rem;padding:6px 8px;outline:none}.additem-list{overflow-y:auto;padding:8px 16px 16px;display:flex;flex-direction:column;gap:4px}.additem-row{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#ffffff05;border:1px solid var(--border-stone);border-radius:4px;transition:border-color .15s}.additem-row:hover{border-color:var(--gold-dim, #6b5a2e)}.additem-row-name{font-family:var(--font-heading);font-size:.78rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.additem-row-cat{font-family:var(--font-ui);font-size:.6rem;color:var(--text-faint);text-transform:capitalize;flex-shrink:0}.additem-row-stats{font-family:var(--font-ui);font-size:.65rem;color:var(--text-faint);flex-shrink:0;white-space:nowrap}.additem-row-add{font-size:.8rem;padding:3px 10px;flex-shrink:0}.additem-empty{font-family:var(--font-ui);font-size:.78rem;color:var(--text-faint);font-style:italic;text-align:center;padding:30px 20px}.game-settings-tab{flex:1;overflow-y:auto;padding:14px 16px}.settings-section-label{font-family:var(--font-ui);font-size:.65rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;margin:0 0 10px}.settings-toggle{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer;font-family:var(--font-ui);font-size:.78rem;color:var(--text-muted)}.settings-toggle input[type=checkbox]{accent-color:var(--gold, #c9a84c);width:16px;height:16px}.game-quests-tab{flex:1;overflow-y:auto;padding:10px 12px}.quest-empty{display:flex;align-items:center;justify-content:center;height:100%;padding:30px 20px}.quest-empty-text{font-family:var(--font-body);font-style:italic;font-size:.85rem;color:var(--text-faint);text-align:center;line-height:1.6}.quest-list{display:flex;flex-direction:column;gap:10px}.quest-card{background:#ffffff08;border:1px solid var(--border-stone);border-radius:var(--radius-md);padding:12px 14px;transition:border-color .15s}.quest-card:hover{border-color:var(--border-gold)}.quest-card.quest-done{opacity:.55}.quest-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.quest-type-badge{font-family:var(--font-heading);font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid;border-radius:3px;padding:1px 6px}.quest-status{font-family:var(--font-ui);font-size:.62rem;color:var(--text-faint);text-transform:capitalize}.quest-title{font-family:var(--font-heading);font-size:.85rem;color:var(--text-primary);margin:0 0 4px;line-height:1.3}.quest-description{font-family:var(--font-body);font-size:.72rem;color:var(--text-muted);margin:0 0 8px;line-height:1.5}.quest-progress-bar{height:3px;background:#ffffff14;border-radius:2px;margin-bottom:8px;overflow:hidden}.quest-progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .4s ease}.quest-objectives{list-style:none;margin:0 0 8px;padding:0;display:flex;flex-direction:column;gap:4px}.quest-obj{display:flex;align-items:flex-start;gap:6px;font-family:var(--font-body);font-size:.72rem;line-height:1.4;color:var(--text-muted)}.quest-obj-icon{flex-shrink:0;width:14px;text-align:center;font-size:.7rem;margin-top:1px}.quest-obj-completed .quest-obj-icon{color:var(--open-text)}.quest-obj-completed .quest-obj-text{text-decoration:line-through;opacity:.6}.quest-obj-failed .quest-obj-icon{color:#e05050}.quest-obj-failed .quest-obj-text{text-decoration:line-through;opacity:.5}.quest-obj-hidden .quest-obj-text{font-style:italic;color:var(--text-faint)}.quest-obj-text{flex:1}.quest-obj-optional{font-style:italic;color:var(--text-faint);font-size:.65rem}.quest-deadline{font-family:var(--font-ui);font-size:.62rem;color:#e0a060;margin:0 0 6px}.quest-actions{display:flex;gap:6px;margin-top:6px}.quest-action-btn{font-size:.7rem!important;padding:4px 12px!important}.quest-abandon-btn{color:#c07070!important;border-color:#c070704d!important}.quest-abandon-btn:hover{border-color:#c0707099!important}.quest-outcomes{margin-top:8px;display:flex;flex-direction:column;gap:4px}.quest-outcomes-label{font-family:var(--font-heading);font-size:.65rem;color:var(--gold);text-transform:uppercase;letter-spacing:.06em;margin:0 0 4px}.quest-outcome-btn{font-size:.7rem!important;padding:6px 10px!important;text-align:left!important;white-space:normal!important;line-height:1.4!important}.quest-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;font-size:.55rem;font-weight:700;background:var(--gold);color:#000;border-radius:8px;margin-left:5px;padding:0 4px}.quest-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.quest-popup{background:linear-gradient(160deg,#1a1108,#0e0a04);border:1px solid var(--border-gold);border-radius:12px;padding:24px 28px;max-width:420px;width:90%;box-shadow:0 8px 40px #0009,inset 0 1px #c9a84c1a;animation:slideUp .25s ease}.quest-popup-header{margin-bottom:8px}.quest-popup-badge{font-family:var(--font-heading);font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid;border-radius:3px;padding:2px 8px}.quest-popup-title{font-family:var(--font-heading);font-size:1.1rem;color:var(--text-primary);margin:0 0 8px;line-height:1.3}.quest-popup-desc{font-family:var(--font-body);font-size:.82rem;color:var(--text-muted);margin:0 0 10px;line-height:1.55}.quest-popup-hook{font-family:var(--font-body);font-style:italic;font-size:.8rem;color:var(--gold);margin:0 0 12px;padding:8px 12px;background:#c9a84c0f;border-left:2px solid var(--gold-dim);border-radius:0 4px 4px 0;line-height:1.5}.quest-popup-initiator{font-family:var(--font-body);font-size:.82rem;color:#e0a060;margin:0 0 10px;line-height:1.5}.quest-popup-objectives{margin-bottom:12px}.quest-popup-section-label{font-family:var(--font-heading);font-size:.62rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em;margin:0 0 6px}.quest-popup-objectives ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}.quest-popup-objectives li{font-family:var(--font-body);font-size:.78rem;color:var(--text-muted);padding-left:14px;position:relative;line-height:1.4}.quest-popup-objectives li:before{content:"○";position:absolute;left:0;color:var(--text-faint);font-size:.65rem;top:2px}.quest-popup-obj-hidden{font-style:italic;color:var(--text-faint)!important}.quest-popup-warning{font-family:var(--font-body);font-size:.75rem;color:#e07070;background:#e0505014;border:1px solid rgba(224,80,80,.2);border-radius:6px;padding:8px 12px;margin-bottom:12px;line-height:1.5}.quest-popup-votes{margin-bottom:16px}.quest-popup-vote-list{display:flex;flex-direction:column;gap:4px}.quest-popup-vote-row{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:#ffffff08;border-radius:4px}.quest-popup-vote-indicator{display:flex;align-items:center;gap:6px}.vote-icon{font-size:.7rem;line-height:1}.vote-icon--pending{color:var(--text-faint)}.vote-icon--yes{color:#4caf50}.vote-icon--no{color:#e05050}.quest-popup-vote-name{font-family:var(--font-ui);font-size:.72rem;color:var(--text-muted)}.quest-popup-vote-status{font-family:var(--font-heading);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.quest-popup-vote-pending{color:var(--text-faint)}.quest-popup-vote-accepted{color:var(--open-text)}.quest-popup-vote-declined,.quest-popup-vote-abandon{color:#e05050}.quest-popup-vote-keep,.quest-popup-vote-yes{color:var(--open-text)}.quest-popup-vote-no{color:#e05050}.quest-popup-actions{display:flex;gap:8px}.quest-popup-btn{flex:1;font-size:.8rem!important;padding:8px 16px!important}.quest-popup-abandon-btn{color:#e07070!important;border-color:#e0505059!important}.quest-popup-abandon-btn:hover{border-color:#e0505099!important;background:#e0505014!important}.vote-popup-btn--danger{color:#e07070!important;border-color:#e0505059!important}.vote-popup-btn--danger:hover{border-color:#e0505099!important;background:#e0505014!important}.combat-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.combat-confirm-popup{background:linear-gradient(160deg,#1a0808,#0e0404);border:1px solid var(--crimson);border-radius:12px;padding:24px 28px;max-width:380px;width:90%;box-shadow:0 8px 40px #b428284d,inset 0 1px #c83c3c26;animation:slideUp .25s ease;text-align:center}.combat-confirm-icon{font-size:2.5rem;margin-bottom:8px;filter:drop-shadow(0 0 8px rgba(200,60,60,.5))}.combat-confirm-title{font-family:var(--font-display);color:var(--crimson-bright);font-size:1.25rem;margin:0 0 8px}.combat-confirm-desc{color:var(--text-muted);font-size:.85rem;margin:0 0 12px}.combat-confirm-opponents{text-align:left;margin-bottom:12px}.combat-confirm-label{color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 4px}.combat-confirm-opponents ul{list-style:none;padding:0;margin:0}.combat-confirm-opponents li{color:var(--crimson-bright);font-size:.85rem;padding:2px 0}.combat-confirm-opponents li:before{content:"⚔️"}.combat-confirm-action{color:var(--text-faint);font-size:.8rem;margin:0 0 16px}.combat-confirm-action em{color:var(--text-muted)}.combat-confirm-actions{display:flex;gap:8px;justify-content:center}.combat-confirm-btn{flex:1;padding:8px 16px;font-size:.85rem}.btn-combat{background:linear-gradient(135deg,var(--crimson) 0%,#8b1a1a 100%);color:#fff;border:1px solid rgba(200,60,60,.5);border-radius:6px;cursor:pointer;font-family:var(--font-display);transition:all .15s ease}.btn-combat:hover{background:linear-gradient(135deg,var(--crimson-bright) 0%,var(--crimson) 100%);border-color:var(--crimson-bright);box-shadow:0 0 12px #c83c3c66}.vendor-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.vendor-popup{background:linear-gradient(160deg,#1a1108,#0e0a04);border:1px solid var(--border-gold);border-radius:12px;padding:0;max-width:680px;width:95%;max-height:68vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #0009,inset 0 1px #c9a84c1a;animation:slideUp .25s ease}.vendor-popup-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border-gold)}.vendor-popup-icon{font-size:2rem}.vendor-popup-shop-name{font-family:var(--font-heading);font-size:1.25rem;color:var(--gold);margin:0;text-transform:capitalize}.vendor-popup-vendor-name{font-family:var(--font-ui);font-size:.9rem;color:var(--text-muted);margin:0}.vendor-popup-close{margin-left:auto;background:none;border:none;color:var(--text-faint);font-size:1.4rem;cursor:pointer;padding:4px 8px;line-height:1}.vendor-popup-close:hover{color:var(--text-primary)}.vendor-popup-gold-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 20px;background:#c9a84c0f;font-family:var(--font-ui);font-size:.85rem;color:var(--gold);border-bottom:1px solid rgba(201,168,76,.1)}.vendor-popup-price-label{font-size:.75rem;color:var(--text-faint);background:#c9a84c1a;padding:2px 8px;border-radius:4px}.vendor-popup-count{font-size:.72rem;color:var(--text-faint)}.vendor-popup-inventory{overflow-y:auto;padding:8px 16px 16px;display:flex;flex-direction:column;gap:2px}.vendor-popup-buy-btn{font-size:.78rem!important;padding:4px 12px!important;min-width:48px}.vendor-category{margin-bottom:6px}.vendor-category-header{display:flex;align-items:center;gap:6px;padding:6px 4px 4px;border-bottom:1px solid rgba(201,168,76,.15);margin-bottom:4px}.vendor-category-icon{font-size:1rem}.vendor-category-label{font-family:var(--font-heading);font-size:.8rem;color:var(--gold);text-transform:uppercase;letter-spacing:.06em}.vendor-category-count{font-family:var(--font-ui);font-size:.7rem;color:var(--text-faint);background:#ffffff0d;padding:1px 6px;border-radius:8px}.vendor-col-headers{display:flex;align-items:center;gap:8px;padding:4px 16px;font-family:var(--font-ui);font-size:.65rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid rgba(255,255,255,.04)}.vendor-col-name{flex:1;min-width:120px}.vendor-col-stats{width:150px;text-align:left}.vendor-col-stock{width:42px;text-align:center}.vendor-col-price{width:65px;text-align:right}.vendor-col-actions{width:90px}.vendor-item-card{background:#ffffff05;border-radius:4px;border-left:3px solid transparent;margin-bottom:1px;transition:background .15s}.vendor-item-card:hover{background:#ffffff0d}.vendor-item-main{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 8px}.vendor-item-name-col{flex:1;min-width:120px;display:flex;align-items:center;gap:6px}.vendor-item-name{font-family:var(--font-body);font-size:.85rem;white-space:nowrap}.vendor-item-rarity-badge{font-family:var(--font-ui);font-size:.6rem;text-transform:uppercase;letter-spacing:.04em;padding:1px 5px;border-radius:3px;white-space:nowrap;flex-shrink:0}.vendor-item-stats-col{width:150px;display:flex;align-items:center;gap:6px;justify-content:flex-start}.vendor-item-stat{font-family:var(--font-ui);font-size:.75rem;color:var(--text-muted);white-space:nowrap}.vendor-item-stat-dim{font-family:var(--font-ui);font-size:.7rem;color:var(--text-faint);white-space:nowrap}.vendor-item-stock-col{width:42px;display:flex;flex-direction:column;align-items:center}.vendor-item-stock-num{font-family:var(--font-heading);font-size:.85rem;color:var(--text-muted)}.vendor-item-stock-label{font-family:var(--font-ui);font-size:.55rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.vendor-item-price{width:65px;font-family:var(--font-heading);font-size:.85rem;color:var(--gold);text-align:right;flex-shrink:0}.vendor-item-info-btn{background:#c9a84c1a;border:1px solid rgba(201,168,76,.2);color:var(--gold-dim);font-size:.7rem;font-family:var(--font-ui);width:22px;height:22px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.vendor-item-info-btn:hover{background:#c9a84c33;color:var(--gold)}.vendor-item-info-spacer{width:22px;flex-shrink:0}.vendor-item-details{padding:4px 10px 8px 8px;border-top:1px solid rgba(255,255,255,.04)}.vendor-item-props{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}.vendor-item-prop-tag{font-family:var(--font-ui);font-size:.7rem;color:var(--text-muted);background:#c9a84c14;padding:2px 6px;border-radius:3px;border:1px solid rgba(201,168,76,.12)}.vendor-item-subcat{font-family:var(--font-ui);font-size:.75rem;color:var(--text-faint);font-style:italic;margin:2px 0}.vendor-item-desc{font-family:var(--font-body);font-size:.8rem;color:var(--text-muted);line-height:1.45;margin:4px 0 0}.rarity-common{color:#aaa}.rarity-uncommon{color:#4caf50}.rarity-rare{color:#42a5f5}.rarity-very_rare{color:#ab47bc}.rarity-legendary{color:#ffa726}.rarity-border-common{border-left-color:#555}.rarity-border-uncommon{border-left-color:#4caf50}.rarity-border-rare{border-left-color:#42a5f5}.rarity-border-very_rare{border-left-color:#ab47bc}.rarity-border-legendary{border-left-color:#ffa726}.rarity-bg-common{color:#888;background:#aaaaaa1a}.rarity-bg-uncommon{color:#4caf50;background:#4caf501a}.rarity-bg-rare{color:#42a5f5;background:#42a5f51a}.rarity-bg-very_rare{color:#ab47bc;background:#ab47bc1a}.rarity-bg-legendary{color:#ffa726;background:#ffa7261a}.game-vendor-clickable{transition:background .15s}.game-vendor-clickable:hover{background:#c9a84c14!important}.game-placeholder-tab{padding:14px}.game-tab-title{font-family:var(--font-heading);font-size:.85rem;color:var(--gold);margin-bottom:10px;text-transform:uppercase;letter-spacing:.08em}.game-tab-empty{font-family:var(--font-body);font-style:italic;font-size:.82rem;color:var(--text-faint)}.game-msg{padding:8px 14px;border-bottom:1px solid rgba(255,255,255,.03)}.game-msg:last-child{border-bottom:none}.game-msg-label{font-family:var(--font-heading);font-size:.68rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;display:block;margin-bottom:3px}.game-msg-player .game-msg-label{color:var(--gold)}.game-msg-player.game-msg-player-other .game-msg-label{color:#7fc99a}.game-msg-dm .game-msg-label{color:#a78bfa}.game-msg-player p,.game-msg-dm p{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.88rem;color:#e0e0e0;line-height:1.65;margin:0;white-space:pre-wrap}.game-msg-dm p{color:#ccc}.game-msg-system{font-family:var(--font-ui);font-size:.72rem;color:var(--text-faint);font-style:italic;display:flex;align-items:center}.game-msg-system p{margin:0}.game-msg-dice{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#c9a84c14;border:1px solid rgba(201,168,76,.2);border-radius:6px;margin:2px 0}.dice-msg-icon{font-size:1.1rem;flex-shrink:0}.dice-msg-body{display:flex;flex-wrap:wrap;align-items:baseline;gap:4px;font-family:var(--font-ui);font-size:.76rem}.dice-msg-name{color:var(--gold);font-weight:700}.dice-msg-notation{color:var(--text-muted)}.dice-msg-rolls{color:var(--text-faint);font-size:.7rem}.dice-msg-eq{color:var(--text-faint)}.dice-msg-total{color:#fff;font-family:var(--font-heading);font-size:1rem;font-weight:700;background:#c9a84c26;padding:1px 8px;border-radius:4px;border:1px solid rgba(201,168,76,.3)}.dice-msg-label{color:var(--text-faint);font-style:italic;font-size:.68rem}.game-charbar{height:72px;flex-shrink:0;border-top:1px solid var(--border-gold);background:var(--bg-nav);display:flex;align-items:center;gap:8px;padding:0 16px;overflow-x:auto}.game-charbar-empty{font-family:var(--font-body);font-style:italic;font-size:.8rem;color:var(--text-faint)}.game-charbar-card{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#ffffff08;border:1px solid var(--border-stone);border-radius:6px;flex-shrink:0;transition:border-color .15s}.game-charbar-card:hover{border-color:var(--border-gold)}.game-charbar-icon{font-size:1.4rem;line-height:1}.game-charbar-info{display:flex;flex-direction:column;gap:1px}.game-charbar-name{font-family:var(--font-heading);font-size:.78rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.game-charbar-player{font-family:var(--font-ui);font-size:.65rem;color:var(--text-faint);white-space:nowrap}.game-toast{position:fixed;top:60px;left:50%;transform:translate(-50%);z-index:200;animation:slideDown .3s ease forwards}.game-toast-inner{display:flex;align-items:center;gap:10px;background:#0e0a06f2;border:1px solid var(--border-gold);border-radius:8px;padding:14px 24px;box-shadow:0 8px 32px #0009;font-family:var(--font-body);font-size:.92rem;color:var(--gold-bright)}.game-toast-icon{font-size:1.2rem}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.map-viewer{position:relative;width:100%;height:100%;background:#0a0e14;border-radius:6px;overflow:hidden;display:flex;flex-direction:column}.map-viewer--empty{align-items:center;justify-content:center;color:var(--text-muted);font-family:var(--font-body)}.map-viewer-viewport{flex:1;position:relative;overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none}.map-viewer-inner{will-change:transform}.map-pin{position:absolute}.map-pin--hidden .map-pin-marker{opacity:.5;filter:grayscale(.6)}.map-pin-marker--unvisited{opacity:.6}.map-pin-marker{position:relative;width:32px;height:32px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2px solid #8ab4f8;background:#0a0e14d9;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0009;transition:border-color .2s}.map-pin-marker:hover{filter:brightness(1.2)}.map-pin-marker--current{border-color:var(--gold-bright, #f4c447)!important;background:#f4c44726}.map-pin-icon{transform:rotate(45deg);font-size:13px;line-height:1}.map-pin-pulse{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:2px solid var(--gold-bright, #f4c447);animation:pinPulse 1.8s ease-out infinite;pointer-events:none}@keyframes pinPulse{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(1.8)}}.map-pin-tooltip-vendors{display:flex;gap:6px;margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap}.map-pin-vendor-icon{font-size:1rem;cursor:default;filter:drop-shadow(0 1px 1px rgba(0,0,0,.5))}.map-pin-tooltip-quest-sources{display:flex;gap:6px;margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap}.map-pin-quest-source-icon{font-size:1rem;cursor:default;filter:drop-shadow(0 1px 1px rgba(0,0,0,.5))}.map-pin-quest-source-icon--clickable{cursor:pointer;transition:transform .1s}.map-pin-quest-source-icon--clickable:hover{transform:scale(1.2)}.map-pin-quest-badge{position:absolute;top:-8px;right:-10px;font-size:.85rem;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.8));pointer-events:none;z-index:3}.map-pin--waypoint .map-pin-marker{border-color:var(--gold, #c9a84c)}.map-pin-tooltip{position:absolute;bottom:44px;left:50%;transform:translate(-50%);background:#0e0a06f5;border:1px solid var(--border-gold, #6b5a2e);border-radius:8px;padding:10px 12px;min-width:180px;max-width:240px;box-shadow:0 6px 24px #000000b3;z-index:100;pointer-events:auto}.map-pin-tooltip-close{position:absolute;top:4px;right:6px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;line-height:1;padding:0}.map-pin-tooltip-close:hover{color:var(--gold-bright)}.map-pin-here-badge{font-size:.7rem;color:var(--gold-bright, #f4c447);font-family:var(--font-body);margin-right:4px}.map-pin-tooltip-name{font-family:var(--font-display, "Cinzel", serif);font-size:.95rem;color:var(--gold-bright, #f4c447);margin-bottom:2px;padding-right:14px}.map-pin-tooltip-type{font-family:var(--font-body);font-size:.75rem;text-transform:capitalize;margin-bottom:6px}.map-pin-tooltip-desc{font-family:var(--font-body);font-size:.8rem;color:var(--text-muted);margin:0 0 6px;line-height:1.4}.map-pin-tooltip-landmarks{font-family:var(--font-body);font-size:.75rem;color:#aaa}.map-pin-tooltip-label{color:var(--text-muted)}.map-pin-tooltip-unknown{font-family:var(--font-body);font-size:.75rem;color:#666;font-style:italic;margin:4px 0 0}.map-viewer-controls{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;gap:4px;z-index:30}.map-ctrl-btn{width:30px;height:30px;background:#0e0a06d9;border:1px solid var(--border-gold, #6b5a2e);border-radius:4px;color:var(--gold-bright, #f4c447);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.map-ctrl-btn:hover{background:#f4c44726}.map-viewer-legend{position:absolute;bottom:12px;left:12px;display:flex;flex-direction:column;gap:6px;z-index:30;background:#0e0a06d9;border:1px solid var(--border-gold, #6b5a2e);border-radius:6px;padding:10px 14px;min-width:120px}.map-legend-item{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.75rem;font-weight:500;color:#ccc;white-space:nowrap;line-height:1.5;letter-spacing:.01em}.map-legend-current{color:var(--gold-bright, #f4c447)}.char-profile-tab{flex:1;overflow-y:auto;padding:12px 14px}.char-profile-empty{display:flex;align-items:center;justify-content:center;height:100%;padding:30px 20px}.char-profile-empty p{font-family:var(--font-body);font-style:italic;font-size:.85rem;color:var(--text-faint);text-align:center}.char-profile-header{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:12px;position:relative}.char-profile-avatar{width:48px;height:56px;flex-shrink:0;color:#ffffff26}.char-profile-silhouette{width:100%;height:100%}.char-profile-identity{flex:1;min-width:0}.char-profile-name{font-family:var(--font-heading);font-size:1rem;color:var(--gold, #c9a84c);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.char-profile-subtitle{font-family:var(--font-ui);font-size:.72rem;color:var(--text-muted);margin-top:2px}.char-profile-pb{font-family:var(--font-ui);font-size:.65rem;color:var(--text-faint);margin-top:2px}.char-profile-lock-btn{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:4px;border-radius:4px;transition:background .15s;flex-shrink:0}.char-profile-lock-btn:hover{background:#ffffff0f}.char-profile-section{margin-bottom:14px}.char-profile-section-label{font-family:var(--font-ui);font-size:.62rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.char-profile-hp-row{display:flex;align-items:center;gap:8px}.char-profile-adj-btn{width:28px;height:28px;border-radius:4px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--text-muted);font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;flex-shrink:0}.char-profile-adj-btn:hover:not(:disabled){background:#ffffff14;border-color:#fff3}.char-profile-adj-btn:disabled{opacity:.3;cursor:not-allowed}.char-profile-hp-display{flex:1;position:relative;height:24px}.char-profile-hp-bar-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff0f;border-radius:4px;overflow:hidden}.char-profile-hp-bar-fill{height:100%;border-radius:4px;transition:width .3s ease,background .3s ease}.char-profile-hp-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:.72rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.char-profile-temp-hp-value{font-family:var(--font-ui);font-size:.85rem;font-weight:600;color:#8ab4f8;min-width:32px;text-align:center}.char-profile-combat-row{display:flex;gap:8px}.char-profile-combat-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;background:#ffffff08;border-radius:6px;border:1px solid rgba(255,255,255,.05)}.char-profile-combat-icon{font-size:.9rem}.char-profile-combat-label{font-family:var(--font-ui);font-size:.6rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.char-profile-combat-value{font-family:var(--font-ui);font-size:.85rem;font-weight:600;color:var(--text-primary, #e8e0d0)}.char-profile-stat-input{width:48px;text-align:center;font-family:var(--font-ui);font-size:.8rem;font-weight:600;color:var(--text-primary, #e8e0d0);background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:2px 4px}.char-profile-stat-input:focus{outline:none;border-color:var(--gold, #c9a84c)}.char-profile-abilities{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.char-profile-ability{display:flex;flex-direction:column;align-items:center;gap:1px;padding:6px 4px;background:#ffffff08;border-radius:6px;border:1px solid rgba(255,255,255,.05)}.char-profile-ability-label{font-family:var(--font-ui);font-size:.58rem;font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em}.char-profile-ability-score{font-family:var(--font-ui);font-size:.9rem;font-weight:700;color:var(--text-primary, #e8e0d0)}.char-profile-ability-input{width:40px;text-align:center;font-family:var(--font-ui);font-size:.85rem;font-weight:700;color:var(--text-primary, #e8e0d0);background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:2px}.char-profile-ability-input:focus{outline:none;border-color:var(--gold, #c9a84c)}.char-profile-ability-mod{font-family:var(--font-ui);font-size:.65rem;color:var(--gold-dim, #a08430);font-weight:600}.char-profile-derived-row{display:flex;gap:10px}.char-profile-derived-stat{flex:1;display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#ffffff08;border-radius:4px}.char-profile-derived-label{font-family:var(--font-ui);font-size:.68rem;color:var(--text-muted)}.char-profile-derived-value{font-family:var(--font-ui);font-size:.8rem;font-weight:600;color:var(--text-primary, #e8e0d0)}.char-profile-bio{font-family:var(--font-body);font-size:.75rem;color:var(--text-muted);line-height:1.5;margin:0;font-style:italic}
