:root{--bg-primary: #04060f;--bg-secondary: #0a1022;--bg-tertiary: #121c38;--bg-slate: #2a3548;--accent-gold: #ffcc00;--accent-gold-bright: #ffd700;--accent-gold-dim: #cd9b4a;--accent-cyan: #00ffff;--accent-cyan-soft: #40e0d0;--accent-blue: #00d4ff;--accent-red: #e85d5d;--accent-green: #40e0d0;--text-primary: #f0ece4;--text-secondary: #8a9bb5;--glass: rgba(8, 14, 30, .82);--glass-border: rgba(255, 204, 0, .28);--glass-border-cyan: rgba(0, 255, 255, .22);--glow-gold: 0 0 20px rgba(255, 204, 0, .45), 0 0 40px rgba(255, 204, 0, .15);--glow-cyan: 0 0 18px rgba(0, 255, 255, .35), 0 0 36px rgba(64, 224, 208, .12);--glow-text-gold: 0 0 12px rgba(255, 204, 0, .7), 0 0 24px rgba(255, 204, 0, .3);--font-fantasy: "Cinzel", Georgia, serif;--font-body: "Crimson Pro", Georgia, serif}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;height:100dvh;width:100%;overflow:hidden}body{font-family:var(--font-body);background:var(--bg-primary);background-image:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(0,255,255,.06) 0%,transparent 55%),radial-gradient(ellipse 60% 50% at 80% 80%,rgba(255,204,0,.05) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 10% 60%,rgba(64,224,208,.04) 0%,transparent 45%),linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 45%,#060a14 100%);background-attachment:fixed;color:var(--text-primary);overflow:hidden;overscroll-behavior:none;-webkit-text-size-adjust:100%}#particles-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.particle{position:absolute;border-radius:50%;animation:float-particle linear infinite;opacity:.75;box-shadow:0 0 6px currentColor}.particle--gold{color:#fc0c;background:var(--accent-gold)}.particle--cyan{color:#00ffffb3;background:var(--accent-cyan-soft)}.particle--star{color:#ffffffe6;background:#fff}h1,h2,h3,.fantasy-title{font-family:var(--font-fantasy)}button{font-family:var(--font-body);cursor:pointer}input,textarea{font-family:var(--font-body)}.screen{position:relative;z-index:1;height:100%;height:100dvh;width:100%;overflow:hidden}.glass-panel{background:var(--glass);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--glass-border);border-radius:16px;box-shadow:inset 0 1px #ffcc000f,0 4px 24px #0006}.btn-primary{padding:14px 32px;background:linear-gradient(135deg,var(--accent-gold-bright) 0%,var(--accent-gold) 50%,var(--accent-gold-dim) 100%);border:1px solid rgba(255,220,80,.5);border-radius:12px;color:#0a0810;font-weight:700;font-size:1.1rem;transition:all .3s ease;font-family:var(--font-fantasy);box-shadow:var(--glow-gold);text-shadow:0 1px 0 rgba(255,255,255,.2)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 28px #ffcc00a6,0 0 50px #ffcc0040}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.45;box-shadow:none;cursor:not-allowed}.btn-secondary{padding:10px 20px;background:#00ffff14;border:1px solid var(--glass-border-cyan);border-radius:10px;color:var(--text-primary);transition:all .3s}.btn-secondary:hover{background:#00ffff29;box-shadow:var(--glow-cyan)}.stat-bar{width:100%;height:28px;background:#0000008c;border-radius:14px;overflow:hidden;position:relative;border:1px solid rgba(255,204,0,.12)}.stat-bar-fill{height:100%;transition:width .6s ease;position:relative}.hp-bar .stat-bar-fill{background:linear-gradient(90deg,#c0392b,#e85d5d);box-shadow:0 0 14px #e85d5d80}.xp-bar .stat-bar-fill{background:linear-gradient(90deg,var(--accent-gold-dim),var(--accent-gold-bright));box-shadow:var(--glow-gold)}.stat-bar-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;text-shadow:0 1px 4px rgba(0,0,0,.9);z-index:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#04060fe0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}.modal-content{max-width:500px;width:100%;max-height:80vh;overflow-y:auto;padding:24px}.loading-spinner{width:48px;height:48px;border:3px solid rgba(255,204,0,.15);border-top-color:var(--accent-gold);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.btn-primary{padding:12px 24px;font-size:1rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes glow{0%,to{box-shadow:0 0 16px #fc06,0 0 32px #00ffff26}50%{box-shadow:0 0 32px #ffcc00b3,0 0 48px #00ffff40}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}@keyframes pulse-hp{0%,to{filter:brightness(1)}50%{filter:brightness(1.4)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float-particle{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:.7}90%{opacity:.7}to{transform:translateY(-10vh) scale(1);opacity:0}}@keyframes dice-roll{0%{transform:rotateX(0) rotateY(0) rotate(0)}25%{transform:rotateX(180deg) rotateY(90deg) rotate(45deg)}50%{transform:rotateX(360deg) rotateY(180deg) rotate(90deg)}75%{transform:rotateX(540deg) rotateY(270deg) rotate(135deg)}to{transform:rotateX(720deg) rotateY(360deg) rotate(180deg)}}@keyframes typewriter-cursor{0%,to{opacity:1}50%{opacity:0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-glow{animation:glow 2s ease-in-out infinite}.animate-shake{animation:shake .5s ease-in-out}.animate-slide-up{animation:slideInUp .4s ease forwards}.animate-scale-in{animation:scaleIn .35s ease forwards}.animate-pulse-hp{animation:pulse-hp .6s ease 2}.dice-rolling{animation:dice-roll .8s ease-in-out}.typewriter-cursor:after{content:"|";animation:typewriter-cursor .8s step-end infinite;color:var(--accent-gold)}.splash-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:24px}.splash-logo-wrap{margin-bottom:20px;border-radius:50%;padding:8px;border:2px solid rgba(255,204,0,.35);box-shadow:var(--glow-gold),var(--glow-cyan)}.splash-logo-img{width:clamp(140px,40vw,220px);height:clamp(140px,40vw,220px);object-fit:cover;border-radius:50%;display:block}.splash-logo{font-family:var(--font-fantasy);font-size:clamp(1.8rem,6vw,3.2rem);color:var(--accent-gold-bright);text-shadow:var(--glow-text-gold);margin-bottom:8px;letter-spacing:.08em}.splash-subtitle{font-size:1.1rem;color:var(--accent-cyan-soft);font-style:italic;margin-bottom:48px;text-shadow:0 0 12px rgba(64,224,208,.4)}.splash-rune{font-size:4rem;margin-bottom:32px;filter:drop-shadow(0 0 20px rgba(0,255,255,.5))}.char-create-screen{display:flex;flex-direction:column;height:100%;max-width:900px;margin:0 auto}.char-create-scroll{flex:1;overflow-y:auto;padding:20px 20px 12px;-webkit-overflow-scrolling:touch}.char-create-scroll h2{text-align:center;color:var(--accent-gold);margin-bottom:20px;font-size:1.8rem}.create-section{margin-bottom:22px}.section-title{color:var(--accent-gold);font-family:var(--font-fantasy);font-size:1rem;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.points-badge{font-size:.85rem;padding:4px 12px;border-radius:20px;background:#00ffff1a;color:var(--accent-cyan-soft);font-family:var(--font-body);border:1px solid var(--glass-border-cyan)}.points-badge.ready{background:#ffcc001f;color:var(--accent-gold-bright);border-color:#ffcc0059}.option-row{display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}.option-row.wrap{flex-wrap:wrap;overflow-x:visible}.option-chip{padding:10px 14px;border-radius:10px;border:1px solid rgba(255,215,0,.25);background:#00000040;color:var(--text-primary);font-size:.9rem;white-space:nowrap;transition:all .2s;flex-shrink:0}.option-chip:hover{border-color:#ffd70080}.option-chip.active{border-color:var(--accent-gold-bright);background:#ffcc001f;box-shadow:var(--glow-gold)}.option-hint{font-size:.85rem;color:var(--text-secondary);margin-top:8px;font-style:italic}.class-details{padding:14px;margin-top:12px}.class-role{color:var(--accent-blue);font-size:.9rem;margin-bottom:8px}.ability-list{list-style:none;font-size:.85rem;color:var(--text-secondary)}.ability-list li{margin-bottom:4px}.char-create-footer{flex-shrink:0;padding:16px 20px;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:0 -8px 30px #0006;z-index:10}.footer-preview{display:flex;align-items:center;gap:12px;width:100%}.footer-avatar{font-size:2.5rem}.footer-info{display:flex;flex-direction:column;gap:2px;font-size:.85rem}.footer-info strong{color:var(--accent-gold);font-family:var(--font-fantasy)}.footer-info span{color:var(--text-secondary)}.btn-start-game{width:100%;max-width:400px;font-size:1.2rem;padding:16px 32px}.footer-hint{font-size:.85rem;color:var(--accent-red);text-align:center}.char-create{height:100%;overflow-y:auto;padding:20px;max-width:900px;margin:0 auto}.char-create h2{text-align:center;color:var(--accent-gold);margin-bottom:24px;font-size:1.8rem}.class-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:28px}.class-card{padding:20px;text-align:center;cursor:pointer;transition:all .3s;border:2px solid transparent}.class-card.selected{border-color:var(--accent-gold-bright);box-shadow:var(--glow-gold),inset 0 0 20px #ffcc0014}.class-card:hover{transform:translateY(-4px);border-color:#00ffff59;box-shadow:var(--glow-cyan)}.class-card-icon{font-size:3rem;margin-bottom:8px}.class-card-name{font-family:var(--font-fantasy);font-size:1.2rem;color:var(--accent-gold);margin-bottom:6px}.class-card-desc{font-size:.85rem;color:var(--text-secondary)}.name-input{width:100%;padding:14px 18px;background:#00000059;border:1px solid var(--glass-border);border-radius:12px;color:var(--text-primary);font-size:1.1rem;margin-bottom:24px;outline:none;transition:border-color .3s}.name-input:focus{border-color:var(--accent-gold);box-shadow:0 0 12px #ffd70033}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}.stat-item{padding:14px;text-align:center}.stat-item-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:4px}.stat-item-value{font-size:1.8rem;font-weight:700;color:var(--accent-gold);font-family:var(--font-fantasy)}.stat-item-mod{font-size:.9rem;color:var(--accent-blue)}.stat-controls{display:flex;justify-content:center;gap:8px;margin-top:8px}.stat-btn{width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,215,0,.3);background:#ffd7001a;color:var(--accent-gold);font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.stat-btn:hover:not(:disabled){background:#ffd70040}.stat-btn:disabled{opacity:.3;cursor:not-allowed}.points-remaining{text-align:center;color:var(--accent-blue);margin-bottom:20px;font-size:1rem}.char-preview{padding:20px;margin-bottom:24px;text-align:center}.char-preview-avatar{font-size:4rem;margin-bottom:8px}.game-layout{display:flex;height:100%}.character-panel{padding:16px;flex-direction:column;gap:16px;overflow-y:auto}.character-avatar{aspect-ratio:1;border-radius:50%;border:3px solid var(--accent-gold-dim);box-shadow:var(--glow-gold),var(--glow-cyan);display:flex;align-items:center;justify-content:center;font-size:4rem;background:radial-gradient(circle,#121c38e6,#04060ff2)}.char-name{font-family:var(--font-fantasy);text-align:center;color:var(--accent-gold);font-size:1.1rem}.char-class{text-align:center;color:var(--text-secondary);font-size:.9rem}.panel-btns{display:flex;flex-direction:column;gap:8px}.panel-btn{padding:10px;text-align:left;font-size:.9rem}.char-gold{text-align:center;color:var(--accent-gold)}.chat-area{display:flex;flex-direction:column;min-width:0}.chat-header{padding:16px 20px;border-bottom:1px solid var(--glass-border);text-align:center;background:var(--glass)}.chat-header h1{color:var(--accent-gold);font-size:1.3rem;text-shadow:0 0 10px rgba(255,215,0,.4)}.chat-location{font-size:.85rem;color:var(--text-secondary);margin-top:4px}.chat-window{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-window::-webkit-scrollbar{width:6px}.chat-window::-webkit-scrollbar-track{background:#0003}.chat-window::-webkit-scrollbar-thumb{background:var(--accent-gold);border-radius:3px}.message{max-width:85%;padding:14px 16px;border-radius:14px;animation:slideInUp .35s ease;line-height:1.6}.ai-message{align-self:flex-start;background:linear-gradient(135deg,#0a1022eb,#121c38e0);border:1px solid rgba(255,204,0,.22);box-shadow:inset 0 0 20px #00ffff08,0 4px 16px #00000059}.player-message{align-self:flex-end;background:linear-gradient(135deg,#00ffff1a,#40e0d014);border:1px solid var(--glass-border-cyan);box-shadow:var(--glow-cyan)}.message-time{font-size:.7rem;color:var(--text-secondary);margin-top:6px;text-align:right}.narrative{color:var(--text-primary);font-style:italic;margin-bottom:8px}.mechanic{color:var(--accent-gold-bright);font-weight:600;margin:8px 0;padding:10px;background:#ffcc000f;border-radius:8px;border-left:3px solid var(--accent-gold);text-shadow:0 0 8px rgba(255,204,0,.3)}.dialogue{color:var(--accent-cyan-soft);margin:8px 0;text-shadow:0 0 8px rgba(64,224,208,.25)}.combat{color:var(--accent-red);font-weight:600;margin:8px 0}.actions-section{margin-top:12px;color:var(--text-secondary)}.input-area{padding:16px;border-top:1px solid var(--glass-border);background:var(--glass)}.input-container{display:flex;gap:10px}.message-input{flex:1;padding:12px 16px;background:#00000059;border:1px solid var(--glass-border);border-radius:10px;color:var(--text-primary);font-size:1rem;outline:none;transition:all .3s}.message-input:focus{border-color:var(--accent-gold);box-shadow:0 0 10px #ffd70033}.send-btn{padding:12px 24px;background:linear-gradient(135deg,var(--accent-gold-bright),var(--accent-gold));border:1px solid rgba(255,204,0,.4);border-radius:10px;color:#0a0810;font-weight:700;transition:all .3s;box-shadow:var(--glow-gold)}.send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #ffd70066}.send-btn:disabled{opacity:.5;cursor:not-allowed}.action-panel{padding:16px;flex-direction:column;gap:12px;overflow-y:auto}.action-buttons{display:flex;flex-direction:column;gap:10px}.action-panel h3{color:var(--accent-gold);text-align:center;font-size:1rem;font-family:var(--font-fantasy)}.action-btn{padding:12px 14px;background:linear-gradient(135deg,#00ffff14,#40e0d00f);border:1px solid var(--glass-border-cyan);border-radius:10px;color:var(--text-primary);text-align:left;font-size:.9rem;transition:all .3s;animation:slideInRight .4s ease backwards}.action-btn:hover{background:linear-gradient(135deg,#00ffff2e,#40e0d01f);transform:translate(4px);box-shadow:var(--glow-cyan)}.quest-indicator{padding:12px;font-size:.85rem}.quest-indicator h4{color:var(--accent-gold);font-size:.9rem;margin-bottom:6px}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:12px}.inventory-item{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px;cursor:pointer;transition:all .3s;text-align:center}.inventory-item:hover{transform:scale(1.05);border-color:var(--accent-gold)}.inventory-item-icon{font-size:2rem}.inventory-item-name{font-size:.7rem;margin-top:4px;color:var(--text-secondary)}.inventory-filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.filter-btn{padding:6px 14px;border-radius:20px;font-size:.85rem;border:1px solid rgba(255,215,0,.3);background:transparent;color:var(--text-secondary);transition:all .2s}.filter-btn.active{background:#ffd70033;color:var(--accent-gold);border-color:var(--accent-gold)}.stats-display{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.stat-circle{text-align:center;padding:20px}.stat-circle-value{font-size:2.5rem;font-family:var(--font-fantasy);color:var(--accent-gold)}.stat-circle-mod{font-size:1.1rem;color:var(--accent-blue);margin-top:4px}.stat-circle-label{font-size:.9rem;color:var(--text-secondary);margin-top:8px}.dice-screen{text-align:center}.dice-display{font-size:5rem;margin:24px 0;display:inline-block}.dice-result{font-size:2rem;color:var(--accent-gold);font-family:var(--font-fantasy);margin:16px 0}.dice-buttons{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:24px}.dice-type-btn{padding:12px 20px;font-size:1.1rem;font-family:var(--font-fantasy)}.dice-history{text-align:left;max-height:200px;overflow-y:auto}.dice-history-item{padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.05);font-size:.9rem}.theme-dark{--bg-primary: #04060f;--bg-secondary: #0a1022}.theme-dungeon{--bg-primary: #0d0d0d;--bg-secondary: #1a0a0a;--accent-gold: #c9a227}.theme-forest{--bg-primary: #0a1a0f;--bg-secondary: #0f2a1a;--accent-gold: #8fbc8f}.crit-success{color:var(--accent-gold);text-shadow:0 0 15px rgba(255,215,0,.8);animation:glow 1s ease-in-out 3}.crit-fail{color:var(--accent-red);animation:shake .5s ease-in-out}.level-up-banner{background:linear-gradient(135deg,#ffd70033,#ff6b6b33);border:2px solid var(--accent-gold);border-radius:12px;padding:20px;text-align:center;animation:scaleIn .5s ease}.level-up-banner h3{color:var(--accent-gold);font-size:1.5rem;font-family:var(--font-fantasy)}.ai-typing{display:flex;align-items:center;gap:8px;padding:12px 16px;color:var(--text-secondary);font-style:italic}.typing-dots span{display:inline-block;width:6px;height:6px;background:var(--accent-gold);border-radius:50%;animation:typing-bounce 1.4s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-6px);opacity:1}}:root{--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--toolbar-h: 56px;--mobile-bar-h: 52px;--touch-min: 44px}.mobile-only{display:flex}.desktop-only{display:none}.game-layout{flex-direction:column;height:100dvh;height:100%;overflow:hidden}.mobile-char-bar{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:8px 12px;padding-top:calc(8px + var(--safe-top));border-radius:0;border-left:none;border-right:none;border-top:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.mobile-char-avatar{font-size:1.8rem;flex-shrink:0}.mobile-char-info{flex:1;min-width:0}.mobile-char-name{font-family:var(--font-fantasy);color:var(--accent-gold);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-char-lvl{color:var(--text-secondary);font-size:.75rem}.mobile-hp{height:18px;margin-top:4px}.mobile-hp .stat-bar-text{font-size:.7rem}.mobile-char-gold{color:var(--accent-gold);font-size:.85rem;flex-shrink:0}.chat-area{width:100%;flex:1;min-height:0;display:flex;flex-direction:column}.chat-header{padding:10px 14px;flex-shrink:0}.chat-header h1{font-size:1rem}.chat-location{font-size:.75rem}.chat-window{flex:1;min-height:0;padding:10px 12px;gap:10px}.message{max-width:92%;padding:10px 12px;font-size:.95rem;line-height:1.5}.mobile-actions-panel{flex-shrink:0;padding:8px 12px 4px;border-top:1px solid var(--glass-border);background:#080e1ebf}.mobile-actions-hint{font-size:.8rem;color:var(--text-secondary);text-align:center;padding:4px 0}.action-buttons--horizontal{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;padding-bottom:4px;scrollbar-width:none}.action-buttons--horizontal::-webkit-scrollbar{display:none}.action-buttons--horizontal .action-btn{flex-shrink:0;scroll-snap-align:start;min-height:var(--touch-min);padding:10px 14px;font-size:.85rem;white-space:nowrap;animation:none}.input-area{flex-shrink:0;padding:10px 12px}.input-container{gap:8px}.message-input{min-height:var(--touch-min);padding:10px 14px;font-size:16px}.send-btn{min-width:var(--touch-min);min-height:var(--touch-min);padding:0;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.mobile-toolbar{flex-shrink:0;display:flex;justify-content:space-around;align-items:center;height:calc(var(--toolbar-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--glass);border-top:1px solid var(--glass-border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.toolbar-btn{min-width:var(--touch-min);min-height:var(--touch-min);display:flex;align-items:center;justify-content:center;font-size:1.4rem;background:none;border:none;border-radius:12px;transition:background .2s;-webkit-tap-highlight-color:transparent}.toolbar-btn:active,.toolbar-btn.active{background:#ffcc001f;box-shadow:var(--glow-gold)}.mobile-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:500;display:flex;align-items:flex-end;padding-bottom:calc(var(--toolbar-h) + var(--safe-bottom))}.mobile-menu{width:100%;padding:20px;border-radius:16px 16px 0 0;animation:slideInUp .3s ease}.mobile-menu-quest{color:var(--accent-gold);font-size:.95rem;margin-bottom:8px}.mobile-menu-xp{color:var(--text-secondary);font-size:.85rem;margin-bottom:16px}.mobile-menu-close{width:100%;min-height:var(--touch-min)}.actions-empty{color:var(--text-secondary);font-size:.85rem;text-align:center}.char-create-screen{height:100dvh;height:100%}.char-create-scroll{padding:14px 14px 8px;padding-top:calc(14px + var(--safe-top))}.char-create-scroll h2{font-size:1.3rem;margin-bottom:14px}.create-section{margin-bottom:16px}.section-title{font-size:.9rem}.class-grid{grid-template-columns:repeat(2,1fr);gap:10px}.class-card{padding:12px 8px}.class-card-icon{font-size:2rem}.class-card-name{font-size:.95rem}.class-card-desc{font-size:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.stats-grid{grid-template-columns:repeat(3,1fr);gap:8px}.stat-item{padding:10px 6px}.stat-item-value{font-size:1.4rem}.stat-btn{width:36px;height:36px}.option-chip{min-height:var(--touch-min);padding:10px 12px}.char-create-footer{padding:12px 14px;padding-bottom:calc(12px + var(--safe-bottom))}.footer-preview{display:none}.btn-start-game{min-height:52px;font-size:1.1rem}.splash-screen{padding:20px;padding-top:calc(20px + var(--safe-top));padding-bottom:calc(20px + var(--safe-bottom))}.splash-logo{font-size:1.8rem}.splash-rune{font-size:3rem;margin-bottom:20px}.splash-subtitle{font-size:.95rem;margin-bottom:32px}.modal-overlay{padding:12px;padding-bottom:calc(12px + var(--safe-bottom));align-items:flex-end}.modal-content{max-height:85dvh;padding:18px;border-radius:16px 16px 0 0}.stats-display{grid-template-columns:repeat(2,1fr);gap:10px}.stat-circle{padding:14px 10px}.stat-circle-value{font-size:2rem}.inventory-grid{grid-template-columns:repeat(4,1fr);gap:8px}.dice-display{font-size:3.5rem}.dice-type-btn{min-height:var(--touch-min);min-width:56px}button,.btn-primary,.btn-secondary{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn-primary,.btn-secondary{min-height:var(--touch-min)}@media(min-width:769px){.mobile-only{display:none!important}.desktop-only{display:flex}.game-layout{flex-direction:row;max-width:1400px;margin:0 auto}.chat-area{width:60%;flex:1}.character-panel{width:20%;min-width:180px;display:flex;flex-direction:column;border-right:1px solid var(--glass-border)}.action-panel{width:20%;min-width:160px;display:flex;flex-direction:column;border-left:1px solid var(--glass-border)}.char-create-scroll{padding:20px}.class-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.footer-preview{display:flex}.modal-overlay{align-items:center;padding:20px}.modal-content{border-radius:16px;max-height:80vh}.stats-display{grid-template-columns:repeat(3,1fr)}}@media(max-width:360px){.stats-grid{grid-template-columns:repeat(2,1fr)}.class-grid{grid-template-columns:1fr 1fr}.message{font-size:.9rem}}@media(max-height:500px)and (orientation:landscape){.mobile-char-bar{padding:4px 12px}.chat-header{display:none}.splash-rune{font-size:2rem;margin-bottom:8px}.splash-subtitle{margin-bottom:16px}}
