: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}:root{--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--bg-primary: #0a111a;--bg-secondary: #101827;--bg-card: rgba(14, 20, 31, .84);--bg-card-hover: rgba(22, 31, 46, .92);--border-gold: #d8b378;--border-dim: rgba(216, 179, 120, .22);--text-primary: #f5edde;--text-secondary: #cbbda8;--text-gold: #f0d59b;--text-muted: #8c8c98;--accent-red: #9a4339;--accent-blue: #4f95da;--accent-green: #59b697;--font-display: "Cinzel", serif;--font-body: "Nunito Sans", sans-serif;--font-accent: "Cormorant Garamond", serif;--navbar-height: 88px;--chrome-height: 82px;--bg-glass: rgba(14, 20, 31, .76);--accent-hp: #59b697;--radius: 10px;--radius-sm: 6px}html,body{min-height:100%;background:radial-gradient(circle at top left,rgba(94,152,214,.22),transparent 32%),radial-gradient(circle at 80% 12%,rgba(255,210,143,.18),transparent 24%),linear-gradient(180deg,#090e15,#111c2a 46%,#0a0f17)}body{position:relative;color:var(--text-primary);font-family:var(--font-body)}body:before,body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}body:before{background:radial-gradient(circle at 18% 24%,rgba(255,244,209,.08),transparent 0 18%),radial-gradient(circle at 68% 12%,rgba(112,184,255,.08),transparent 0 14%),radial-gradient(circle at 82% 78%,rgba(255,207,151,.07),transparent 0 12%);filter:blur(6px)}body:after{background-image:radial-gradient(circle,rgba(255,247,230,.6) 0 1px,transparent 1px),radial-gradient(circle,rgba(126,186,255,.4) 0 1px,transparent 1px);background-position:0 0,22px 18px;background-size:32px 32px,46px 46px;opacity:.08}#root{position:relative;z-index:1;min-height:100%}.app-shell{max-width:520px;min-height:100dvh;margin:0 auto;padding:18px 12px}.app-shell.immersive{max-width:none;padding:0}.app{position:relative;display:flex;flex-direction:column;min-height:calc(100dvh - 36px);border-radius:34px;overflow:hidden;border:1px solid rgba(255,242,217,.18);background:linear-gradient(180deg,#fff7e81a,#121824db 16%,#090d14fa),linear-gradient(145deg,rgba(78,148,219,.16),transparent 40%);box-shadow:0 28px 56px #0000006b,inset 0 1px #ffffff24,inset 0 0 0 1px #799ac414;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.app:before,.app:after{content:"";position:absolute;pointer-events:none}.app:before{top:10px;right:10px;bottom:10px;left:10px;border-radius:26px;border:1px solid rgba(255,237,211,.08)}.app:after{inset:auto 16px 0;height:160px;background:radial-gradient(circle at bottom,rgba(91,160,223,.22),transparent 68%)}.app-immersive{min-height:100dvh;border-radius:0;border:0;box-shadow:none}.app-immersive:before,.app-immersive:after{display:none}.app-content{flex:1;overflow-y:auto;padding-top:calc(var(--chrome-height) + var(--safe-top) + 18px);padding-bottom:calc(var(--navbar-height) + var(--safe-bottom) + 18px);scrollbar-width:none}.app-content-immersive{padding-top:0;padding-bottom:0}.app-content::-webkit-scrollbar{display:none}.app-chrome{position:absolute;top:0;left:0;right:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:calc(var(--safe-top) + 14px) 18px 16px;min-height:calc(var(--chrome-height) + var(--safe-top));background:linear-gradient(180deg,#0a0f18f5,#101926e0 66%,#10192600)}.app-chrome-brand{display:flex;align-items:center;gap:14px;min-width:0;padding:0;border:0;background:transparent;color:inherit;cursor:pointer;text-align:left}.app-crest{display:grid;place-items:center;width:50px;height:50px;flex-shrink:0;border-radius:18px;background:radial-gradient(circle at 30% 28%,rgba(248,252,255,.75),transparent 0 30%),linear-gradient(180deg,#69baf4,#2d6fa8,#183b5d);border:1px solid rgba(210,236,255,.44);box-shadow:0 12px 26px #18568747,inset 0 1px #ffffff73}.app-crest-number{font-family:var(--font-display);font-size:16px;font-weight:700;color:#edf8ff}.app-chrome-copy{display:flex;flex-direction:column;min-width:0}.app-chrome-title{font-family:var(--font-display);font-size:28px;line-height:1;color:var(--text-primary);letter-spacing:.04em}.app-chrome-subtitle{margin-top:4px;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text-secondary)}.app-chrome-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.chrome-pill,.chrome-user{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;border:1px solid rgba(241,224,196,.16);background:#0f1622b8;box-shadow:inset 0 1px #ffffff14}.chrome-pill{font-size:10px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--text-gold)}.chrome-pill-highlight{background:linear-gradient(180deg,#6fbeff5c,#235f9447),#121c28b8;color:#eff9ff}.chrome-user-name{max-width:104px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:700;color:var(--text-primary)}.chrome-user-lang{font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-blue)}.page{max-width:100%;padding:20px 18px 30px}.page-center{min-height:72vh}.page-header{margin-bottom:18px;padding:18px 20px;text-align:left;border-radius:28px;border:1px solid rgba(240,223,193,.22);background:linear-gradient(180deg,#fff7e51f,#111823db),linear-gradient(140deg,rgba(98,165,231,.12),transparent 40%);box-shadow:inset 0 1px #ffffff1a,0 24px 40px #02060b47}.logo,.page-title,.page-section-title{font-family:var(--font-display);color:var(--text-primary);text-shadow:0 4px 14px rgba(0,0,0,.28)}.logo{font-size:34px;letter-spacing:.06em}.page-title{font-size:28px}.page-kicker,.subtitle{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--text-secondary)}.page-section-title{margin-top:4px;font-size:26px}.greeting,.menu-card,.home-session-card,.settings-section,.cs-section,.session-card,.char-card,.lobby-section,.empty-state,.cc-option,.cc-spell,.cc-review,.cs-form,.lobby-char-select,.session-join-bar,.game-scene,.game-log,.game-checks,.game-quick-actions,.game-input-bar,.combat-narrative,.combat-enemies,.combat-party,.combat-log,.combat-turn-indicator{position:relative;border-radius:26px;border:1px solid rgba(240,223,193,.22);background:linear-gradient(180deg,#fff7e91f,#121823d6),linear-gradient(140deg,rgba(82,146,212,.14),transparent 38%),#090d14cc;box-shadow:inset 0 1px #ffffff17,0 24px 40px #02060b57;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.greeting:before,.menu-card:before,.settings-section:before,.cs-section:before,.session-card:before,.char-card:before,.lobby-section:before,.empty-state:before,.home-hero:before,.home-session-spotlight:before,.home-board:before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:inherit;pointer-events:none;border:1px solid rgba(255,255,255,.04)}.btn{min-height:50px;border-radius:16px;padding:12px 22px;font-family:var(--font-display);font-size:14px;letter-spacing:.04em;border-width:1px;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn-primary{color:#f7fbff;background:linear-gradient(180deg,#7fc6ff,#2c7db8 44%,#174566);border-color:#ceecff85;box-shadow:0 18px 28px #19619557,inset 0 1px #ffffff6b}.btn-primary:hover:not(:disabled){box-shadow:0 18px 32px #1961956b,inset 0 1px #ffffff85}.btn-secondary{color:var(--text-primary);background:linear-gradient(180deg,#fff8e833,#45403b2e),#0e151fbd;border-color:#eed9b533;box-shadow:0 12px 22px #0000002e,inset 0 1px #ffffff1f}.btn-danger{color:#fde7e3;background:linear-gradient(180deg,#bf6257,#7a3029 42%,#431611);border-color:#ffc3b842;box-shadow:0 18px 28px #4d110a3d,inset 0 1px #ffffff38}.btn-full{width:100%}.btn-sm{min-height:42px;padding:10px 14px;border-radius:14px}.loading-orb{border-color:#ffeacb1f;border-top-color:var(--accent-blue);box-shadow:0 0 16px #59aaef4d}.loading-text,.hint,.menu-desc,.char-counter,.info-label,.session-card-bottom,.lobby-member-char,.lobby-invite-hint,.greeting-text,.empty-state p,.version-info{color:var(--text-secondary)}.empty-state{padding:36px 24px;border-style:solid}.empty-icon{filter:drop-shadow(0 12px 18px rgba(0,0,0,.22))}.cc-input,.game-input,.session-join-input{border-radius:16px;border-color:#e5cfab2e;background:linear-gradient(180deg,#121a26f0,#090d14e0);color:var(--text-primary);box-shadow:inset 0 1px #ffffff0f}.cc-input:focus,.game-input:focus{border-color:#89cbff94;box-shadow:0 0 0 3px #68b6f524,inset 0 1px #ffffff14}.home-page{display:flex;flex-direction:column;gap:16px}.home-hero,.home-session-spotlight,.home-board{position:relative;padding:20px;border-radius:30px;border:1px solid rgba(240,223,193,.24);background:linear-gradient(180deg,#fff9ec1f,#101824e0),linear-gradient(145deg,rgba(98,171,237,.18),transparent 44%),#090d15d6;box-shadow:inset 0 1px #ffffff1f,0 28px 48px #02060b52}.home-hero{overflow:hidden}.home-hero:after{content:"";position:absolute;right:-36px;top:-54px;width:190px;height:190px;border-radius:50%;background:radial-gradient(circle,rgba(103,181,245,.26),transparent 68%);pointer-events:none}.home-hero-top{display:flex;align-items:center;gap:16px}.home-hero-emblem{position:relative;display:grid;place-items:center;width:88px;height:88px;flex-shrink:0;border-radius:28px;background:radial-gradient(circle at 30% 24%,rgba(255,255,255,.62),transparent 0 24%),linear-gradient(180deg,#69bcffe0,#27588aeb);border:1px solid rgba(211,238,255,.56);box-shadow:0 18px 30px #13568952,inset 0 1px #fff6}.home-hero-emblem.empty{background:radial-gradient(circle at 30% 24%,rgba(255,255,255,.52),transparent 0 24%),linear-gradient(180deg,#ffe2a4eb,#906221e0)}.home-hero-emblem span{font-family:var(--font-display);font-size:24px;color:#f5fbff;letter-spacing:.08em}.home-hero-copy{min-width:0}.home-hero-kicker{font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--text-secondary)}.home-hero-name{font-family:var(--font-display);font-size:38px;line-height:1.02;color:var(--text-primary);text-shadow:0 3px 14px rgba(0,0,0,.32)}.home-hero-role{margin-top:6px;font-size:15px;color:var(--text-secondary)}.home-hero-health{margin-top:18px}.home-hero-health-meta{display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px;font-weight:700;color:var(--text-primary)}.home-hero-health-track{height:12px;overflow:hidden;border-radius:999px;background:#ffffff14;box-shadow:inset 0 1px 2px #00000052}.home-hero-health-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#5dc5a4,#8de6d1);box-shadow:0 0 18px #74e4c84d}.home-hero-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:18px}.home-hero-stat{padding:12px 10px;border-radius:18px;border:1px solid rgba(235,217,190,.14);background:linear-gradient(180deg,#fff6e324,#121924db);text-align:center}.home-hero-stat span{display:block;margin-bottom:4px;font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary)}.home-hero-stat strong{font-family:var(--font-display);font-size:20px;color:var(--text-primary)}.home-hero-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}.home-empty-callout{margin-top:18px;padding:18px;border-radius:22px;border:1px solid rgba(237,217,185,.14);background:linear-gradient(180deg,#fff8e61a,#111824c2)}.home-empty-callout.compact{margin-top:12px}.home-empty-title{font-family:var(--font-display);font-size:20px;color:var(--text-primary)}.home-empty-text{margin-top:8px;margin-bottom:16px;font-size:14px;color:var(--text-secondary)}.home-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.home-status-pill{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#eff9ff;background:#132030b8;border:1px solid rgba(189,225,255,.18)}.home-status-pill.active{background:#3c91d23d}.home-status-pill.lobby{background:#e0b8702e}.home-session-visual{position:relative;display:flex;align-items:flex-end;min-height:148px;padding:18px;overflow:hidden;border-radius:24px;background:linear-gradient(180deg,#050d1857,#070d17cc),radial-gradient(circle at 42% 28%,rgba(91,191,255,.32),transparent 0 18%),linear-gradient(135deg,#172f4beb,#0d1522fa);border:1px solid rgba(221,232,244,.12)}.home-session-glow{position:absolute;inset:auto 14% 18% 10%;height:68px;border-radius:999px;background:radial-gradient(circle,rgba(94,204,255,.34),transparent 68%)}.home-session-copy{position:relative;z-index:1}.home-session-copy p{margin:0}.home-session-meta{font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary)}.home-session-role{margin-top:8px;font-family:var(--font-display);font-size:20px;color:var(--text-primary)}.home-session-roster{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 16px}.home-roster-pill{padding:8px 12px;border-radius:999px;font-size:12px;font-weight:700;color:var(--text-primary);background:#fff9ec14;border:1px solid rgba(236,218,187,.14)}.menu-grid-home{margin-bottom:0}.menu-grid{gap:12px}.menu-card{align-items:flex-start;gap:8px;padding:18px 16px;border-radius:24px;border-color:#f0dfc12e;text-align:left;box-shadow:inset 0 1px #ffffff14,0 20px 34px #02060b3d}.menu-card:hover,.menu-card:active{border-color:#b3ddff57;box-shadow:inset 0 1px #ffffff1f,0 24px 38px #0d3a5f38}.menu-grid-home .menu-card:nth-child(1){background:linear-gradient(180deg,#5f9fdb42,#121a26e0),#0a0e16d6}.menu-grid-home .menu-card:nth-child(2){background:linear-gradient(180deg,#ffe4ad33,#121a26e0),#0a0e16d6}.menu-grid-home .menu-card:nth-child(3){background:linear-gradient(180deg,#8f7ae224,#121a26e0),#0a0e16d6}.menu-grid-home .menu-card:nth-child(4){background:linear-gradient(180deg,#70d6b529,#121a26e0),#0a0e16d6}.menu-icon{display:grid;place-items:center;width:48px;height:48px;margin-bottom:6px;border-radius:16px;background:#ffffff14;font-size:22px}.menu-title{font-size:18px;color:var(--text-primary)}.menu-desc{font-size:13px;line-height:1.4}.navbar{position:absolute;left:12px;right:12px;bottom:0;z-index:35;display:flex;align-items:stretch;gap:8px;height:auto;padding:10px;padding-bottom:calc(10px + var(--safe-bottom));border-top:0;border-radius:28px 28px 0 0;background:linear-gradient(180deg,#0e1621eb,#0a0e16fa);border:1px solid rgba(243,225,197,.16);box-shadow:0 -18px 32px #00000057,inset 0 1px #ffffff1a}.nav-tab{flex:1;gap:6px;justify-content:center;min-height:64px;padding:8px 10px;border-radius:20px;color:var(--text-secondary);transition:transform .2s ease,background .2s ease,color .2s ease}.nav-tab:hover{color:var(--text-primary);background:#ffffff0a}.nav-tab.active{color:#f3fbff;background:linear-gradient(180deg,#6ebfff4d,#295c8a5c),#121c28b8;box-shadow:0 14px 24px #1a5c8d3d,inset 0 1px #ffffff47}.nav-icon-shell{display:grid;place-items:center;width:32px;height:32px;border-radius:12px;background:#ffffff0f}.nav-tab.active .nav-icon-shell{background:#ffffff1f}.nav-icon{font-size:16px}.nav-label{font-size:11px;font-weight:800;letter-spacing:.14em}.char-list,.session-list,.lobby-members{gap:12px}.char-card,.session-card,.lobby-member{border-radius:24px}.char-card,.session-card{padding:18px}.char-card-name,.session-card-theme,.cs-name{color:var(--text-primary)}.char-card-name{font-size:18px}.char-card-info,.session-card-bottom,.session-card-role{font-size:13px}.char-card-right{gap:6px}.char-card-hp{color:#8fe8cb}.session-join-bar{display:flex;align-items:center;gap:10px;padding:10px;margin-bottom:14px}.session-join-input{flex:1}.session-card-top{align-items:center;margin-bottom:10px}.session-card-type,.section-title,.cs-label,.combat-section-label,.game-section-label{color:var(--text-gold)}.section-title{font-size:19px}.session-card-status{padding:6px 10px;border-radius:999px;background:#ffffff0f}.session-card-theme{font-size:19px}.settings-section,.cs-section,.lobby-section,.cs-form{padding:18px}.info-row+.info-row{border-top-color:#f2dfbf14}.badge-free{border-radius:999px;padding:4px 10px;background:#56a3e438;color:#ebf8ff}.lang-btn{border-radius:16px;border-color:#f0dfc129}.lang-btn.active{background:#4c90d12e}.cc-option,.cc-spell,.cs-toggle,.game-check-btn,.game-qa-btn,.combat-enemy-card,.spell-btn{border-radius:18px}.cc-option-name,.cc-spell-name,.cs-feature-name{color:var(--text-primary)}.cc-option-desc,.cc-spell-desc,.cs-feature-desc{color:var(--text-secondary)}.lobby-invite-code{border-radius:18px;border-color:#f0dfc138;background:#070b12b8;color:#eff8ff;box-shadow:inset 0 1px #ffffff0a}.lobby-member{padding:16px;border:1px solid rgba(240,223,193,.12);background:#ffffff0a}.lobby-host-badge,.lobby-ready-badge{border-radius:999px}.lobby-ready-badge.ready{background:#5ecaa538;color:#dcfff5}.lobby-ready-badge.not-ready{background:#bf685c2e;color:#ffd8d3}.game-header,.combat-header{margin-bottom:14px;padding:18px;border-radius:0 0 26px 26px;background:linear-gradient(180deg,#0d131df5,#111b29e0),#0b0f17f0;border-bottom:1px solid rgba(240,223,193,.14)}.game-party-member,.combat-player-card,.combat-init-token,.combat-enemy-card{border-radius:18px}.version-info{padding:8px 0 2px;font-size:10px;letter-spacing:.16em}@media(max-width:420px){.app-shell{padding:10px 8px}.app{min-height:calc(100dvh - 20px);border-radius:28px}.app-chrome{gap:10px;padding-inline:14px}.app-crest{width:44px;height:44px;border-radius:16px}.app-chrome-title{font-size:24px}.chrome-user{padding-inline:10px}.chrome-user-name{max-width:72px}.page{padding-inline:14px}.home-hero-name{font-size:30px}.home-hero-stats,.home-hero-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.menu-grid{grid-template-columns:1fr}.session-join-bar{flex-direction:column}.session-join-bar .btn{width:100%}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:root{--navbar-height: 76px;--chrome-height: 72px}body{overflow:hidden}body:before{filter:blur(4px);opacity:.8}body:after{opacity:.04}.app-shell{height:100dvh;padding:12px 10px;overflow:hidden}.app{height:100%;min-height:0;border-radius:30px;border-color:#dfcaa924;background:linear-gradient(180deg,#232d3bdb,#090e16fa 22%,#070c13),linear-gradient(145deg,rgba(67,116,171,.12),transparent 42%);box-shadow:0 18px 36px #00000057,inset 0 1px #ffffff14}.app:before{display:none}.app:after{inset:auto 18px 0;height:88px;opacity:.55}.app-content{padding-top:calc(var(--chrome-height) + var(--safe-top) + 12px);padding-bottom:calc(var(--navbar-height) + var(--safe-bottom) + 14px)}.app-chrome{gap:12px;padding:calc(var(--safe-top) + 12px) 16px 10px;min-height:calc(var(--chrome-height) + var(--safe-top))}.app-crest{width:42px;height:42px;border-radius:14px;box-shadow:0 8px 18px #18568738,inset 0 1px #ffffff57}.app-crest-number{font-size:15px}.app-chrome-title{font-size:24px;letter-spacing:.03em}.app-chrome-subtitle{margin-top:2px;font-size:10px;letter-spacing:.16em}.chrome-pill,.chrome-user{padding:6px 10px;border-color:#f1e0c41f;box-shadow:none}.chrome-user-name{max-width:88px;font-size:12px}.page{padding:14px 14px 24px}.page-header{margin-bottom:14px;padding:14px 16px;border-radius:24px;border-color:#f0dfc129;box-shadow:inset 0 1px #ffffff14,0 14px 24px #02060b3d}.page-title{font-size:22px}.page-section-title{font-size:20px}.page-kicker,.subtitle{gap:6px;font-size:10px;letter-spacing:.16em}.greeting:before,.menu-card:before,.settings-section:before,.cs-section:before,.session-card:before,.char-card:before,.lobby-section:before,.empty-state:before,.home-hero:before,.home-session-spotlight:before,.home-board:before{display:none}.greeting,.menu-card,.home-session-card,.settings-section,.cs-section,.session-card,.char-card,.lobby-section,.empty-state,.cc-option,.cc-spell,.cc-review,.cs-form,.lobby-char-select,.session-join-bar{border-color:#e2ccaa24;box-shadow:inset 0 1px #ffffff0f,0 12px 22px #02060b3d}.btn{min-height:44px;padding:10px 16px;border-radius:14px;font-size:13px;letter-spacing:.02em}.btn-primary{box-shadow:0 12px 22px #19619542,inset 0 1px #ffffff5c}.btn-primary:hover:not(:disabled){box-shadow:0 14px 24px #1961954d,inset 0 1px #ffffff6b}.btn-secondary,.btn-danger{box-shadow:0 10px 18px #00000024,inset 0 1px #ffffff1a}.btn-sm{min-height:38px;padding:8px 12px;border-radius:12px}.home-page{gap:12px}.home-hero,.home-session-spotlight,.home-board{padding:16px;border-radius:24px;border-color:#e1cba929;background:linear-gradient(180deg,#3c4654d1,#131c28eb),linear-gradient(145deg,rgba(84,146,205,.1),transparent 46%),#080d14eb;box-shadow:inset 0 1px #ffffff14,0 16px 28px #02060b42}.home-hero:after{top:-28px;right:-18px;width:132px;height:132px;opacity:.75}.home-hero-top{gap:12px}.home-hero-emblem{width:72px;height:72px;border-radius:22px;box-shadow:0 12px 20px #13568938,inset 0 1px #ffffff4d}.home-hero-emblem span{font-size:21px}.home-hero-kicker{font-size:10px}.home-hero-name{font-size:30px}.home-hero-role{margin-top:4px;font-size:13px}.home-hero-health,.home-hero-stats,.home-hero-actions{margin-top:12px}.home-hero-health-meta{margin-bottom:6px;font-size:12px}.home-hero-health-track{height:10px}.home-hero-stats{gap:8px}.home-hero-stat{padding:10px 8px;border-radius:14px}.home-hero-stat strong{font-size:16px}.home-hero-actions{gap:8px}.home-empty-callout{margin-top:14px;padding:14px;border-radius:18px}.home-empty-title{font-size:18px}.home-empty-text{margin-top:6px;margin-bottom:12px;font-size:13px}.home-section-head{align-items:center;gap:10px;margin-bottom:12px}.home-status-pill{padding:6px 10px;font-size:10px;letter-spacing:.14em}.home-session-visual{min-height:92px;padding:14px;border-radius:20px}.home-session-glow{inset:auto 18% 14% 14%;height:44px}.home-session-meta{font-size:11px}.home-session-role{margin-top:6px;font-size:16px}.home-session-roster{gap:6px;margin:10px 0 12px}.home-roster-pill{padding:6px 10px;font-size:11px}.home-session-card{padding:12px 14px;border-radius:20px}.menu-grid{gap:10px}.menu-grid-home{grid-template-columns:repeat(2,minmax(0,1fr))}.menu-card{gap:6px;min-height:132px;padding:14px 12px;border-radius:20px;box-shadow:inset 0 1px #ffffff0f,0 12px 20px #02060b2e}.menu-icon{width:42px;height:42px;margin-bottom:4px;border-radius:14px;font-size:18px}.menu-title{font-size:15px}.menu-desc{font-size:12px;line-height:1.3}.char-list,.session-list,.lobby-members{gap:10px}.char-card,.session-card,.lobby-member{border-radius:20px}.char-card,.session-card{padding:14px}.char-card-name,.session-card-theme{font-size:16px}.char-card-info,.session-card-bottom,.session-card-role,.session-card-players,.char-card-hp{font-size:12px}.char-card-ac{font-size:11px}.char-card-hp-bar{height:5px;max-width:120px;margin-top:5px}.session-join-bar{gap:8px;padding:8px;border-radius:20px}.session-card-top{margin-bottom:8px}.session-card-status{padding:5px 8px;font-size:10px}.session-card-members{gap:5px;margin:6px 0 8px}.session-member-chip{padding:3px 8px;font-size:10px}.session-delete-btn,.session-leave-btn{width:24px;height:24px;font-size:10px}.settings-section,.cs-section,.lobby-section,.cs-form,.lobby-char-select{padding:14px;border-radius:22px}.section-title{margin-bottom:10px;padding-bottom:6px;font-size:17px}.info-row{padding:10px 0}.info-label{font-size:12px}.info-value{font-size:13px}.lang-btn{padding:12px 10px;border-radius:14px;font-size:13px}.llm-key-actions,.lobby-invite-actions{gap:8px;flex-wrap:wrap}.llm-key-actions .btn,.llm-key-form .btn{flex:1}.navbar{left:10px;right:10px;padding:8px;padding-bottom:calc(8px + var(--safe-bottom));gap:6px;border-radius:24px 24px 0 0;border-color:#f3e1c51f;box-shadow:0 -10px 20px #0000003d,inset 0 1px #ffffff14}.nav-tab{gap:4px;min-height:58px;padding:6px 8px;border-radius:18px}.nav-tab.active{box-shadow:0 10px 18px #1a5c8d2e,inset 0 1px #ffffff38}.nav-icon-shell{width:28px;height:28px;border-radius:10px}.nav-icon{font-size:15px}.nav-label{font-size:10px;letter-spacing:.12em}.version-info{padding:6px 0 0;font-size:10px}@media(max-width:420px){.app-shell{padding:8px}.app{border-radius:26px}.page{padding:12px 12px 22px}.home-hero-name{font-size:26px}.home-hero-stats,.home-hero-actions,.menu-grid-home{grid-template-columns:repeat(2,minmax(0,1fr))}.menu-card{min-height:116px}}.fantasy-icon{width:1em;height:1em;display:block;flex-shrink:0}.menu-icon .fantasy-icon{width:22px;height:22px}.nav-icon{width:16px;height:16px}.chrome-pill-highlight{background:linear-gradient(180deg,#ab895457,#43465638),#121b28b8}.nav-tab.active{background:linear-gradient(180deg,#799cbf57,#404f6061),#121c28b8}.menu-grid-home .menu-card:nth-child(1){background:linear-gradient(180deg,#55759a3d,#121a26e0),#0a0e16d6}.menu-grid-home .menu-card:nth-child(2){background:linear-gradient(180deg,#af8b5538,#121a26e0),#0a0e16d6}.menu-grid-home .menu-card:nth-child(3){background:linear-gradient(180deg,#6e5c822e,#121a26e0),#0a0e16d6}.menu-grid-home .menu-card:nth-child(4){background:linear-gradient(180deg,#4e6a542e,#121a26e0),#0a0e16d6}.menu-icon{color:#e8d6b3}.menu-card:hover .menu-icon,.menu-card:active .menu-icon{color:#f6ead4}.game-page{display:flex;flex-direction:column;gap:10px;padding-bottom:24px}.game-page-start{padding-top:10px}.game-start-panel,.game-party-panel{position:relative;padding:18px;border-radius:24px;border:1px solid rgba(231,212,181,.16);background:linear-gradient(180deg,#484f5c9e,#0f1620f0),linear-gradient(145deg,rgba(173,137,82,.12),transparent 48%),#090d14eb;box-shadow:inset 0 1px #ffffff0f,0 18px 28px #02060b3d}.game-start-copy{margin-top:10px;color:var(--text-secondary);font-size:14px;line-height:1.65}.game-party-panel{padding:12px 14px 14px}.game-party-bar-start{margin-bottom:0}.game-awaiting-note{padding:10px 12px 0;color:var(--text-secondary);text-align:center;font-size:13px}.game-header,.combat-header{margin-bottom:0;padding:16px;border-radius:24px;border:1px solid rgba(234,215,184,.14);background:linear-gradient(180deg,#3d45528f,#0d141ef2),linear-gradient(145deg,rgba(160,129,79,.1),transparent 48%),#0a0f16eb;box-shadow:inset 0 1px #ffffff12,0 18px 28px #02060b3d}.game-header-top{gap:10px}.game-title-small,.combat-title{letter-spacing:.04em}.game-title-small{font-size:18px}.game-header-buttons{display:flex;align-items:center;gap:8px}.game-quest-toggle,.game-log-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:40px;border:1px solid rgba(226,204,171,.18);border-radius:16px;background:linear-gradient(180deg,#fff7e514,#0f151fd6),#0b1018eb;color:var(--text-gold);box-shadow:none}.game-quest-toggle{width:40px;padding:0}.game-log-toggle{padding:0 14px}.game-header-icon{width:18px;height:18px}.game-location-bar{padding:8px 12px;margin-bottom:10px;border-radius:16px;background:#0c121ac2;border-color:#dfc8a81f}.game-party-bar{gap:8px;margin-bottom:0;padding-bottom:2px}.game-party-member{min-width:72px;padding:8px 12px;background:linear-gradient(180deg,#fff7e814,#0f141de6),#0b1018e0;border-color:#e0caa81f}.game-scene,.game-log,.game-checks,.game-quick-actions,.game-input-bar,.combat-narrative,.combat-enemies,.combat-party,.combat-log,.combat-turn-indicator{border-radius:22px;border-color:#e5d2b324;background:linear-gradient(180deg,#4f545e80,#0e141df2),linear-gradient(145deg,rgba(164,130,80,.08),transparent 52%),#090d14eb;box-shadow:inset 0 1px #ffffff0f,0 16px 26px #02060b38}.game-scene,.game-log,.combat-narrative,.combat-enemies,.combat-party,.combat-log,.combat-turn-indicator{padding:16px;margin-bottom:0}.game-scene-text{font-size:15px;line-height:1.74;color:#f1e7d5}.game-npc-dialogue{margin-top:14px;padding-top:12px}.game-action-stack{display:flex;flex-direction:column;gap:10px;margin-top:2px}.game-checks,.game-quick-actions,.game-input-bar{margin-bottom:0}.game-checks,.game-quick-actions{padding:12px}.game-section-label,.combat-section-label{margin-bottom:10px;font-size:12px;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.game-check-list{display:flex;flex-direction:column;gap:8px}.game-check-btn{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;width:100%;margin-bottom:0;padding:12px 14px;border-radius:18px;background:linear-gradient(180deg,#111b28f0,#0a0f16fa);border:1px solid rgba(106,163,221,.54);color:inherit;text-align:left}.game-check-btn:hover:not(:disabled){background:linear-gradient(180deg,#172331fa,#0c121a);border-color:#e6c9958f}.game-check-action{min-width:0;font-size:14px;line-height:1.38;color:var(--text-primary)}.game-check-info{min-width:fit-content;text-align:right;white-space:nowrap;font-size:11px;color:#d8c9ab}.game-quick-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.game-qa-btn{min-height:46px;padding:10px 12px;border-radius:16px;background:linear-gradient(180deg,#fff7e814,#0f151eeb),#0c121ae6;border:1px solid rgba(223,201,168,.12);color:var(--text-primary);font-size:13px;text-align:left;line-height:1.35}.game-qa-btn:hover:not(:disabled){border-color:#e5c7906b;color:#f3ead9}.game-input-bar{position:sticky;bottom:calc(var(--safe-bottom) + 8px);left:auto;right:auto;z-index:18;display:flex;align-items:center;gap:10px;padding:10px;border-top:0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:inset 0 1px #ffffff14,0 18px 28px #02060b47}.game-input{min-height:48px;padding:12px 14px;border-radius:16px;font-size:15px}.game-send-btn{width:48px;height:48px;border-radius:18px;background:linear-gradient(180deg,#b66a57,#7f3429 48%,#4a1711);border:1px solid rgba(248,207,193,.22);color:#fff2e2}.combat-grid-info{gap:12px;margin-bottom:8px;padding:10px 12px;border-radius:18px;border:1px solid rgba(225,205,174,.14);background:linear-gradient(180deg,#fff7e814,#0c121aeb),#090d14eb}.combat-move-remaining{color:#8fc0e8}.combat-grid-tip{min-width:0;font-size:11px;text-align:right;color:var(--text-secondary)}.combat-grid-wrapper{padding:12px;margin:0;border-radius:24px;border:1px solid rgba(229,207,176,.14);background:linear-gradient(180deg,#40465080,#0b1018f2),#080c12f0;box-shadow:inset 0 1px #ffffff0f,0 18px 30px #02060b3d}.combat-grid-canvas{border-radius:18px;border:1px solid rgba(226,207,178,.12);background:#0d1218;box-shadow:0 18px 28px #00000047}.combat-budget{gap:8px;padding:0;margin-bottom:0}.budget-pill{padding:10px 12px;border-radius:18px;background:linear-gradient(180deg,#fff7e814,#0c121af0),#080c12eb}.budget-pill.movement{border-color:#78a8d44d}.budget-pill.action{border-color:#d9b47447}.budget-pill.bonus{border-color:#9d73bd47}.combat-tray{gap:10px;padding:12px;border-radius:22px;border:1px solid rgba(229,207,177,.14);background:linear-gradient(180deg,#4a4f5a80,#0b1018f2),#080c12f0;box-shadow:inset 0 1px #ffffff0f,0 18px 30px #02060b3d;bottom:calc(var(--safe-bottom) + 8px)}.combat-tray-status{min-height:20px}.combat-group-label{font-size:10px;letter-spacing:.14em}.combat-action-buttons{gap:8px}.combat-btn{min-height:46px;padding:12px 10px;border-radius:16px;font-size:13px;letter-spacing:.02em}.spell-picker{margin-bottom:0;padding:12px;border-radius:18px;background:linear-gradient(180deg,#fff7e814,#0c121af0),#080c12eb}.spell-list{gap:8px}.spell-btn{min-height:40px;border-radius:14px}.combat-log-entry{padding:8px 10px;border-radius:14px}.scene-map-container{display:block;padding:72px 14px 14px;margin:0;border-radius:24px;border:1px solid rgba(228,208,176,.14);background:linear-gradient(180deg,#474e5a7a,#0c121af2),linear-gradient(145deg,rgba(171,137,82,.08),transparent 52%),#080c12f0;box-shadow:inset 0 1px #ffffff0f,0 18px 28px #02060b3d;overflow:hidden}.map-hud{position:absolute;inset:12px 12px auto;z-index:2;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;pointer-events:none}.map-hud-hero{display:flex;align-items:center;gap:10px;min-width:0;padding:8px 10px;border-radius:18px;border:1px solid rgba(228,207,177,.14);background:#0a0f16db}.map-hud-avatar{display:grid;place-items:center;width:38px;height:38px;border-radius:14px;background:radial-gradient(circle at 30% 24%,rgba(255,255,255,.38),transparent 0 28%),linear-gradient(180deg,#d2a65d,#9f7133 46%,#674620);color:#fff4dc;font-family:var(--font-display);font-size:14px;letter-spacing:.08em}.map-hud-copy{display:flex;flex-direction:column;min-width:0}.map-hud-title{font-family:var(--font-display);font-size:15px;color:var(--text-primary)}.map-hud-subtitle{font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--text-secondary)}.map-hud-chips{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px}.map-hud-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;border:1px solid rgba(227,206,175,.12);background:#0a0f16d1;color:var(--text-secondary);font-size:11px;font-weight:700}.map-hud-icon{width:14px;height:14px}.scene-map-canvas{width:100%;border-radius:20px;border:1px solid rgba(226,207,177,.12);background:#0d1218;box-shadow:0 18px 28px #00000042}.scene-map-tooltip{padding:6px 10px;border-radius:12px;background:#070a10eb}.map-controls{position:absolute;right:12px;bottom:12px;left:12px;z-index:3;display:flex;align-items:flex-end;justify-content:space-between;gap:12px;pointer-events:none}.map-help-hint{position:static;transform:none;max-width:min(220px,calc(100% - 146px));padding:8px 12px;border-radius:999px;border:1px solid rgba(227,206,174,.12);background:#0a0f16d1;color:#f3da9fe6;font-size:11px;line-height:1.35;box-shadow:0 12px 20px #00000038;pointer-events:none}.map-dpad{position:static;grid-template-columns:42px 42px 42px;grid-template-rows:42px 42px 42px;gap:3px;padding:6px;border-radius:18px;background:linear-gradient(180deg,#181f2adb,#0a0f16eb);border:1px solid rgba(227,206,174,.12);box-shadow:0 14px 24px #00000047;pointer-events:auto}.dpad-btn{background:linear-gradient(180deg,#2e353ef0,#11151efa);color:#f2d797;border-color:#dbb9763d;box-shadow:inset 0 1px #ffffff0f,0 8px 14px #0000002e}.dpad-btn:active:not(:disabled){background:linear-gradient(180deg,#78613c66,#1c2129fa)}.dpad-center{background:#101620c2;border:1px dashed rgba(224,200,143,.16)}@media(max-width:420px){.game-start-panel,.game-party-panel,.game-scene,.game-log,.game-checks,.game-quick-actions,.game-input-bar,.combat-narrative,.combat-enemies,.combat-party,.combat-log,.combat-turn-indicator,.scene-map-container,.combat-grid-wrapper{border-radius:20px}.game-check-btn{grid-template-columns:1fr;gap:6px}.game-check-info,.combat-grid-tip{text-align:left}.game-quick-actions{grid-template-columns:1fr}.map-hud{flex-direction:column;align-items:stretch}.map-hud-chips{justify-content:flex-start}.map-help-hint{max-width:calc(100% - 146px)}}.app-content-navless{padding-bottom:calc(var(--safe-bottom) + 18px)}.app:after{background:radial-gradient(circle at bottom,rgba(163,127,84,.15),transparent 68%)}.app-crest,.home-hero-emblem{background:radial-gradient(circle at 30% 24%,rgba(255,255,255,.56),transparent 0 28%),linear-gradient(180deg,#92adc2,#4d687c 48%,#243645);border-color:#d8e3ec61}.btn-primary{background:linear-gradient(180deg,#99b4c8,#5b7790 44%,#2d4050);border-color:#d6e4ee66;box-shadow:0 14px 24px #30485b3d,inset 0 1px #ffffff5c}.btn-primary:hover:not(:disabled){box-shadow:0 16px 28px #30485b47,inset 0 1px #ffffff6b}.chrome-pill-highlight,.nav-tab.active,.home-status-pill.active{background:linear-gradient(180deg,#859cb24d,#44526257),#121c28b8}.menu-grid-home .menu-card:nth-child(1),.home-session-visual{background:linear-gradient(180deg,#5c6f843d,#121a26e6),#0a0e16db}.home-hero,.home-session-spotlight,.home-board,.page-header{background:linear-gradient(180deg,#484d54d6,#131b24f0),linear-gradient(145deg,rgba(155,126,83,.08),transparent 48%),#080d14eb}.home-session-glow,.home-hero:after{background:radial-gradient(circle,rgba(170,140,96,.18),transparent 68%)}.mood-mysterious{background:#57657d38;color:#b8c8da}.game-check-btn{border-color:#6c8bab70}.game-check-btn:hover:not(:disabled){border-color:#ddbd8485}.menu-icon,.nav-icon,.map-hud-icon,.game-header-icon{color:#d7ccb6}.cc-page{display:flex;flex-direction:column;gap:14px;padding-bottom:24px}.cc-progress{margin-bottom:6px}.cc-step{margin-bottom:0}.cc-nav{position:sticky;bottom:calc(var(--safe-bottom) + 8px);left:auto;right:auto;z-index:14;margin-top:4px;padding:10px;border-radius:24px;border:1px solid rgba(225,205,173,.14);background:linear-gradient(180deg,#212a36f0,#0f151ffa);box-shadow:inset 0 1px #ffffff0f,0 18px 28px #02060b3d;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.cc-nav .btn{min-height:46px}.game-action-stack{gap:12px}.game-input-bar{position:static;bottom:auto;z-index:auto;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:inset 0 1px #ffffff0f,0 14px 24px #02060b2e}.combat-budget{margin-bottom:10px}.combat-tray{position:static;bottom:auto}.scene-map-container{display:flex;flex-direction:column;gap:12px;padding:14px}.map-hud{position:static;inset:auto;z-index:auto;align-items:center;pointer-events:auto}.map-hud-chip span{white-space:nowrap}.map-controls{position:static;right:auto;left:auto;bottom:auto;z-index:auto;align-items:flex-end;justify-content:space-between;pointer-events:auto}.map-control-stack{display:flex;flex:1;min-width:0;flex-direction:column;gap:8px}.map-help-hint{max-width:none;pointer-events:auto}.map-action-strip{display:flex;flex-wrap:wrap;gap:8px}.map-action-btn{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:14px;border:1px solid rgba(224,203,169,.14);background:linear-gradient(180deg,#fff7e814,#0c121aeb),#090d14e0;color:var(--text-primary);font-family:var(--font-display);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.map-action-btn.primary{border-color:#6d8eb147;color:#c7d8e8}.map-action-btn.placeholder{opacity:.72}.map-dpad{flex-shrink:0;background:linear-gradient(180deg,#1f2630e0,#0c1118f5)}.dpad-btn{background:linear-gradient(180deg,#3b4047f5,#14181ffa);color:#f0d8a1}@media(max-width:420px){.cc-nav{bottom:calc(var(--safe-bottom) + 6px)}.map-hud{align-items:stretch}.map-controls{flex-direction:column;align-items:stretch}.map-dpad{align-self:flex-end}.map-action-strip{flex-direction:column}.map-action-btn{width:100%}}.game-page-split{display:flex;flex-direction:column;min-height:100dvh;height:100dvh;padding:calc(var(--chrome-height) + var(--safe-top) + 10px) 12px calc(var(--safe-bottom) + 12px);overflow:hidden}.session-split-shell{display:grid;grid-template-rows:minmax(0,47%) minmax(0,53%);gap:12px;flex:1;min-height:0}.session-stage,.session-bottom-sheet{min-height:0;border-radius:28px;border:1px solid rgba(229,207,176,.14);background:linear-gradient(180deg,#3e444d85,#0a0f16f5),linear-gradient(145deg,rgba(171,137,82,.08),transparent 52%),#080c12f0;box-shadow:inset 0 1px #ffffff0f,0 18px 30px #02060b3d;overflow:hidden}.session-stage{display:flex;flex-direction:column;padding:10px;gap:10px}.session-stage-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.session-stage-copy{display:flex;min-width:0;flex:1;flex-direction:column;gap:4px}.session-stage-kicker{font-size:10px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--text-secondary)}.session-stage-title{font-family:var(--font-display);font-size:20px;line-height:1.1;color:var(--text-primary)}.session-stage-meta{display:flex;flex-wrap:wrap;gap:6px}.session-stage-pill,.session-panel-pill{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid rgba(229,207,176,.12);background:#0a0f16d6;color:var(--text-secondary);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.session-stage-pill.accent,.session-panel-pill.accent{color:#d8c7a4;border-color:#d8b3783d}.session-stage-pill.muted,.session-panel-pill.muted{color:#aab7c6;border-color:#8296b129}.session-stage-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:16px;border:1px solid rgba(229,207,176,.14);background:linear-gradient(180deg,#fff7e814,#0f151fd6),#0b1018eb;color:var(--text-gold)}.session-stage-chip-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.session-stage-chip-row::-webkit-scrollbar{display:none}.session-stage-chip-row .combat-init-token{min-width:92px;padding:8px 10px;border-radius:16px}.session-stage-mapframe{display:flex;flex:1;min-height:0;align-items:center;justify-content:center;overflow:hidden}.session-stage-mapframe .scene-map-container{display:flex;width:100%;height:100%;align-items:center;justify-content:center;padding:0;border:0;background:transparent;box-shadow:none}.session-stage-mapframe .scene-map-canvas,.session-stage-mapframe .combat-grid-canvas{max-width:100%;max-height:100%}.session-stage-mapframe .scene-map-tooltip{z-index:3}.scene-map-container.map-nohud.map-nocontrols{gap:0}.session-stage-empty{display:grid;place-items:center;width:100%;height:100%;padding:18px;border-radius:22px;border:1px dashed rgba(229,207,176,.18);background:#0a0f16b8;color:var(--text-secondary);text-align:center;line-height:1.6}.session-bottom-sheet{display:flex;flex-direction:column;padding:10px;gap:8px}.session-swipe-hint{text-align:center;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#d8c7a99e}.swipe-pager{display:flex;min-height:0;flex:1;flex-direction:column;gap:10px}.swipe-pager-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.swipe-pager-tab{min-height:42px;border-radius:16px;border:1px solid rgba(229,207,176,.12);background:linear-gradient(180deg,#fff7e814,#0f151fd6),#0b1018eb;color:var(--text-secondary);font-family:var(--font-display);font-size:13px;letter-spacing:.08em;text-transform:uppercase}.swipe-pager-tab.active{color:var(--text-primary);border-color:#d8b3783d;background:linear-gradient(180deg,#6c80922e,#141d28d6),#0b1018f0}.swipe-pager-viewport{display:grid;flex:1;min-height:0;grid-auto-columns:100%;grid-auto-flow:column;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;overscroll-behavior-x:contain}.swipe-pager-viewport::-webkit-scrollbar{display:none}.swipe-pager-page{min-width:0;height:100%;overflow:hidden;scroll-snap-align:start}.swipe-pager-dots{display:flex;justify-content:center;gap:6px}.swipe-pager-dot{width:8px;height:8px;border-radius:999px;background:#ffffff1f}.swipe-pager-dot.active{background:#d8b378c7}.session-sheet-page{display:flex;height:100%;min-height:0;flex-direction:column}.session-sheet-scroll{display:flex;flex:1;min-height:0;flex-direction:column;gap:10px;overflow-y:auto;padding-right:2px;scrollbar-width:none}.session-sheet-scroll::-webkit-scrollbar{display:none}.session-sheet-input{margin-top:10px;flex-shrink:0}.session-panel-card,.session-banner{padding:14px;border-radius:22px;border:1px solid rgba(229,207,176,.12);background:linear-gradient(180deg,#4f545e70,#0d141df2),linear-gradient(145deg,rgba(164,130,80,.06),transparent 52%),#090d14eb;box-shadow:inset 0 1px #ffffff0d,0 14px 24px #02060b2e}.session-panel-hero{gap:12px}.session-panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:12px}.session-panel-kicker{margin-bottom:4px;font-size:10px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--text-secondary)}.session-panel-title{font-family:var(--font-display);font-size:18px;line-height:1.12;color:var(--text-primary)}.session-inline-action{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:0 12px;border-radius:14px;border:1px solid rgba(229,207,176,.16);background:#0a0f16b8;color:var(--text-secondary);font-size:12px;font-weight:700}.session-inline-action:disabled{opacity:.58}.session-control-hero{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center}.session-control-copy{display:flex;min-width:0;flex-direction:column;gap:8px}.session-control-label{font-family:var(--font-display);font-size:16px;color:var(--text-primary)}.session-control-text{color:var(--text-secondary);line-height:1.55}.session-dpad{flex-shrink:0}.session-dpad-center{border-style:dashed}.session-party-grid{display:grid;gap:8px}.session-party-card{display:flex;flex-direction:column;gap:4px;padding:12px;border-radius:16px;border:1px solid rgba(229,207,176,.12);background:#0a0f16b8}.session-party-card.me{border-color:#d8b37842}.session-party-name{font-family:var(--font-display);font-size:15px;color:var(--text-primary)}.session-party-meta{color:var(--text-secondary);font-size:12px}.session-map-action-groups{display:flex;flex-direction:column;gap:12px}.session-map-action-group{display:flex;flex-direction:column;gap:8px}.session-map-action-label{font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--text-secondary)}.session-map-action-list{display:grid;gap:8px}.session-map-action{display:flex;flex-direction:column;gap:4px;width:100%;padding:12px 14px;border-radius:16px;border:1px solid rgba(229,207,176,.12);background:linear-gradient(180deg,#111b28f0,#0a0f16fa);color:var(--text-primary);text-align:left}.session-map-action small{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.12em}.session-empty-copy{color:var(--text-secondary);line-height:1.6}.session-story-section{margin-bottom:0}.session-story-text{color:#f1e7d5}.session-story-log .section-title{margin-bottom:10px}.session-inline-error{margin-top:10px;text-align:center}.combat-mode.game-page-split .session-stage-chip-row{margin-top:-2px}.combat-stage-frame{align-items:stretch}.session-combat-grid{display:flex;width:100%;height:100%;align-items:center;justify-content:center;margin:0}.combat-mode.game-page-split .combat-budget{margin-bottom:0}.session-combat-sheet{margin:0}.session-combat-sheet .combat-action-buttons{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.session-combat-sheet .combat-btn.end-turn-full{margin-top:0}@media(max-width:420px){.game-page-split{padding:calc(var(--chrome-height) + var(--safe-top) + 8px) 10px calc(var(--safe-bottom) + 10px)}.session-split-shell{grid-template-rows:minmax(0,45%) minmax(0,55%);gap:10px}.session-stage,.session-bottom-sheet{border-radius:24px}.session-stage-title{font-size:18px}.session-control-hero{grid-template-columns:1fr}.session-dpad{align-self:center}.session-combat-sheet .combat-action-buttons{grid-template-columns:1fr}}
