:root{--bg-primary: #0d0c10;--bg-secondary: #141318;--bg-card: #1a1920;--bg-card-hover: #21202a;--bg-glass: rgba(26, 25, 32, .75);--border-gold: rgba(186, 160, 90, .4);--border-dim: rgba(255, 255, 255, .06);--text-primary: #ddd6c6;--text-secondary: #9a9080;--text-gold: #c4a650;--text-muted: #555060;--accent-red: #6e2818;--accent-blue: #1e3654;--accent-green: #2a4e24;--accent-hp: #3d8a38;--font-display: "Cinzel", "Georgia", serif;--font-body: "Nunito Sans", -apple-system, sans-serif;--navbar-height: 56px;--radius: 10px;--radius-sm: 6px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);font-size:14px;line-height:1.55;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden}body{background-image:radial-gradient(ellipse at 15% 50%,rgba(40,35,20,.3) 0%,transparent 55%),radial-gradient(ellipse at 85% 15%,rgba(30,20,10,.25) 0%,transparent 50%)}#root{height:100%}.app{display:flex;flex-direction:column;min-height:100%}.app-content{flex:1;padding-bottom:var(--navbar-height);overflow-y:auto}.page{padding:20px 16px;max-width:480px;margin:0 auto}.page-center{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}.page-header{text-align:center;margin-bottom:24px}.logo{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--text-gold);letter-spacing:6px;text-shadow:0 1px 8px rgba(180,140,40,.15);margin-bottom:0}.subtitle{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:4px;color:var(--text-muted);margin-top:4px}.page-title{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--text-gold);letter-spacing:1px}.greeting{text-align:center;margin-bottom:24px;padding:10px 16px;border-bottom:1px solid var(--border-dim)}.greeting-text{color:var(--text-muted);font-size:13px}.greeting-text strong{color:var(--text-secondary)}.home-page .home-header{padding-top:8px}.home-section-title{font-family:var(--font-display);font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px}.home-active-sessions{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.home-session-card{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:var(--bg-glass);border:1px solid var(--border-dim);border-radius:var(--radius);cursor:pointer;transition:all .15s;color:inherit;width:100%;text-align:left;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.home-session-card:active{border-color:var(--border-gold);transform:scale(.99)}.home-session-left{display:flex;align-items:center;gap:10px}.home-session-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.home-session-dot.active{background:var(--accent-green);box-shadow:0 0 6px #2d5a2780}.home-session-dot.lobby{background:var(--accent-blue);box-shadow:0 0 6px #1e3a5f80}.home-session-theme{display:block;font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--text-gold)}.home-session-meta{display:block;font-size:11px;color:var(--text-muted)}.home-session-arrow{font-size:20px;color:var(--text-muted)}.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.menu-card{display:flex;flex-direction:column;align-items:center;padding:18px 10px 14px;background:var(--bg-glass);border:1px solid var(--border-dim);border-radius:var(--radius);text-decoration:none;color:inherit;transition:all .15s ease;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden}.menu-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(200,170,80,.15),transparent)}.menu-card:active{background:var(--bg-card-hover);border-color:var(--border-gold);transform:scale(.97)}.menu-icon{font-size:22px;margin-bottom:8px;opacity:.65}.menu-title{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--text-gold);margin-bottom:2px;letter-spacing:.5px}.menu-desc{font-size:10px;color:var(--text-muted);text-align:center}.loading-orb{width:48px;height:48px;border:3px solid var(--border-dim);border-top-color:var(--border-gold);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-style:italic}.empty-state{text-align:center;padding:36px 20px;border:1px solid var(--border-dim);border-radius:var(--radius);background:var(--bg-glass)}.empty-icon{font-size:36px;margin-bottom:12px;opacity:.4}.empty-state h3{font-family:var(--font-display);font-weight:600;color:var(--text-gold);margin-bottom:6px;font-size:16px}.empty-state p{color:var(--text-muted);font-size:13px;margin-bottom:16px}.btn{display:inline-block;padding:11px 24px;border:1px solid var(--border-gold);border-radius:var(--radius);font-family:var(--font-display);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none;letter-spacing:.8px}.btn-primary{background:linear-gradient(180deg,#b4963c2e,#8c641e1f);color:var(--text-gold);border-color:var(--border-gold);box-shadow:inset 0 1px #ffffff0a}.btn-primary:active:not(:disabled){background:linear-gradient(180deg,#b4963c4d,#8c641e33);transform:scale(.98)}.btn-secondary{background:var(--bg-glass);color:var(--text-secondary);border-color:var(--border-dim)}.btn-sm{padding:6px 14px;font-size:11px}.btn:disabled{opacity:.3;cursor:not-allowed}.hint{font-size:11px;color:var(--text-muted);margin-top:8px}.settings-section{background:var(--bg-glass);border:1px solid var(--border-dim);border-radius:var(--radius);padding:16px;margin-bottom:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.section-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text-gold);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-dim);letter-spacing:.5px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.info-row+.info-row{border-top:1px solid rgba(42,42,74,.5)}.info-label{font-size:13px;color:var(--text-secondary)}.info-value{font-size:14px;color:var(--text-primary)}.badge-free{background:var(--accent-blue);padding:2px 8px;border-radius:4px;font-size:12px}.navbar{position:fixed;bottom:0;left:0;right:0;height:var(--navbar-height);background:#0d0c10eb;border-top:1px solid var(--border-dim);display:flex;align-items:center;justify-content:space-around;z-index:100;padding-bottom:env(safe-area-inset-bottom,0);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.nav-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 16px;background:none;border:none;color:var(--text-muted);font-size:9px;cursor:pointer;transition:color .2s}.nav-tab.active{color:var(--text-gold)}.nav-tab:hover{color:var(--text-secondary)}.nav-icon{font-size:20px}.nav-label{font-family:var(--font-body);text-transform:uppercase;letter-spacing:1px}.version-info{text-align:center;font-size:11px;color:var(--text-muted);padding:20px 0;letter-spacing:2px;text-transform:uppercase}.btn-full{display:block;width:100%;text-align:center;margin-top:16px}.btn-danger{background:linear-gradient(135deg,#4a1010,#2a0808);color:#c66;border-color:#5a2020;margin-bottom:24px}.text-red{color:#c44}.char-counter{font-size:12px;color:var(--text-muted);margin-top:4px}.char-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.char-card{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;cursor:pointer;transition:all .2s;text-align:left;color:inherit;width:100%}.char-card:hover{border-color:var(--border-gold);background:var(--bg-card-hover)}.char-card-left{display:flex;flex-direction:column;gap:2px}.char-card-name{font-family:var(--font-display);font-size:17px;color:var(--text-gold)}.char-card-info{font-size:12px;color:var(--text-secondary)}.char-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.char-card-hp{font-size:13px;color:var(--accent-green);font-weight:600}.char-card-ac{font-size:12px;color:var(--text-secondary)}.char-card-hp-bar{margin-top:6px;width:100%;max-width:180px;height:4px;background:#00000059;border-radius:2px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.char-card-hp-fill{height:100%;background:linear-gradient(90deg,#3d8a38,#5faa58);transition:width .3s ease}.char-card-hp-fill.med{background:linear-gradient(90deg,#c09020,#d0a83a)}.char-card-hp-fill.low{background:linear-gradient(90deg,#a02020,#c83030)}.lang-switch{display:flex;gap:8px}.lang-btn{flex:1;padding:10px;background:var(--bg-secondary);border:1px solid var(--border-dim);border-radius:6px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .2s;font-family:var(--font-body)}.lang-btn.active{border-color:var(--border-gold);color:var(--text-gold);background:var(--bg-card-hover)}.cc-page{padding-bottom:calc(100px + var(--navbar-height))}.cc-progress{display:flex;justify-content:center;gap:8px;margin-bottom:20px}.cc-dot{width:10px;height:10px;border-radius:50%;background:var(--border-dim);transition:background .3s}.cc-dot.active{background:var(--text-gold);box-shadow:0 0 6px #d4a84b66}.cc-step{margin-bottom:20px}.cc-step-title{font-family:var(--font-display);font-size:20px;color:var(--text-gold);margin-bottom:16px;text-align:center}.cc-sub-title{font-family:var(--font-display);font-size:15px;color:var(--text-secondary);margin-bottom:10px}.cc-input{width:100%;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:8px;color:var(--text-primary);font-size:16px;font-family:var(--font-body);outline:none;transition:border-color .2s}.cc-input:focus{border-color:var(--border-gold)}.cc-input::placeholder{color:var(--text-muted)}.cc-options{display:flex;flex-direction:column;gap:10px}.cc-option{display:flex;flex-direction:column;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;cursor:pointer;transition:all .2s;text-align:left;color:inherit;width:100%}.cc-option:hover{background:var(--bg-card-hover)}.cc-option.selected{border-color:var(--border-gold);background:var(--bg-card-hover);box-shadow:0 0 8px #c9a84c26}.cc-option-name{font-family:var(--font-display);font-size:17px;color:var(--text-gold);margin-bottom:4px}.cc-option-desc{font-size:12px;color:var(--text-secondary);line-height:1.4}.cc-points{text-align:center;font-size:14px;color:var(--text-secondary);margin-bottom:16px}.cc-points strong{color:var(--text-gold);font-size:18px}.cc-stats{display:flex;flex-direction:column;gap:8px}.cc-stat-row{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:8px}.cc-stat-label{width:36px;font-weight:600;font-size:13px;color:var(--text-secondary)}.cc-stat-controls{display:flex;align-items:center;gap:8px;flex:1;justify-content:center}.cc-stat-btn{width:32px;height:32px;background:var(--bg-secondary);border:1px solid var(--border-dim);border-radius:6px;color:var(--text-gold);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.cc-stat-btn:hover{background:var(--bg-card-hover)}.cc-stat-value{width:48px;text-align:center;font-size:18px;font-weight:600;color:var(--text-primary)}.cc-stat-bonus{font-size:12px;color:var(--accent-green);margin-left:2px}.cc-stat-final{width:60px;text-align:right;font-size:14px;color:var(--text-primary)}.cc-stat-mod{font-size:12px;color:var(--text-secondary)}.cc-spell-list{display:flex;flex-direction:column;gap:8px}.cc-spell{display:flex;flex-direction:column;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:8px;cursor:pointer;transition:all .2s;text-align:left;color:inherit;width:100%}.cc-spell.selected{border-color:var(--accent-blue);background:#1e3a5f4d}.cc-spell-name{font-family:var(--font-display);font-size:15px;color:var(--text-gold);margin-bottom:2px}.cc-spell-desc{font-size:11px;color:var(--text-secondary);line-height:1.3}.cc-review{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:10px;padding:16px}.cc-review-header{text-align:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-dim)}.cc-review-name{font-family:var(--font-display);font-size:24px;color:var(--text-gold);display:block}.cc-review-info{font-size:13px;color:var(--text-secondary)}.cc-review-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.cc-review-stat{text-align:center;padding:8px;background:var(--bg-secondary);border-radius:6px}.cc-review-stat-label{display:block;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.cc-review-stat-value{display:block;font-size:20px;font-weight:700;color:var(--text-primary)}.cc-review-stat-mod{display:block;font-size:12px;color:var(--text-secondary)}.cc-review-spells{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-dim)}.cc-review-spell-tag{display:inline-block;padding:3px 10px;margin:3px;background:#1e3a5f4d;border:1px solid var(--accent-blue);border-radius:4px;font-size:12px;color:var(--text-primary)}.cc-error{color:#c44;text-align:center;margin-top:12px;font-size:13px}.cc-nav{position:fixed;bottom:var(--navbar-height);left:0;right:0;display:flex;gap:10px;padding:12px 16px;background:var(--bg-secondary);border-top:1px solid var(--border-dim);z-index:99}.cc-nav .btn{flex:1;text-align:center}.cs-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.cs-back{background:none;border:1px solid var(--border-dim);border-radius:8px;color:var(--text-gold);font-size:20px;width:40px;height:40px;cursor:pointer;display:flex;align-items:center;justify-content:center}.cs-name{font-family:var(--font-display);font-size:24px;color:var(--text-gold)}.cs-subtitle{font-size:13px;color:var(--text-secondary)}.cs-section{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;padding:14px;margin-bottom:12px}.cs-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.cs-stat-box{text-align:center;padding:10px 4px;background:var(--bg-secondary);border:1px solid var(--border-dim);border-radius:8px}.cs-stat-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:2px}.cs-stat-value{display:block;font-size:22px;font-weight:700;color:var(--text-primary)}.cs-stat-mod{display:block;font-size:13px;color:var(--text-gold)}.cs-combat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.cs-combat-box{text-align:center;padding:8px 4px;background:var(--bg-secondary);border-radius:6px}.cs-combat-label{display:block;font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:2px}.cs-combat-value{display:block;font-size:16px;font-weight:600;color:var(--text-primary)}.cs-features{display:flex;flex-direction:column;gap:8px}.cs-feature{padding:8px 10px;background:var(--bg-secondary);border-radius:6px}.cs-feature-name{display:block;font-family:var(--font-display);font-size:14px;color:var(--text-gold);margin-bottom:2px}.cs-feature-desc{display:block;font-size:11px;color:var(--text-secondary);line-height:1.3}.cs-spell-slots{font-size:12px;color:var(--text-secondary);margin-bottom:8px}.cs-inventory{display:flex;flex-wrap:wrap;gap:6px}.cs-inv-tag{padding:4px 10px;background:var(--bg-secondary);border:1px solid var(--border-dim);border-radius:4px;font-size:12px;color:var(--text-primary);text-transform:capitalize}.session-join-bar{display:flex;gap:8px;margin-bottom:12px}.session-join-input{flex:1;font-family:monospace;letter-spacing:2px;text-transform:lowercase}.session-list-section{margin-top:20px}.session-list{display:flex;flex-direction:column;gap:10px}.session-card{display:flex;flex-direction:column;gap:6px;padding:14px 16px;background:var(--bg-glass);border:1px solid var(--border-dim);border-radius:var(--radius);cursor:pointer;transition:all .15s;text-align:left;color:inherit;width:100%;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden}.session-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(200,170,80,.1),transparent)}.session-card:active{border-color:var(--border-gold);transform:scale(.99)}.session-card-completed{opacity:.6;cursor:default}.session-card-top{display:flex;justify-content:space-between;align-items:center}.session-card-type{font-family:var(--font-display);font-size:14px;color:var(--text-gold)}.session-card-status{font-size:10px;font-weight:600;padding:3px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:1px}.status-lobby{background:#1e365466;color:#6b9cd0}.status-active{background:#2a4e2466;color:#6aaa64}.status-paused{background:#b4963c26;color:var(--text-gold)}.status-completed{background:#ffffff0a;color:var(--text-muted)}.session-card-theme{font-size:13px;color:var(--text-secondary);font-style:italic}.session-card-members{display:flex;flex-wrap:wrap;gap:4px;margin:2px 0 4px}.session-member-chip{display:inline-flex;align-items:center;padding:2px 8px;font-size:11px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--text-secondary);max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-member-chip.host{color:var(--text-gold);border-color:#e8c86059;background:#e8c86014}.session-card-bottom{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-muted)}.session-card-role{color:var(--text-gold);font-size:11px}.session-card-players{font-size:12px;color:var(--text-muted)}.session-delete-btn,.session-leave-btn{width:26px;height:26px;border-radius:50%;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--text-muted);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.session-delete-btn:active{border-color:#b43c2866;color:#c06050;background:#b43c281a}.session-leave-btn:active{border-color:#ffffff1f;color:var(--text-secondary)}.session-delete-btn:disabled,.session-leave-btn:disabled{opacity:.2;cursor:not-allowed}.cs-form{display:flex;flex-direction:column;gap:20px;margin-bottom:80px}.cs-field{display:flex;flex-direction:column;gap:8px}.cs-field-row{flex-direction:row;justify-content:space-between;align-items:center}.cs-label{font-family:var(--font-display);font-size:14px;color:var(--text-gold)}.cs-toggle-group{display:flex;gap:6px}.cs-toggle{flex:1;padding:10px 8px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:6px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .2s;font-family:var(--font-body);text-align:center}.cs-toggle:hover{background:var(--bg-card-hover)}.cs-toggle.active{border-color:var(--border-gold);color:var(--text-gold);background:var(--bg-card-hover)}.cs-counter{display:flex;align-items:center;gap:16px;justify-content:center}.cs-counter-value{font-size:22px;font-weight:700;color:var(--text-primary);min-width:32px;text-align:center}.cs-checkbox{width:32px;height:32px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:6px;color:var(--text-gold);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.cs-checkbox.checked{border-color:var(--border-gold);background:#c9a84c26}.lobby-page{padding-bottom:24px}.lobby-theme{font-size:13px;color:var(--text-secondary);font-style:italic;margin-top:4px}.lobby-section{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;padding:16px;margin-bottom:12px}.lobby-invite-hint{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.lobby-invite-code{font-family:monospace;font-size:28px;letter-spacing:4px;color:var(--text-gold);text-align:center;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-gold);border-radius:8px;margin-bottom:10px;text-transform:uppercase}.lobby-invite-actions{display:flex;gap:8px}.btn-sm{padding:6px 12px;font-size:12px;flex:1;text-align:center}.lobby-members{display:flex;flex-direction:column;gap:8px}.lobby-member{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--bg-secondary);border-radius:8px}.lobby-member-name{font-family:var(--font-display);font-size:15px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.lobby-host-badge{font-size:10px;padding:1px 6px;border-radius:3px;background:var(--accent-blue);color:var(--text-gold);font-family:var(--font-body);text-transform:uppercase;letter-spacing:1px}.lobby-member-char{font-size:12px;color:var(--text-secondary);margin-top:2px}.lobby-no-char{color:var(--text-muted);font-style:italic}.lobby-ready-badge{font-size:11px;padding:4px 10px;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:1px}.lobby-ready-badge.ready{background:#2d5a274d;color:#6aaa64;border:1px solid rgba(45,90,39,.5)}.lobby-ready-badge.not-ready{background:#8b250033;color:var(--text-muted);border:1px solid rgba(139,37,0,.3)}.lobby-char-select{margin-bottom:8px}.lobby-char-select .char-card.selected{border-color:var(--border-gold);background:var(--bg-card-hover)}.lobby-start-btn{margin-top:8px}.llm-key-status{display:flex;flex-direction:column;gap:10px}.llm-key-set{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-primary)}.llm-key-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-green);box-shadow:0 0 6px #2d5a2780}.llm-key-actions{display:flex;gap:8px}.llm-key-form{display:flex;flex-direction:column}.game-page{padding-bottom:80px}.game-header{margin-bottom:16px}.game-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.game-title-small{font-family:var(--font-display);font-size:20px;color:var(--text-gold)}.game-log-toggle{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:6px;padding:4px 12px;color:var(--text-secondary);font-size:12px;cursor:pointer;font-family:var(--font-body)}.game-location-bar{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;background:var(--bg-secondary);border:1px solid var(--border-dim);border-radius:6px;margin-bottom:8px}.game-location{font-family:var(--font-display);font-size:13px;color:var(--text-gold)}.game-mood{font-size:11px;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:1px}.mood-tense{background:#8b250033;color:#c64}.mood-calm{background:#2d5a2733;color:#6aaa64}.mood-mysterious{background:#1e3a5f4d;color:#68b}.mood-dangerous{background:#8b25004d;color:#c44}.mood-triumphant{background:#c9a84c33;color:var(--text-gold)}.game-party-bar{display:flex;gap:8px;margin-bottom:12px;overflow-x:auto;padding-bottom:4px}.game-party-member{display:flex;flex-direction:column;align-items:center;padding:6px 12px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:8px;min-width:80px;flex-shrink:0}.game-party-member.me{border-color:var(--border-gold)}.game-party-name{font-family:var(--font-display);font-size:12px;color:var(--text-gold);white-space:nowrap}.game-party-class{font-size:10px;color:var(--text-muted)}.game-party-hp{font-size:11px;color:var(--accent-green);font-weight:600}.game-scene{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;padding:16px;margin-bottom:12px}.game-scene-text{font-size:14px;line-height:1.7;color:var(--text-primary)}.game-scene-text p{margin-bottom:10px}.game-scene-text p:last-child{margin-bottom:0}.game-npc-dialogue{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-dim)}.game-npc-line{margin-bottom:8px;font-size:14px;line-height:1.5}.game-npc-name{font-family:var(--font-display);color:var(--text-gold);margin-right:6px}.game-npc-text{color:var(--text-secondary);font-style:italic}.game-checks{margin-bottom:12px}.game-section-label{font-family:var(--font-display);font-size:14px;color:var(--text-gold);margin-bottom:8px}.game-check-btn{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;background:var(--bg-card);border:1px solid var(--accent-blue);border-radius:8px;cursor:pointer;transition:all .2s;color:inherit;margin-bottom:6px}.game-check-btn:hover:not(:disabled){background:#1e3a5f4d;border-color:var(--border-gold)}.game-check-btn:disabled{opacity:.5;cursor:not-allowed}.game-check-action{font-size:13px;color:var(--text-primary)}.game-check-info{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.game-quick-actions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.game-qa-btn{padding:8px 14px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:20px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .2s;font-family:var(--font-body)}.game-qa-btn:hover:not(:disabled){border-color:var(--border-gold);color:var(--text-gold)}.game-qa-btn:disabled{opacity:.5;cursor:not-allowed}.game-input-bar{position:fixed;bottom:var(--navbar-height);left:0;right:0;display:flex;gap:8px;padding:10px 16px;background:var(--bg-secondary);border-top:1px solid var(--border-dim);z-index:99}.game-input{flex:1;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:20px;color:var(--text-primary);font-size:14px;font-family:var(--font-body);outline:none;transition:border-color .2s}.game-input:focus{border-color:var(--border-gold)}.game-input::placeholder{color:var(--text-muted)}.game-send-btn{width:44px;height:44px;background:linear-gradient(135deg,var(--accent-red),#6b1d00);border:1px solid var(--border-gold);border-radius:50%;color:var(--text-gold);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.game-send-btn:disabled{opacity:.4;cursor:not-allowed}.game-log{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;padding:12px;margin-bottom:12px;max-height:300px;overflow-y:auto}.game-log-entries{display:flex;flex-direction:column;gap:6px}.game-log-entry{padding:6px 10px;border-radius:6px;font-size:12px;line-height:1.4}.log-scene{background:var(--bg-secondary)}.log-narrative{color:var(--text-secondary);font-style:italic}.log-action{color:var(--text-primary)}.log-action strong{color:var(--text-gold)}.log-check{background:#1e3a5f26;border-left:3px solid var(--accent-blue);padding-left:10px;color:var(--text-secondary);font-family:monospace;font-size:11px}.combat-mode{padding-bottom:20px}.combat-header{margin-bottom:12px}.combat-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.combat-title{font-family:var(--font-display);font-size:20px;color:#c44}.combat-round{font-size:13px;color:var(--text-secondary);background:var(--bg-card);padding:3px 10px;border-radius:12px;border:1px solid var(--border-dim)}.combat-initiative{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;margin-bottom:8px}.combat-init-token{display:flex;flex-direction:column;align-items:center;padding:4px 10px;border-radius:8px;min-width:60px;flex-shrink:0;border:2px solid transparent;transition:all .2s}.combat-init-token.player{background:#1e3a5f4d;border-color:var(--accent-blue)}.combat-init-token.enemy{background:#8b250033;border-color:var(--accent-red)}.combat-init-token.active{border-color:var(--border-gold);box-shadow:0 0 8px #c9a84c66}.combat-init-token.me{border-color:var(--text-gold)}.init-name{font-size:10px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60px}.init-hp{font-size:9px;color:var(--text-secondary)}.combat-narrative{background:var(--bg-card);border:1px solid var(--accent-red);border-radius:10px;padding:12px 16px;margin-bottom:12px;font-size:13px;line-height:1.6;color:var(--text-primary);font-style:italic}.combat-enemies{margin-bottom:12px}.combat-section-label{font-family:var(--font-display);font-size:13px;color:var(--text-gold);margin-bottom:6px}.combat-enemy-list{display:flex;flex-direction:column;gap:6px}.combat-enemy-card{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#8b25001a;border:1px solid var(--accent-red);border-radius:8px;cursor:pointer;transition:all .2s;color:inherit;font-family:var(--font-body);text-align:left;width:100%}.combat-enemy-card.selected{border-color:var(--border-gold);background:#c9a84c1a;box-shadow:0 0 8px #c9a84c4d}.combat-enemy-card.disabled{opacity:.6;cursor:default}.enemy-name{font-family:var(--font-display);font-size:14px;color:#c64}.enemy-stats{display:flex;gap:12px;align-items:center}.enemy-hp{position:relative;font-size:11px;color:var(--text-secondary);padding:2px 8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden;min-width:60px;text-align:center}.enemy-hp-bar{position:absolute;left:0;top:0;bottom:0;background:#8b250066;border-radius:4px;transition:width .3s}.enemy-ac{font-size:11px;color:var(--text-muted)}.combat-party{margin-bottom:12px}.combat-party-list{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px}.combat-player-card{display:flex;flex-direction:column;align-items:center;padding:8px 12px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:8px;min-width:80px;flex-shrink:0}.combat-player-card.me{border-color:var(--border-gold)}.combat-player-card.active-turn{box-shadow:0 0 8px #c9a84c66}.cp-name{font-family:var(--font-display);font-size:12px;color:var(--text-gold);white-space:nowrap}.cp-class{font-size:10px;color:var(--text-muted);text-transform:capitalize}.cp-hp-bar-wrapper{position:relative;width:100%;height:14px;background:var(--bg-secondary);border-radius:3px;overflow:hidden;margin-top:4px}.cp-hp-bar{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#2d5a27,#4a8a3f);border-radius:3px;transition:width .3s}.cp-hp-text{position:relative;z-index:1;font-size:9px;color:var(--text-primary);display:flex;align-items:center;justify-content:center;height:100%}.combat-turn-indicator{text-align:center;padding:8px;margin-bottom:8px}.your-turn{font-family:var(--font-display);font-size:16px;color:var(--text-gold);animation:pulse-gold 1.5s ease-in-out infinite}.waiting-turn{font-size:13px;color:var(--text-muted)}@keyframes pulse-gold{0%,to{opacity:1}50%{opacity:.6}}.combat-actions{margin-bottom:12px}.combat-action-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px}.combat-btn{padding:12px 8px;border-radius:8px;font-family:var(--font-display);font-size:14px;cursor:pointer;border:1px solid;transition:all .2s}.combat-btn:disabled{opacity:.4;cursor:not-allowed}.combat-btn.attack{background:linear-gradient(135deg,#8b25004d,#8b25001a);border-color:var(--accent-red);color:#c64}.combat-btn.attack:hover:not(:disabled){background:#8b250066}.combat-btn.cantrip,.combat-btn.spell{background:linear-gradient(135deg,#1e3a5f4d,#1e3a5f1a);border-color:var(--accent-blue);color:#68b}.combat-btn.cantrip:hover:not(:disabled),.combat-btn.spell:hover:not(:disabled){background:#1e3a5f66}.combat-btn.heal{background:linear-gradient(135deg,#2d5a274d,#2d5a271a);border-color:var(--accent-green);color:#6aaa64}.combat-btn.heal:hover:not(:disabled){background:#2d5a2766}.combat-btn.dodge{background:linear-gradient(135deg,#c9a84c26,#c9a84c0d);border-color:var(--border-gold);color:var(--text-gold)}.combat-btn.dodge:hover:not(:disabled){background:#c9a84c40}.combat-hint{font-size:11px;color:var(--text-muted);text-align:center;margin-top:6px}.spell-picker{background:var(--bg-card);border:1px solid var(--accent-blue);border-radius:10px;padding:12px;margin-bottom:8px}.spell-picker h4{font-family:var(--font-display);font-size:14px;color:var(--text-gold);margin-bottom:8px}.spell-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.spell-btn{padding:8px 14px;background:#1e3a5f33;border:1px solid var(--accent-blue);border-radius:20px;color:#68b;font-size:12px;cursor:pointer;transition:all .2s;font-family:var(--font-body)}.spell-btn:hover:not(:disabled){background:#1e3a5f66;border-color:var(--border-gold);color:var(--text-gold)}.spell-btn:disabled{opacity:.4;cursor:not-allowed}.combat-log{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;padding:10px;max-height:200px;overflow-y:auto}.combat-log-entries{display:flex;flex-direction:column;gap:4px}.combat-log-entry{padding:4px 8px;border-radius:4px;background:var(--bg-secondary)}.clog-details{font-size:12px;color:var(--text-primary);display:block}.clog-mechanical{font-size:10px;color:var(--text-muted);font-family:monospace;display:block}.combat-trigger-banner{background:#8b250026;border:1px solid var(--accent-red);border-radius:10px;padding:16px;margin-bottom:12px;text-align:center}.combat-trigger-text{font-family:var(--font-display);font-size:16px;color:#c44;margin-bottom:12px;animation:pulse-gold 1.5s ease-in-out infinite}.btn-danger{background:linear-gradient(135deg,var(--accent-red),#6b1d00);border:1px solid #cc4444;color:#fca}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#9b3000,#8b2500)}.log-combat{background:#8b25001a;border-left:3px solid var(--accent-red);padding-left:10px;color:#c64;font-weight:600}.log-combat-action{color:var(--text-secondary);font-size:11px;padding-left:10px;border-left:2px solid var(--border-dim)}.combat-rewards{background:linear-gradient(135deg,#c9a84c1a,#2d5a271a);border:1px solid var(--border-gold);border-radius:10px;padding:16px;margin-bottom:12px;text-align:center}.reward-xp{font-family:var(--font-display);font-size:20px;color:var(--text-gold);margin-bottom:8px}.reward-loot{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:8px}.reward-loot-item{padding:4px 10px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:12px;font-size:12px;color:var(--text-secondary)}.reward-levelups{margin-bottom:8px}.reward-levelup{font-family:var(--font-display);font-size:14px;color:#6aaa64;margin-bottom:4px}.game-toast{position:fixed;top:72px;left:50%;transform:translate(-50%);padding:10px 18px;background:linear-gradient(135deg,#1e1e28f2,#322819f2);border:1px solid var(--accent-gold);border-radius:8px;color:var(--accent-gold);font-family:var(--font-display);font-size:13px;z-index:1000;animation:toast-fade 3s ease-in-out;pointer-events:none;white-space:nowrap;max-width:90vw;overflow:hidden;text-overflow:ellipsis}@keyframes toast-fade{0%{opacity:0;transform:translate(-50%,-10px)}10%,90%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-10px)}}.game-rest-bar{display:flex;gap:8px;margin-bottom:12px}.game-rest-btn{flex:1;padding:10px;background:linear-gradient(135deg,#2d5a2733,#2d5a271a);border:1px solid var(--accent-green);border-radius:8px;color:#6aaa64;font-family:var(--font-display);font-size:13px;cursor:pointer;transition:all .2s}.game-rest-btn:hover:not(:disabled){background:#2d5a274d}.game-rest-btn:disabled{opacity:.4;cursor:not-allowed}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-dim);border-radius:2px}.scene-map-container{display:flex;justify-content:center;padding:8px;margin:0 -8px 12px;border-radius:8px;background:var(--bg-secondary);border:1px solid var(--border-dim);overflow-x:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x pinch-zoom}.scene-map-canvas{image-rendering:pixelated;image-rendering:crisp-edges;border-radius:4px;max-width:100%}.scene-map-tooltip{position:absolute;background:#000000e0;color:#e0d8c0;padding:3px 8px;font-size:11px;font-family:var(--font-body);border-radius:4px;pointer-events:none;white-space:nowrap;z-index:10;border:1px solid rgba(186,160,90,.3)}.biome-dungeon{background:#1a1a1f}.biome-forest{background:#1a2a1a}.biome-village{background:#2a2520}.biome-tavern{background:#2a1a10}.biome-cave{background:#0a0a14}.biome-ruins{background:#1a1a20}.biome-crypt{background:#151520}.biome-wilderness{background:#1a2a1a}.npc-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:100;display:flex;align-items:flex-end;justify-content:center;padding:16px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.npc-modal{width:100%;max-width:440px;max-height:80vh;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.npc-modal-header{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border-dim);background:var(--bg-secondary)}.npc-modal-info{flex:1;min-width:0}.npc-modal-name{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text-gold);margin:0}.npc-modal-meta{display:flex;gap:8px;font-size:11px}.npc-modal-role{color:var(--text-secondary)}.npc-modal-disposition{text-transform:capitalize}.npc-modal-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;line-height:1;border-radius:4px;transition:all .15s}.npc-modal-close:hover{color:var(--text-primary);background:#ffffff0d}.npc-msg-list{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px;min-height:120px;max-height:40vh}.npc-msg-hint{color:var(--text-muted);font-style:italic;font-size:12px;text-align:center;padding:16px 0}.npc-msg{max-width:85%;padding:8px 12px;border-radius:12px;font-size:13px;line-height:1.45;word-wrap:break-word}.npc-msg.npc{align-self:flex-start;background:var(--bg-secondary);border:1px solid var(--border-dim);color:var(--text-primary);border-bottom-left-radius:4px}.npc-msg.player{align-self:flex-end;background:#baa05a26;border:1px solid rgba(186,160,90,.25);color:var(--text-gold);border-bottom-right-radius:4px}.npc-msg-typing{opacity:.5;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:.7}}.npc-quest-offer,.npc-item-offer{padding:10px 14px;border-top:1px solid var(--border-dim);background:#c4a65014}.npc-quest-title,.npc-item-title{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--text-gold);margin-bottom:4px}.npc-quest-desc{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.npc-quest-reward,.npc-item-effect{font-size:11px;color:var(--accent-hp);font-style:italic;margin-bottom:6px}.npc-quest-actions{display:flex;gap:8px;margin-top:6px}.npc-input-bar{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--border-dim);background:var(--bg-secondary)}.npc-input{flex:1;background:var(--bg-primary);border:1px solid var(--border-dim);border-radius:20px;padding:8px 14px;color:var(--text-primary);font-size:13px;font-family:var(--font-body);outline:none;transition:border-color .15s}.npc-input:focus{border-color:var(--border-gold)}.npc-input:disabled{opacity:.4}.npc-send-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border-gold);background:#baa05a1a;color:var(--text-gold);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.npc-send-btn:hover:not(:disabled){background:#baa05a33}.npc-send-btn:disabled{opacity:.3;cursor:not-allowed}.quest-log-panel{width:100%;max-width:440px;max-height:70vh;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;animation:slideUp .2s ease}.quest-log-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border-dim);background:var(--bg-secondary)}.quest-log-title{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-gold);margin:0}.quest-log-body{flex:1;overflow-y:auto;padding:12px 14px}.quest-log-empty{color:var(--text-muted);font-style:italic;font-size:13px;text-align:center;padding:24px 0}.quest-log-section{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.quest-log-section-title{font-family:var(--font-display);font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px}.quest-card{padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border-dim);border-radius:var(--radius-sm);transition:border-color .15s}.quest-card:hover{border-color:#baa05a33}.quest-card-done{opacity:.6}.quest-card-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.quest-card-title{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--text-primary)}.quest-card-status{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.quest-card-desc{font-size:12px;color:var(--text-secondary);margin-top:4px;line-height:1.4}.quest-card-reward{font-size:11px;color:var(--accent-hp);font-style:italic;margin-top:4px}.combat-grid-wrapper{display:flex;justify-content:center;padding:8px;margin:0 -8px 8px;background:var(--bg-secondary);border:1px solid var(--border-dim);border-radius:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x pinch-zoom}.combat-grid-canvas{image-rendering:pixelated;image-rendering:crisp-edges;border-radius:4px;cursor:pointer}.combat-grid-info{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;margin-bottom:4px;background:var(--bg-glass);border:1px solid var(--border-dim);border-radius:var(--radius-sm);font-size:12px}.combat-move-remaining{color:#6aa0d0;font-weight:600}.combat-target-selected{color:var(--text-gold)}.combat-btn.end-turn{background:linear-gradient(135deg,#64646433,#6464641a);border-color:#9696964d;color:#aaa}.combat-btn.end-turn-full{width:100%;margin-top:8px;padding:10px;font-size:14px}.combat-grid-wrapper{position:relative}.combat-enemy-banner{position:absolute;inset:auto 8px 8px;padding:10px 14px;background:linear-gradient(135deg,#781e1eeb,#500a0aeb);border:1px solid rgba(232,100,100,.5);border-radius:8px;box-shadow:0 4px 14px #00000080;color:#ffe0d8;pointer-events:none;animation:enemy-banner-in .2s ease-out}.enemy-banner-label{font-family:var(--font-display, "Cinzel", serif);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#ffb0a0;opacity:.85}.enemy-banner-actor{font-family:var(--font-display, "Cinzel", serif);font-size:16px;color:#ffe8d8;margin:2px 0}.enemy-banner-details{font-size:13px;line-height:1.35;color:#ffd0c0}@keyframes enemy-banner-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.combat-budget{display:flex;gap:6px;padding:6px 8px;margin-bottom:6px;overflow-x:auto;-webkit-overflow-scrolling:touch}.budget-pill{flex:1 1 0;min-width:90px;display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-glass, rgba(20, 20, 30, .5));border:1px solid var(--border-dim, rgba(255, 255, 255, .08));border-radius:8px;position:relative;transition:opacity .2s,background .2s}.budget-pill.spent{opacity:.45;background:#00000040}.budget-pill.movement{border-color:#5aa0f059}.budget-pill.action{border-color:#e8c86059}.budget-pill.bonus{border-color:#b464dc59}.budget-icon{font-size:16px;line-height:1}.budget-pill.movement .budget-icon{color:#6aa0d0}.budget-pill.action .budget-icon{color:#e8c860}.budget-pill.bonus .budget-icon{color:#c898e8}.budget-text{display:flex;flex-direction:column;flex:1;min-width:0}.budget-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #888);line-height:1.2}.budget-value{font-size:13px;font-weight:600;color:var(--text-primary, #e8e8f0);line-height:1.2}.budget-bar{position:absolute;bottom:0;left:6px;right:6px;height:2px;background:#00000040;border-radius:1px;overflow:hidden}.budget-bar-fill{height:100%;background:#6aa0d0;transition:width .25s ease}.combat-tray{display:flex;flex-direction:column;gap:8px;padding:10px;background:var(--bg-card, rgba(15, 15, 22, .85));border-top:1px solid var(--border-dim, rgba(255, 255, 255, .08));border-radius:12px 12px 0 0;position:sticky;bottom:0}.combat-tray-status{min-height:18px;font-size:12px;text-align:center}.combat-action-group{display:flex;flex-direction:column;gap:4px}.combat-group-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted, #888);padding:0 2px}.combat-action-group.bonus .combat-group-label{color:#c898e8}.scene-map-container{position:relative}.map-dpad{position:absolute;right:12px;bottom:12px;display:grid;grid-template-columns:38px 38px 38px;grid-template-rows:38px 38px 38px;gap:2px;z-index:10;-webkit-user-select:none;user-select:none;touch-action:manipulation}.dpad-btn{display:flex;align-items:center;justify-content:center;background:#14141ec7;color:#e8c860;border:1px solid rgba(232,200,96,.4);font-size:18px;font-weight:700;cursor:pointer;transition:background .15s,transform .05s;box-shadow:0 2px 6px #0006;padding:0}.dpad-btn:active:not(:disabled){background:#e8c86040;transform:scale(.95)}.dpad-btn:disabled{opacity:.3;cursor:not-allowed}.dpad-btn.up{grid-area:1 / 2 / 2 / 3;border-radius:8px 8px 4px 4px}.dpad-btn.left{grid-area:2 / 1 / 3 / 2;border-radius:8px 4px 4px 8px}.dpad-btn.right{grid-area:2 / 3 / 3 / 4;border-radius:4px 8px 8px 4px}.dpad-btn.down{grid-area:3 / 2 / 4 / 3;border-radius:4px 4px 8px 8px}.dpad-center{grid-area:2 / 2 / 3 / 3;background:#14141e80;border:1px dashed rgba(232,200,96,.2);border-radius:4px}.map-help-hint{position:absolute;left:50%;bottom:8px;transform:translate(-50%);padding:4px 10px;background:#00000080;color:#e8c860d9;font-size:11px;border-radius:12px;pointer-events:none;z-index:5;white-space:nowrap}
