@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&display=swap";.town-modal .modal-content{width:100vw;height:100vh;max-width:none;max-height:none;border:none;border-radius:0;margin:0;padding:0;background:transparent}.town-menu{position:relative;width:100vw;height:100vh;background-color:var(--bg-primary);background-image:url(/Descent-Cyber-Wizardry/assets/gui/circuit_board.png);background-size:1024px 1024px;background-position:center;background-repeat:no-repeat;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center}.town-menu:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:1024px;height:1024px;background:#0000001a;z-index:1;pointer-events:none}.noise-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");pointer-events:none}.dashboard-logo{display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);margin-top:-310px;z-index:10;pointer-events:none}.dashboard-logo img{width:700px;height:auto;object-fit:contain;filter:drop-shadow(0 0 20px rgba(255,60,60,.4))}.town-container-wrapper{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:1024px;height:1024px;margin:0 auto;width:100%;padding:240px var(--space-4) var(--space-4)}.town-title{text-align:center;margin-bottom:var(--space-6)}.town-title h2{font-family:var(--font-primary);font-size:var(--font-size-3xl);font-weight:700;text-transform:uppercase;letter-spacing:4px;color:#00f2ff;text-shadow:0 0 10px rgba(0,242,255,.6);margin-bottom:var(--space-2)}.town-title p{color:var(--text-secondary);font-size:var(--font-size-sm);max-width:500px}.town-grid-container{display:flex;flex-direction:column;gap:var(--space-4);width:100%;max-width:800px;margin-bottom:var(--space-6)}.town-grid-row{display:flex;gap:var(--space-4);width:100%}.town-grid-row.dual-cards{display:grid;grid-template-columns:1fr 1fr}.town-card-column{display:flex;flex-direction:column;gap:var(--space-4);flex:1}.town-card{background:#001419bf;border:1px solid rgba(0,242,255,.25);box-shadow:0 0 8px #00f2ff14,inset 0 0 4px #00f2ff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-lg);display:flex;align-items:stretch;transition:all .2s ease;position:relative;cursor:pointer;overflow:hidden}.town-card.primary-action{flex:1.5;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:var(--space-6)}.town-card.primary-action .card-icon{font-size:3rem;margin-right:0;margin-bottom:var(--space-4)}.town-card:not(.primary-action){padding:var(--space-4);flex:1}.town-card:hover:not(.disabled){border-color:#00f2ffcc;box-shadow:0 0 15px #00f2ff4d,inset 0 0 8px #00f2ff1a;transform:translateY(-2px)}.town-card.primary-action:hover:not(.disabled){box-shadow:0 0 25px #00f2ff66,inset 0 0 12px #00f2ff33}.town-card.disabled{border-color:#ffffff1a;background:#0a0a0a99;cursor:not-allowed;opacity:.6}.card-icon{font-size:2.5rem;margin-right:var(--space-4);display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 0 5px rgba(255,255,255,.15))}.town-card.disabled .card-icon{filter:grayscale(1);opacity:.5}.card-content{display:flex;flex-direction:column;justify-content:center;flex:1}.card-content h3{font-family:var(--font-primary);font-size:var(--font-size-lg);font-weight:700;text-transform:uppercase;letter-spacing:2px;color:#00f2ff;text-shadow:0 0 5px rgba(0,242,255,.3);margin:0 0 var(--space-1) 0;padding:0;border:none;text-align:left}.town-card.primary-action .card-content h3{text-align:center;font-size:var(--font-size-xl)}.town-card.disabled .card-content h3{color:var(--text-muted);text-shadow:none}.card-content p{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:var(--space-3);line-height:1.4}.card-action-text{font-family:var(--font-primary);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--accent-success);margin-top:auto}.card-action-text.active-text{color:var(--accent-primary)}.card-action-text.disabled-text{color:var(--accent-alert)}.town-card.disabled .card-action-text{color:var(--text-muted)}.party-status-footer{width:100%;max-width:800px;display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:#0009;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);margin-top:auto;font-family:var(--font-primary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:1px}.status-left,.status-right{display:flex;align-items:center;gap:var(--space-2)}.status-label{color:var(--text-muted)}.status-value{color:var(--text-primary);font-weight:700}.status-value.status-active{color:var(--accent-success);text-shadow:0 0 5px rgba(16,185,129,.4)}.status-value.status-inactive{color:var(--accent-alert)}.dashboard-panel{background:#001419bf;border:1px solid rgba(0,242,255,.25);box-shadow:0 0 8px #00f2ff14,inset 0 0 4px #00f2ff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;transition:border-color .2s,box-shadow .2s;position:relative;flex:1;min-height:0}.dashboard-panel:hover{border-color:#00f2ff80;box-shadow:0 0 15px #00f2ff26,inset 0 0 8px #00f2ff0f}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:#0006;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.panel-title{font-family:var(--font-primary);font-size:var(--font-size-lg);font-weight:700;text-transform:uppercase;letter-spacing:2px;color:#00f2ff;text-shadow:0 0 5px rgba(0,242,255,.5),0 0 10px rgba(0,242,255,.25);display:flex;align-items:center;gap:var(--space-2)}.panel-title .icon{font-size:1.2em;filter:drop-shadow(0 0 5px currentColor)}.panel-controls{display:flex;gap:var(--space-2)}.panel-btn-icon{background:transparent;border:1px solid transparent;color:var(--text-muted);font-size:var(--font-size-sm);padding:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.panel-btn-icon:hover{color:var(--text-primary);background:#ffffff1a;border-color:#fff3}.panel-content{flex:1;padding:var(--space-4);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-3);position:relative;min-height:0}.panel-footer{padding:var(--space-2) var(--space-4);border-top:1px solid rgba(255,255,255,.05);font-size:var(--font-size-xs);color:var(--text-muted);background:#0003;display:flex;justify-content:space-between;align-items:center;text-transform:uppercase;letter-spacing:1px;flex-shrink:0}.panel-footer .status{display:flex;align-items:center;gap:6px}.panel-footer .status:before{content:"";display:block;width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 4px currentColor}.status-active{color:var(--accent-success)}.status-critical{color:var(--accent-alert)}.status-warning{color:var(--accent-warning)}.status-neutral{color:var(--text-muted)}.panel-agentops{border-top:3px solid var(--accent-success)}.panel-agentops .panel-title .icon{color:var(--accent-success)}.panel-network{border-top:3px solid var(--accent-alert)}.panel-network .panel-title .icon{color:var(--accent-alert)}.panel-data{border-top:3px solid var(--accent-primary)}.panel-restoration{border-top:3px solid var(--accent-warning)}.panel-restoration .panel-title .icon{color:var(--accent-warning)}.panel-manifest{border-top:3px solid var(--accent-primary)}.panel-manifest .panel-title .icon{color:var(--accent-primary)}.panel-news{border-top:3px solid var(--accent-success)}.panel-news .panel-title .icon{color:var(--accent-success)}.data-table-row{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:var(--font-size-sm)}.data-table-row:last-child{border-bottom:none}.big-stat{display:flex;flex-direction:column;align-items:center;padding:var(--space-4);background:#0000004d;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.05)}.big-stat-value{font-size:var(--font-size-3xl);font-weight:700;color:var(--text-primary);line-height:1.1}.big-stat-label{font-size:var(--font-size-xs);letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}.big-stat.critical .big-stat-value{color:var(--accent-alert);text-shadow:0 0 10px var(--glow-alert)}.big-stat.healthy .big-stat-value{color:var(--accent-success);text-shadow:0 0 10px var(--glow-success)}.panel-info-row{display:flex;align-items:center;gap:var(--space-4)}.panel-info-icon{font-size:2.2rem;flex-shrink:0;filter:drop-shadow(0 0 5px rgba(255,255,255,.15))}.panel-info-text{display:flex;flex-direction:column;gap:2px;font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--text-primary)}.panel-status-badge{margin-top:auto;padding:var(--space-2) var(--space-3);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:1px;text-align:center;color:var(--text-muted)}.panel-status-badge.status-critical{color:var(--accent-alert);border-color:#960c1966}.panel-status-badge.status-alert{color:var(--accent-primary);border-color:#22d3ee4d}.panel-actions{margin-top:auto;display:flex;gap:var(--space-2)}.panel-action-btn{flex:1;padding:var(--space-2) var(--space-3);background:#00f2ff0d;border:1px solid rgba(0,242,255,.3);color:#00f2ff;font-family:var(--font-primary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .2s;text-align:center;border-radius:var(--radius-sm);text-shadow:0 0 4px rgba(0,242,255,.3)}.panel-action-btn:hover:not(:disabled){background:#00f2ff26;color:#fff;border-color:#00f2ff;box-shadow:0 0 12px #00f2ff4d;text-shadow:0 0 6px rgba(0,242,255,.5)}.panel-action-btn.primary{border-color:#00f2ff80;color:#00f2ff}.panel-action-btn:disabled{opacity:.3;cursor:not-allowed}.panel-action-btn.alert{border-color:#ff3c3c66;color:var(--accent-alert);background:#ff3c3c0d}.panel-action-btn.alert:hover:not(:disabled){background:#ff3c3c26;border-color:var(--accent-alert);box-shadow:0 0 12px #ff3c3c4d}.status-indicator{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:1px;color:var(--accent-success);text-shadow:0 0 4px var(--accent-success)}.crt-overlay{background:linear-gradient(#12101000 50%,#00000040 50%),linear-gradient(90deg,#ff00000f,#00ff0005,#0000ff0f);background-size:100% 2px,3px 100%;pointer-events:none;position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;opacity:.6;animation:flicker .15s infinite}.crt-overlay:after{content:" ";display:block;position:absolute;inset:0;background:linear-gradient(#12101000 50%,#0000001a 50%);background-size:100% 4px;z-index:2;animation:scanline 10s linear infinite;pointer-events:none}@keyframes flicker{0%{opacity:.55}5%{opacity:.6}10%{opacity:.55}15%{opacity:.6}20%{opacity:.55}50%{opacity:.55}55%{opacity:.6}60%{opacity:.55}to{opacity:.55}}@keyframes scanline{0%{transform:translateY(0)}to{transform:translateY(100vh)}}.dashboard-panel:hover .panel-title{text-shadow:0 0 8px rgba(0,242,255,.6),2px 0 var(--accent-alert),-2px 0 rgba(0,242,255,.8)}@media(max-width:1200px){.dashboard-body{grid-template-columns:1fr 1fr}.dashboard-center{display:none}}@media(max-width:768px){.dashboard-body{grid-template-columns:1fr}.dashboard-logo img{max-height:80px}}:root{--bg-primary: #000000;--bg-secondary: #050505;--bg-tertiary: #0a0a0a;--bg-panel: #080808;--bg-glass: rgba(0, 0, 0, .85);--accent-primary: #22d3ee;--accent-secondary: #00d4ff;--accent-alert: #ef4444;--accent-success: #10b981;--accent-warning: #f59e0b;--accent-data: #a855f7;--text-primary: #f0f0f0;--text-secondary: #9ca3af;--text-muted: #4b5563;--border-primary: #1f2937;--border-accent: #374151;--border-glow: #22d3ee;--glow-primary: rgba(34, 211, 238, .4);--glow-alert: rgba(239, 68, 68, .4);--glow-success: rgba(16, 185, 129, .4);--font-primary: "JetBrains Mono", "Courier New", monospace;--font-size-xs: .7rem;--font-size-sm: .8rem;--font-size-base: .9rem;--font-size-lg: 1.1rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--radius-sm: 2px;--radius-md: 4px;--radius-lg: 8px;--radius-xl: 12px;--transition-fast: .1s ease;--transition-normal: .2s ease;--shadow-card: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-glow: 0 0 15px var(--glow-primary);--shadow-glow-lg: 0 0 25px var(--glow-primary)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-primary);background:linear-gradient(135deg,var(--bg-primary) 0%,#0f1629 100%);color:var(--text-primary);overflow:hidden;font-size:var(--font-size-base);line-height:1.5}#game-container{position:relative;width:100vw;height:100vh;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}#game-canvas{position:absolute;top:0;left:0;background:var(--bg-primary);border:2px solid var(--border-accent);border-radius:var(--radius-lg);box-shadow:var(--shadow-glow);display:none;z-index:500}.game-state-playing #game-canvas,.game-state-dungeon #game-canvas,.game-state-combat #game-canvas{display:block}#ui-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:grid;grid-template-columns:280px 1fr 240px;grid-template-rows:1fr;gap:var(--space-4);padding:var(--space-4)}.panel{background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-4);pointer-events:auto;overflow-y:auto;box-shadow:var(--shadow-card);position:relative}.panel h3{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--accent-alert);margin-bottom:var(--space-4);display:flex;align-items:center;border-bottom:1px solid var(--border-primary);padding-bottom:var(--space-2)}.panel h3:before{content:"";display:inline-block;width:8px;height:8px;background:currentColor;margin-right:8px;border-radius:50%;box-shadow:0 0 8px currentColor}.panel:hover{border-color:var(--border-accent)}#character-panel{grid-column:1}#game-panel{grid-column:2;display:flex;flex-direction:column;border:none;background:transparent;box-shadow:none;padding:0;pointer-events:none}#game-panel>*{pointer-events:auto}#control-panel{grid-column:3}.viewport{flex:1;border:1px solid var(--border-primary);background:#000;margin-bottom:var(--space-4);min-height:400px;display:flex;font-size:var(--font-size-xl);border-radius:var(--radius-lg);box-shadow:inset 0 0 20px #000c;position:relative;overflow:hidden}.viewport:before{content:"";position:absolute;top:10px;left:10px;width:20px;height:20px;border-top:2px solid var(--accent-primary);border-left:2px solid var(--accent-primary);z-index:10;pointer-events:none}.viewport:after{content:"";position:absolute;bottom:10px;right:10px;width:20px;height:20px;border-bottom:2px solid var(--accent-primary);border-right:2px solid var(--accent-primary);z-index:10;pointer-events:none}.viewport canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.message-log{height:180px;border:1px solid var(--border-primary);background:#080808;padding:var(--space-2);overflow-y:auto;font-size:var(--font-size-xs);border-radius:var(--radius-sm);box-shadow:inset 0 0 10px #00000080;color:var(--text-secondary);font-family:Courier New,monospace;line-height:1.4}.message-log::-webkit-scrollbar{width:6px;background:#111}.message-log::-webkit-scrollbar-thumb{background:var(--border-primary)}#movement-controls,#action-controls{margin-bottom:20px}#audio-controls{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-primary)}#toggle-audio{background:var(--bg-secondary);border:1px solid var(--border-primary);color:var(--text-primary);padding:var(--space-2);border-radius:var(--radius-sm);cursor:pointer;font-size:16px;transition:all var(--transition-fast);width:100%}#toggle-audio:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);box-shadow:0 0 10px var(--glow-secondary)}button{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);padding:var(--space-2) var(--space-3);margin:var(--space-1);cursor:pointer;font-family:var(--font-primary);font-size:var(--font-size-xs);width:100%;border-radius:var(--radius-sm);transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:1px;position:relative;overflow:hidden}button:before{content:"";position:absolute;top:0;left:0;width:2px;height:100%;background:var(--accent-primary);opacity:0;transition:opacity .2s}button:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);color:#fff;box-shadow:0 0 10px #3b82f633}button:hover:before{opacity:1}button:active{transform:scale(.98)}button:disabled{color:var(--text-muted);border-color:var(--border-primary);cursor:not-allowed;opacity:.5;background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary))}.exit-btn{background:linear-gradient(145deg,#ff6b00,#ff8500)!important;color:#fff!important;border-color:#ff8500!important;font-weight:700;animation:exitPulse 2s infinite}.exit-btn:hover{background:linear-gradient(145deg,#ff8500,#fa0)!important;transform:translateY(-2px);box-shadow:0 0 20px #ff6b00,var(--shadow-md)}@keyframes exitPulse{0%,to{box-shadow:0 0 10px #ff6b00}50%{box-shadow:0 0 20px #ff6b00,0 0 30px #ff8500}}.treasure-btn{background:linear-gradient(145deg,#10b981,#34d399)!important;color:#fff!important;border-color:#34d399!important;font-weight:700}.treasure-btn:hover{background:linear-gradient(145deg,#34d399,#6ee7b7)!important;transform:translateY(-2px);box-shadow:0 0 20px #10b981,var(--shadow-md)}.treasure-glow{animation:treasurePulse 1.5s infinite}@keyframes treasurePulse{0%,to{box-shadow:0 0 10px #10b981}50%{box-shadow:0 0 20px #10b981,0 0 30px #34d399}}button:disabled:hover{background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));color:var(--text-muted);transform:none;box-shadow:var(--shadow-sm)}h3{color:var(--accent-primary);margin-bottom:var(--space-4);text-align:center;border-bottom:1px solid var(--border-accent);padding-bottom:var(--space-2);font-size:var(--font-size-xl);text-shadow:0 0 10px var(--glow-primary)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#0a0f1cf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-normal)}.modal-content{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:2px solid var(--border-accent);padding:0;max-width:800px;width:95%;max-height:90%;display:flex;flex-direction:column;border-radius:var(--radius-xl);box-shadow:var(--shadow-glow-lg),var(--shadow-lg);animation:slideIn var(--transition-normal)}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--border-accent);background:linear-gradient(145deg,var(--bg-tertiary),var(--bg-secondary));border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:inset 0 1px #ffffff1a}.modal-body{padding:var(--space-6);flex:1;overflow-y:auto;background:linear-gradient(145deg,var(--bg-secondary),var(--bg-primary))}.modal ::-webkit-scrollbar{width:8px;background:var(--panel-bg, #1A1A2E)}.modal ::-webkit-scrollbar-track{background:var(--panel-bg, #1A1A2E);border-radius:4px}.modal ::-webkit-scrollbar-thumb{background:var(--border-color, #16213E);border-radius:4px;border:1px solid var(--panel-bg, #1A1A2E)}.modal ::-webkit-scrollbar-thumb:hover{background:var(--primary-blue, #4A9EFF)}.modal{scrollbar-width:thin;scrollbar-color:var(--border-color, #16213E) var(--panel-bg, #1A1A2E)}.modal-footer{padding:var(--space-6);border-top:1px solid var(--border-accent);background:linear-gradient(145deg,var(--bg-tertiary),var(--bg-secondary));display:flex;justify-content:space-between;align-items:center;border-radius:0 0 var(--radius-xl) var(--radius-xl);box-shadow:inset 0 1px #ffffff1a}.step-indicator{margin-top:10px}.step-progress{width:100%;height:10px;background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));border:1px solid var(--border-accent);margin-bottom:var(--space-4);overflow:hidden;border-radius:var(--radius-sm);box-shadow:inset 0 2px 4px #0000004d}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transition:width var(--transition-normal);box-shadow:0 0 10px var(--glow-primary)}.step-text{color:var(--accent-primary);font-size:var(--font-size-lg);text-align:center;text-shadow:0 0 5px var(--glow-primary)}.step-content{color:var(--text-primary)}.step-content h3{margin-bottom:var(--space-4);color:var(--accent-primary);text-align:left;border-bottom:1px solid var(--border-accent);padding-bottom:var(--space-3);text-shadow:0 0 10px var(--glow-primary)}.step-content p{margin-bottom:var(--space-5);color:var(--text-secondary);line-height:1.6}.race-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:15px;margin-top:20px}.race-option{border:1px solid var(--border-primary);padding:var(--space-4);cursor:pointer;transition:all var(--transition-normal);background:linear-gradient(145deg,var(--bg-secondary),var(--bg-primary));border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.race-option:hover{border-color:var(--accent-primary);background:linear-gradient(145deg,var(--bg-tertiary),var(--bg-secondary));box-shadow:var(--shadow-glow),var(--shadow-md);transform:translateY(-2px)}.race-option.selected{border-color:var(--accent-primary);background:linear-gradient(145deg,var(--bg-tertiary),var(--bg-secondary));box-shadow:var(--shadow-glow-lg),var(--shadow-lg);transform:translateY(-2px)}.race-option h4{color:var(--accent-primary);margin-bottom:var(--space-2);font-size:var(--font-size-lg);text-shadow:0 0 5px var(--glow-primary)}.race-description{color:var(--text-secondary);margin-bottom:var(--space-3);font-style:italic;line-height:1.5}.race-modifiers{margin-bottom:10px}.modifier{display:inline-block;margin-right:10px;margin-bottom:5px;padding:2px 6px;border-radius:3px;font-size:12px}.modifier.positive{background:linear-gradient(145deg,var(--success),rgba(16,185,129,.2));color:var(--success);border:1px solid var(--success);border-radius:var(--radius-sm);box-shadow:0 0 5px #10b9814d}.modifier.negative{background:linear-gradient(145deg,var(--warning),rgba(245,158,11,.2));color:var(--warning);border:1px solid var(--warning);border-radius:var(--radius-sm);box-shadow:0 0 5px #f59e0b4d}.no-modifiers{color:var(--text-muted);font-style:italic}.race-abilities,.race-restrictions{margin-top:var(--space-2);font-size:var(--font-size-xs);color:var(--text-secondary)}.attribute-display{margin:20px 0}.attributes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:20px}.attribute-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);border:1px solid var(--border-primary);background:linear-gradient(145deg,var(--bg-secondary),var(--bg-primary));border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.attribute-name{font-weight:700;color:var(--accent-primary);text-shadow:0 0 5px var(--glow-primary)}.attribute-value{font-weight:700;color:var(--text-primary);font-size:var(--font-size-xl);text-shadow:0 0 3px var(--glow-secondary)}.attribute-total{text-align:center;margin:var(--space-5) 0;font-size:var(--font-size-xl);color:var(--accent-primary);text-shadow:0 0 10px var(--glow-primary);font-weight:700}.reroll-section{text-align:center;margin-top:30px}.reroll-info{margin-top:10px;font-size:12px;color:#888}.class-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:15px;margin-top:20px}.class-option{border:1px solid #006600;padding:15px;cursor:pointer;transition:all .3s ease;background-color:#00000080}.class-option:hover:not(.disabled){border-color:#0f0;background-color:#00ff001a}.class-option.selected{border-color:#0f0;background-color:#0f03;box-shadow:0 0 10px #00ff004d}.class-option.disabled{opacity:.5;cursor:not-allowed;border-color:#333}.class-option h4{color:#0f0;margin-bottom:8px;font-size:18px}.class-description{color:#ccc;margin-bottom:10px;font-style:italic}.class-requirements,.class-stats{margin-bottom:10px;font-size:12px}.requirement-met{color:#0f0}.requirement-failed{color:#f60}.unavailable-reason{color:#f60;font-weight:700;margin-top:10px;text-align:center}.character-form{max-width:500px;margin:0 auto}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#0f0;font-weight:700}.form-group input{width:100%;padding:10px;background-color:#000;color:#0f0;border:1px solid #00ff00;font-family:Courier New,monospace;font-size:16px}.form-group small{color:#888;font-size:12px}.character-summary{margin-top:10px;padding:var(--space-3);border:1px solid var(--border-primary);background-color:var(--bg-tertiary);border-left:3px solid var(--border-primary);transition:all var(--transition-fast);cursor:pointer;position:relative;overflow:hidden}.character-summary:hover{background-color:var(--bg-secondary);border-left-color:var(--accent-primary);box-shadow:0 0 10px #00000080}.character-summary.leader{border-left-color:var(--accent-success);background:linear-gradient(90deg,rgba(16,185,129,.05),transparent)}.character-summary.leader:after{content:"LEADER";position:absolute;top:2px;right:2px;font-size:8px;color:var(--accent-success);opacity:.5}.character-summary h4{color:#0f0;margin-bottom:15px;text-align:center}.summary-grid{display:grid;gap:10px}.attributes-summary .attributes-grid{grid-template-columns:repeat(2,1fr);gap:10px}.character-confirmation{display:flex;gap:30px;align-items:flex-start}.character-portrait{flex-shrink:0}.portrait-placeholder{width:100px;height:120px;display:flex;align-items:center;justify-content:center;font-weight:700;text-align:center;word-break:break-word;font-size:2rem}.character-details{flex:1}.character-details h4{color:#0f0;margin-bottom:15px;font-size:24px}.character-details p{margin-bottom:10px;color:#ccc}.final-attributes,.calculated-stats{margin-top:20px;padding:15px;border:1px solid #006600;background-color:#00ff000d}.final-attributes h5,.calculated-stats h5{color:#0f0;margin-bottom:10px;border-bottom:1px solid #006600;padding-bottom:5px}.final-attributes .attributes-grid{grid-template-columns:repeat(2,1fr);gap:8px}.final-attributes .attribute-item{padding:5px 10px;font-size:14px}.btn-primary,.btn-secondary,.btn-cancel{padding:var(--space-3) var(--space-5);border:1px solid var(--border-accent);background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));color:var(--text-primary);cursor:pointer;font-family:var(--font-primary);font-size:var(--font-size-base);transition:all var(--transition-normal);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);font-weight:600}.btn-primary:hover:not(:disabled){background:linear-gradient(145deg,var(--accent-primary),var(--accent-secondary));color:var(--bg-primary);border-color:var(--accent-secondary);box-shadow:var(--shadow-glow),var(--shadow-md);transform:translateY(-2px)}.btn-secondary{border-color:var(--border-primary);color:var(--text-secondary);background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary))}.btn-secondary:hover:not(:disabled){border-color:var(--accent-primary);color:var(--accent-primary);background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));box-shadow:var(--shadow-glow),var(--shadow-md);transform:translateY(-2px)}.btn-cancel{border-color:var(--danger);color:var(--danger);background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary))}.btn-cancel:hover{background:linear-gradient(145deg,var(--danger),rgba(239,68,68,.8));color:var(--bg-primary);border-color:var(--danger);box-shadow:0 0 20px #ef444466,var(--shadow-md);transform:translateY(-2px)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed;background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));color:var(--text-muted);border-color:var(--border-primary)}.btn-primary:disabled:hover,.btn-secondary:disabled:hover{background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));color:var(--text-muted);transform:none;box-shadow:var(--shadow-sm)}.modal h2{color:#0f0;margin-bottom:20px}.no-party{text-align:center;padding:20px;color:#666}.no-party p{margin-bottom:15px}.party-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #006600}.party-header h4{margin:0;color:#0f0}.character-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2);border-bottom:1px solid var(--border-primary);padding-bottom:2px}.character-name{font-weight:700;color:var(--text-primary);font-size:var(--font-size-base);text-shadow:0 0 5px var(--glow-primary)}.character-level{color:var(--accent-secondary);font-size:var(--font-size-xs);font-weight:700}.character-info{margin-bottom:var(--space-2)}.character-race-class{color:var(--text-muted);font-size:var(--font-size-xs);margin-bottom:var(--space-1);text-transform:uppercase}.character-hp{display:flex;align-items:center;margin-bottom:3px}.hp-bar-container{flex:1;height:8px;background-color:#222;border:1px solid #333;margin-right:8px;position:relative;overflow:hidden}.hp-bar{height:100%;transition:width .3s ease;background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:1rem 1rem}.hp-bar.healthy{background-color:var(--accent-success);box-shadow:0 0 5px var(--accent-success)}.hp-bar.wounded{background-color:#f59e0b;box-shadow:0 0 5px #f59e0b}.hp-bar.critical{background-color:var(--accent-alert);box-shadow:0 0 5px var(--accent-alert)}.hp-text{font-size:10px;color:#ccc;min-width:35px}.character-status{font-size:10px;font-weight:700}.character-status.ok{color:#0f0}.character-status.poisoned{color:#f60}.character-status.dead{color:red}.character-status.unconscious{color:#666}.character-actions{display:flex;gap:5px;margin-top:5px}.party-actions{margin-top:15px;display:flex;flex-direction:column;gap:5px}.btn-small{padding:5px 10px;border:1px solid #00ff00;background-color:#000;color:#0f0;cursor:pointer;font-family:Courier New,monospace;font-size:11px;transition:all .3s ease}.btn-small:hover{background-color:#0f0;color:#000}.btn-tiny{padding:2px 6px;border:1px solid #006600;background-color:#000;color:#ccc;cursor:pointer;font-family:Courier New,monospace;font-size:9px;transition:all .3s ease}.btn-tiny:hover{border-color:#0f0;color:#0f0;background-color:#00ff001a}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;color:#0f0}.form-group select,.form-group input{width:100%;padding:5px;background-color:#000;color:#0f0;border:1px solid #00ff00;font-family:Courier New,monospace}.attribute-display{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0}.attribute-item{display:flex;justify-content:space-between;padding:5px;border:1px solid #006600}.attribute-bonus{color:#0f0}.attribute-penalty{color:#f60}.class-list{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0}.class-item{padding:10px;border:1px solid #00ff00;cursor:pointer;text-align:center}.class-item:hover{background-color:#0f0;color:#000}.class-item.disabled{border-color:#060;color:#060;cursor:not-allowed}.class-item.disabled:hover{background-color:#000;color:#060}.hidden{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%,to{box-shadow:0 0 5px var(--glow-primary)}50%{box-shadow:0 0 20px var(--glow-primary),0 0 30px var(--glow-primary)}}@keyframes glow{0%,to{text-shadow:0 0 5px var(--glow-primary)}50%{text-shadow:0 0 10px var(--glow-primary),0 0 15px var(--glow-primary)}}.town-interface,.training-grounds-interface{text-align:center;padding:var(--space-8);color:var(--text-primary)}.equipment-item.cyber-enhanced{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-accent);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-2);transition:all var(--transition-fast)}.equipment-item.cyber-enhanced:hover{border-color:var(--accent-primary);box-shadow:0 0 10px var(--glow-primary)}.equipment-slot{display:flex;align-items:center;gap:var(--space-2);font-weight:600;color:var(--accent-secondary);margin-bottom:var(--space-1)}.equipment-icon{font-size:var(--font-size-lg);filter:drop-shadow(0 0 5px var(--glow-primary))}.equipment-details{display:flex;flex-direction:column;gap:var(--space-1);align-items:flex-start}.equipment-name[data-cyber-enhanced=true]{color:var(--accent-primary);text-shadow:0 0 5px var(--glow-primary);font-weight:500}.digital-classification,.program-class,.encryption-level{font-size:var(--font-size-xs);color:var(--accent-tertiary);background:#3b82f61a;padding:2px 6px;border-radius:var(--radius-sm);border:1px solid var(--accent-primary);margin-left:var(--space-2)}.spell-level.program-tier{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-accent);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-3)}.tier-header{display:flex;align-items:center;gap:var(--space-2);color:var(--accent-primary);font-size:var(--font-size-lg);margin-bottom:var(--space-3);border-bottom:1px solid var(--border-accent);padding-bottom:var(--space-2)}.tier-icon{filter:drop-shadow(0 0 5px var(--glow-primary))}.spell-list.program-suite{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-2)}.spell-item.cyber-enhanced{background:linear-gradient(135deg,#3b82f61a,#3b82f60d);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast);display:flex;flex-direction:column;gap:var(--space-1)}.spell-item.cyber-enhanced:hover{background:linear-gradient(135deg,#3b82f633,#3b82f61a);box-shadow:0 0 8px var(--glow-primary);transform:translateY(-1px)}.spell-name{font-weight:500;color:var(--text-primary)}.spell-item[data-cyber-enhanced=true] .spell-name{color:var(--accent-secondary);text-shadow:0 0 3px var(--glow-primary)}.program-type,.execution-method,.algorithm-class{font-size:var(--font-size-xs);color:var(--accent-tertiary);background:#60a5fa1a;padding:1px 4px;border-radius:var(--radius-sm);border:1px solid var(--accent-secondary);align-self:flex-start}.no-spells.cyber-enhanced{color:var(--text-muted);font-style:italic;text-align:center;padding:var(--space-4);background:#64748b1a;border:1px dashed var(--border-primary);border-radius:var(--radius-md)}.inventory-container{background:linear-gradient(135deg,var(--bg-primary),var(--bg-secondary));border:2px solid var(--border-accent);border-radius:var(--radius-lg);padding:var(--space-6);margin:var(--space-4);box-shadow:var(--shadow-glow)}.inventory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:2px solid var(--border-accent)}.inventory-title{color:var(--accent-primary);font-size:var(--font-size-2xl);text-shadow:0 0 10px var(--glow-primary)}.inventory-stats{display:flex;gap:var(--space-4);color:var(--text-secondary);font-size:var(--font-size-sm)}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-3);margin-bottom:var(--space-4)}.inventory-item{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-3);transition:all var(--transition-normal);cursor:pointer}.inventory-item:hover{border-color:var(--accent-primary);box-shadow:0 0 15px var(--glow-primary);transform:translateY(-2px)}.inventory-item.cyber-enhanced{background:linear-gradient(145deg,#3b82f61a,#3b82f60d);border-color:var(--accent-primary)}.item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2)}.item-name{font-weight:600;color:var(--text-primary);font-size:var(--font-size-base)}.item-type{font-size:var(--font-size-xs);color:var(--accent-tertiary);background:#93c5fd1a;padding:2px 6px;border-radius:var(--radius-sm);border:1px solid var(--accent-tertiary)}.item-stats{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.item-stat{font-size:var(--font-size-xs);color:var(--text-secondary);background:#cbd5e11a;padding:2px 4px;border-radius:var(--radius-sm)}.item-description{font-size:var(--font-size-sm);color:var(--text-muted);line-height:1.4;margin-bottom:var(--space-2)}.item-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.item-action-btn{padding:var(--space-1) var(--space-2);border:1px solid var(--border-accent);background:var(--bg-secondary);color:var(--text-primary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.item-action-btn:hover{background:var(--accent-primary);color:var(--bg-primary);box-shadow:0 0 5px var(--glow-primary)}.item-durability{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border-primary)}.durability-bar{width:100%;height:4px;background:var(--bg-primary);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--space-1)}.durability-fill{height:100%;border-radius:var(--radius-sm);transition:all var(--transition-normal)}.durability-fill.good{background:var(--success)}.durability-fill.worn{background:var(--warning)}.durability-fill.damaged{background:var(--danger)}.durability-fill.broken{background:var(--text-muted)}.durability-text{font-size:var(--font-size-xs);color:var(--text-muted);text-align:center}.character-sheet-modal{z-index:2000}.memorial-modal{z-index:1500}.memorial-character-card{position:relative;cursor:pointer;transition:all var(--transition-fast);isolation:isolate;background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary))!important;border:1px solid var(--border-accent)!important;color:var(--text-primary)!important;border-color:var(--border-accent)!important}.memorial-character-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow);border-color:var(--accent-secondary)!important;background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary))!important}.memorial-character-card.clickable-card:hover{border-color:var(--accent-secondary)!important;background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary))!important}.memorial-card-status{display:flex;align-items:center;justify-content:center;padding:var(--space-2) var(--space-3);background:linear-gradient(135deg,#ef44441a,#ef44440d);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);margin-top:var(--space-2);margin-bottom:var(--space-12);position:relative;z-index:5}.memorial-status-indicator{display:flex;align-items:center;gap:var(--space-2)}.memorial-icon{font-size:var(--font-size-lg);opacity:.8}.memorial-text{font-size:var(--font-size-sm);color:var(--danger);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.memorial-redact-btn{position:absolute;bottom:var(--space-2);left:var(--space-2);right:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs);z-index:10;opacity:.8;transition:opacity var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast);border-radius:var(--radius-md);background-clip:padding-box;isolation:isolate;overflow:hidden;background:var(--danger)!important;border:1px solid var(--danger)!important;color:#fff!important;box-shadow:none!important;text-shadow:none!important;filter:none!important;background-image:none!important;background-origin:padding-box!important;background-attachment:scroll!important}.memorial-redact-btn:hover{opacity:1;background:#dc2626!important;background-image:none!important;border-color:#dc2626!important;isolation:isolate;z-index:20;color:#fff!important;border:1px solid #dc2626!important}.memorial-character-card .memorial-redact-btn{pointer-events:all}.status-lost{color:var(--danger)!important;font-weight:600}.modal.character-delete-modal,.delete-confirmation-modal.character-delete-modal{z-index:2500!important}.roster-subtitle{display:flex;align-items:center;gap:var(--space-2, .5rem);font-size:var(--font-size-lg, 1.125rem);color:var(--text-secondary, #cbd5e1);margin-bottom:var(--space-4, 1rem)}.character-count{color:var(--text-muted, #64748b);font-weight:400}.btn-title{display:flex;align-items:center;gap:var(--space-2, .5rem)}.btn-count{color:var(--text-muted, #64748b);font-weight:400}.character-sheet-container{width:90vw;max-width:1200px;height:85vh;max-height:900px;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--bg-primary),var(--bg-secondary));border:2px solid var(--border-accent);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-glow-lg)}.character-sheet-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-6);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border-bottom:2px solid var(--border-accent);box-shadow:0 2px 10px #0000004d}.character-title-section{display:flex;align-items:center;gap:var(--space-4)}.character-portrait{width:80px;height:80px}.portrait-frame{width:100%;height:100%;border:2px solid var(--accent-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));position:relative;overflow:hidden}.cyber-portrait{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center}.portrait-grid{position:absolute;inset:0;opacity:.3}.portrait-grid .grid-line{position:absolute;background:var(--accent-primary)}.portrait-grid .grid-line.horizontal{width:100%;height:1px;top:50%}.portrait-grid .grid-line.vertical{height:100%;width:1px;left:50%}.portrait-data{position:absolute;top:5px;right:5px;display:flex;flex-direction:column;gap:2px}.system-indicator{width:8px;height:8px;border-radius:50%;background:var(--success);animation:pulse 2s infinite}.portrait-avatar{font-size:var(--font-size-3xl);color:var(--accent-primary);text-shadow:0 0 10px var(--glow-primary);z-index:1}.character-basic-info{display:flex;flex-direction:column;gap:var(--space-2)}.character-name{color:var(--accent-primary);font-size:var(--font-size-3xl);font-weight:700;text-shadow:0 0 15px var(--glow-primary);margin:0}.character-class-level{display:flex;gap:var(--space-4);color:var(--text-secondary);font-size:var(--font-size-lg)}.character-status-indicators{display:flex;flex-direction:column;gap:var(--space-2)}.status-indicator{display:flex;align-items:center;gap:var(--space-2)}.status-label{min-width:100px;color:var(--text-secondary);font-size:var(--font-size-sm)}.health-bar{width:150px;height:8px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);overflow:hidden}.health-fill{height:100%;border-radius:var(--radius-sm);transition:all var(--transition-normal)}.health-fill.good{background:linear-gradient(90deg,var(--success),#22c55e)}.health-fill.warning{background:linear-gradient(90deg,var(--warning),#f59e0b)}.health-fill.critical{background:linear-gradient(90deg,var(--danger),#ef4444)}.health-text{color:var(--text-primary);font-size:var(--font-size-sm);font-weight:600}.status-value{color:var(--accent-secondary);font-weight:600;text-transform:capitalize}.character-sheet-nav{background:var(--bg-secondary);border-bottom:1px solid var(--border-accent);padding:0 var(--space-6)}.nav-tabs{display:flex;gap:var(--space-2)}.nav-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all var(--transition-fast);font-family:var(--font-primary);font-size:var(--font-size-base)}.nav-tab:hover{color:var(--accent-secondary);background:#3b82f61a}.nav-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);background:#3b82f626;text-shadow:0 0 5px var(--glow-primary)}.tab-icon{font-size:var(--font-size-lg)}.character-sheet-content{flex:1;overflow-y:auto;padding:var(--space-6)}.tab-content{height:100%}.character-sheet-footer{background:var(--bg-secondary);border-top:1px solid var(--border-accent);padding:var(--space-4) var(--space-6)}.footer-stats{display:flex;gap:var(--space-6);justify-content:center}.footer-stat{display:flex;gap:var(--space-2);align-items:center}.footer-stat .stat-label{color:var(--text-secondary);font-size:var(--font-size-sm)}.footer-stat .stat-value{color:var(--accent-primary);font-weight:600}.overview-content{height:100%}.overview-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:var(--space-6);height:100%}.overview-section{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-accent);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-md)}.section-title{color:var(--accent-primary);font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--space-3);text-shadow:0 0 5px var(--glow-primary);border-bottom:1px solid var(--border-accent);padding-bottom:var(--space-2)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.stat-item{display:flex;flex-direction:column;gap:var(--space-1)}.stat-item .stat-label{color:var(--text-secondary);font-size:var(--font-size-sm)}.stat-item .stat-value{color:var(--accent-secondary);font-size:var(--font-size-lg);font-weight:600}.info-grid{display:flex;flex-direction:column;gap:var(--space-2)}.info-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2);background:#3b82f60d;border-radius:var(--radius-sm);border:1px solid rgba(59,130,246,.2)}.info-label{color:var(--text-secondary);font-size:var(--font-size-sm)}.info-value{color:var(--text-primary);font-weight:500}.activity-log{max-height:200px;overflow-y:auto}.activity-item{padding:var(--space-2);border-bottom:1px solid var(--border-primary);display:flex;flex-direction:column;gap:var(--space-1)}.activity-item:last-child{border-bottom:none}.activity-time{color:var(--text-muted);font-size:var(--font-size-xs)}.activity-description{color:var(--text-primary);font-size:var(--font-size-sm)}.no-activity{color:var(--text-muted);text-align:center;font-style:italic;padding:var(--space-4)}.close-btn.cyber-btn{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--danger),#dc2626);border:2px solid var(--danger);color:#fff;font-size:var(--font-size-xl);font-weight:700;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.close-btn.cyber-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 0 15px #ef444480;transform:scale(1.1)}.town-interface h2,.training-grounds-interface h2{color:var(--accent-primary);font-size:var(--font-size-3xl);margin-bottom:var(--space-6);text-shadow:0 0 15px var(--glow-primary);animation:glow 2s ease-in-out infinite}.town-interface p,.training-grounds-interface p{color:var(--text-secondary);font-size:var(--font-size-lg);margin-bottom:var(--space-8);line-height:1.6}.town-locations,.training-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-8)}.location-btn,.action-btn{padding:var(--space-4) var(--space-6);border:1px solid var(--border-accent);background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));color:var(--text-primary);cursor:pointer;font-family:var(--font-primary);font-size:var(--font-size-base);border-radius:var(--radius-lg);transition:all var(--transition-normal);box-shadow:var(--shadow-md);font-weight:600;min-height:60px;display:flex;align-items:center;justify-content:center}.location-btn:hover:not(:disabled),.action-btn:hover:not(:disabled){background:linear-gradient(145deg,var(--accent-primary),var(--accent-secondary));color:var(--bg-primary);border-color:var(--accent-secondary);box-shadow:var(--shadow-glow),var(--shadow-lg);transform:translateY(-3px)}.action-btn.primary{background:linear-gradient(145deg,var(--accent-primary),var(--accent-secondary));color:var(--bg-primary);border-color:var(--accent-secondary);box-shadow:var(--shadow-glow),var(--shadow-md)}.action-btn.primary:hover:not(:disabled){background:linear-gradient(145deg,var(--accent-secondary),var(--accent-tertiary));box-shadow:var(--shadow-glow-lg),var(--shadow-lg);transform:translateY(-3px) scale(1.02)}.action-btn.secondary{background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));color:var(--text-secondary);border-color:var(--border-primary)}.action-btn.danger{background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));color:var(--danger);border-color:var(--danger);max-width:93%}.action-btn.danger:hover:not(:disabled){background:linear-gradient(145deg,var(--danger),rgba(239,68,68,.8));color:var(--bg-primary);box-shadow:0 0 20px #ef444466,var(--shadow-lg)}.party-status{padding:var(--space-6);background:linear-gradient(145deg,var(--bg-secondary),var(--bg-primary));border:1px solid var(--border-accent);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.party-status h3{color:var(--accent-primary);margin-bottom:var(--space-4);text-shadow:0 0 10px var(--glow-primary)}.party-status p{color:var(--text-secondary);font-size:var(--font-size-base);margin:0}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2000}.loading-title{font-size:var(--font-size-3xl);color:var(--accent-primary);margin-bottom:var(--space-5);text-align:center;text-shadow:0 0 15px var(--glow-primary);animation:glow 2s ease-in-out infinite}.loading-subtitle{font-size:var(--font-size-xl);color:var(--accent-secondary);margin-bottom:var(--space-10);text-align:center;text-shadow:0 0 10px var(--glow-secondary)}.loading-progress{width:300px;height:20px;border:2px solid var(--border-accent);background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));overflow:hidden;border-radius:var(--radius-md);box-shadow:inset 0 2px 4px #0000004d}.loading-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));width:0%;transition:width var(--transition-normal);box-shadow:0 0 10px var(--glow-primary);animation:pulse 2s ease-in-out infinite}.town-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0a0f1cf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;transition:opacity var(--transition-normal)}.town-modal .modal-content{background:transparent;border:none;border-radius:0;box-shadow:none;width:100%;height:100%;max-width:none;max-height:none;overflow:hidden;animation:fadeIn var(--transition-normal)}.town-modal .modal-body{padding:0;height:100%;overflow:hidden;position:relative}.town-modal .modal-body:before,.town-modal .modal-body:after{display:none}.training-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0a0f1cf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;transition:opacity var(--transition-normal)}.training-modal .modal-content{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:2px solid var(--border-accent);border-radius:var(--radius-xl);box-shadow:var(--shadow-glow-lg),var(--shadow-lg);max-width:800px;width:90%;max-height:90%;overflow:hidden;animation:slideIn var(--transition-normal)}.training-modal .modal-body{padding:var(--space-8);height:100%;overflow-y:auto}.training-grounds-interface{display:flex;flex-direction:column;height:100%;color:var(--text-primary)}.training-header{text-align:center;margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:2px solid var(--border-accent)}.training-title{font-size:var(--font-size-3xl);color:var(--accent-primary);margin-bottom:var(--space-4);text-shadow:0 0 20px var(--glow-primary);animation:glow 3s ease-in-out infinite;font-weight:700}.training-subtitle{font-size:var(--font-size-lg);color:var(--accent-secondary);text-shadow:0 0 10px var(--glow-secondary);margin:0}.training-content{flex:1;display:flex;flex-direction:column;gap:var(--space-8)}.training-actions{display:flex;flex-direction:column;gap:var(--space-4)}.action-btn.large{display:flex;align-items:center;padding:var(--space-5);min-height:80px;text-align:left}.btn-icon{font-size:2rem;margin-right:var(--space-4);flex-shrink:0;filter:drop-shadow(0 0 5px currentColor)}.btn-text{display:flex;flex-direction:column;gap:var(--space-1)}.btn-title{font-size:var(--font-size-lg);font-weight:600;text-shadow:0 0 5px currentColor}.btn-desc{font-size:var(--font-size-sm);opacity:.8}.party-status-section{padding:var(--space-6);background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));border:1px solid var(--border-accent);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.party-status-section h3{color:var(--accent-primary);margin-bottom:var(--space-4);text-shadow:0 0 10px var(--glow-primary)}.status-ready{color:var(--success);font-weight:600;margin:0}.status-empty{color:var(--warning);font-weight:600;margin:0}.action-btn.compact{padding:8px 16px;font-size:.9em;margin-top:10px;display:inline-block;width:auto;min-height:auto;background:#00ffff1a;border:1px solid #00ffff;color:#0ff}.action-btn.compact:hover:not(:disabled){background:#0ff3;box-shadow:0 0 15px #0ff6}.training-footer{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-primary);display:flex;justify-content:center}.roster-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0a0f1cf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1001;opacity:0;transition:opacity var(--transition-normal)}.roster-modal .modal-content{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:2px solid var(--border-accent);border-radius:var(--radius-xl);box-shadow:var(--shadow-glow-lg),var(--shadow-lg);max-width:1200px;width:95%;max-height:90%;overflow:hidden;animation:slideIn var(--transition-normal)}.roster-modal .modal-body{padding:var(--space-8);height:100%;overflow-y:auto}.roster-interface{display:flex;flex-direction:column;height:100%;color:var(--text-primary)}.roster-header{text-align:center;margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:2px solid var(--border-accent)}.roster-title{font-size:var(--font-size-3xl);color:var(--accent-primary);margin-bottom:var(--space-4);text-shadow:0 0 20px var(--glow-primary);animation:glow 3s ease-in-out infinite;font-weight:700;letter-spacing:2px}.roster-subtitle{font-size:var(--font-size-lg);color:var(--accent-secondary);text-shadow:0 0 10px var(--glow-secondary);font-style:italic;margin:0}.roster-content{flex:1;overflow-y:auto}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-6);padding:var(--space-4)}.character-roster-card{background:linear-gradient(145deg,#0006,#0028004d);border:2px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-5);cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.character-roster-card:hover{border-color:var(--accent-primary);background:linear-gradient(145deg,#00280066,#003c004d);box-shadow:0 0 15px #00ff004d;transform:translateY(-2px)}.character-card-header{display:flex;align-items:center;margin-bottom:var(--space-4);gap:var(--space-3)}.class-icon{font-size:var(--font-size-2xl);padding:var(--space-2);background:#00ff001a;border:1px solid var(--border-primary);border-radius:var(--radius-md);min-width:40px;text-align:center}.character-card-name{font-weight:700;color:var(--accent-primary);font-size:var(--font-size-lg);flex:1}.character-card-level{color:var(--text-secondary);font-size:var(--font-size-sm);background:#00ff001a;padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--border-primary)}.character-card-info{margin-bottom:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.character-card-race-class{color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:600}.character-card-location,.character-card-status{display:flex;justify-content:space-between;font-size:var(--font-size-sm)}.location-label,.status-label{color:var(--text-tertiary)}.location-value{color:var(--text-secondary);font-weight:600}.status-value{font-weight:600;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.status-alive{color:var(--success);background:#00ff001a}.status-unconscious{color:var(--warning);background:#ffff001a}.status-dead{color:var(--danger);background:#ff00001a}.status-ashes{color:var(--danger);background:#80000033}.status-lost{color:var(--text-tertiary);background:#8080801a}.character-card-health{display:flex;align-items:center;gap:var(--space-3)}.hp-indicator{flex:1;height:8px;background:#00000080;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-primary)}.hp-bar{height:100%;border-radius:var(--radius-sm);transition:width .3s ease}.hp-indicator.excellent .hp-bar{background:var(--success)}.hp-indicator.good .hp-bar{background:var(--info)}.hp-indicator.wounded .hp-bar{background:var(--warning)}.hp-indicator.critical .hp-bar{background:var(--danger)}.hp-text{color:var(--text-secondary);font-size:var(--font-size-xs);font-weight:600;min-width:60px;text-align:right}.no-characters{text-align:center;padding:var(--space-12);color:var(--text-secondary)}.no-characters-icon{font-size:4rem;margin-bottom:var(--space-6);opacity:.5}.no-characters h3{color:var(--text-primary);margin-bottom:var(--space-4);font-size:var(--font-size-xl)}.no-characters p{color:var(--text-tertiary);font-style:italic}.roster-footer{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-primary);display:flex;justify-content:center}@media(max-width:768px){.character-grid{grid-template-columns:1fr;gap:var(--space-4)}.roster-modal .modal-content{width:98%;max-height:95%}.roster-modal .modal-body{padding:var(--space-4)}}.character-detail-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0a0f1cf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1002;opacity:0;transition:opacity var(--transition-normal)}.character-detail-modal .modal-content{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:2px solid var(--border-accent);border-radius:var(--radius-xl);box-shadow:var(--shadow-glow-lg),var(--shadow-lg);max-width:900px;width:95%;max-height:90%;overflow:hidden;animation:slideIn var(--transition-normal)}.character-detail-modal .modal-body{padding:var(--space-8);height:100%;overflow-y:auto}.character-detail-interface{display:flex;flex-direction:column;height:100%;color:var(--text-primary)}.character-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:2px solid var(--border-accent)}.character-detail-title{display:flex;align-items:center;gap:var(--space-4)}.character-detail-icon{font-size:3rem;padding:var(--space-3);background:#00ff001a;border:2px solid var(--border-primary);border-radius:var(--radius-lg);min-width:80px;text-align:center}.character-detail-name-block{display:flex;flex-direction:column}.character-detail-name{font-size:var(--font-size-3xl);color:var(--accent-primary);margin:0 0 var(--space-2) 0;text-shadow:0 0 20px var(--glow-primary);font-weight:700;letter-spacing:1px}.character-detail-subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);margin:0;font-weight:600}.character-detail-status{display:flex;flex-direction:column;gap:var(--space-2);align-items:flex-end}.status-badge,.location-badge{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;border:1px solid var(--border-primary)}.status-badge{color:var(--success);background:#00ff001a}.location-badge{color:var(--text-secondary);background:#0000004d}.character-detail-content{flex:1;overflow-y:auto}.character-detail-section{margin-bottom:var(--space-8)}.character-detail-section h3{color:var(--accent-primary);font-size:var(--font-size-xl);margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-primary);text-shadow:0 0 10px var(--glow-primary)}.attributes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-4)}.attribute-item{background:#0000004d;border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-4);text-align:center;transition:all .3s ease}.attribute-item:hover{border-color:var(--accent-primary);background:#0028004d}.attribute-name{color:var(--text-tertiary);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-1)}.attribute-value{color:var(--accent-primary);font-size:var(--font-size-2xl);font-weight:700;text-shadow:0 0 10px var(--glow-primary)}.health-exp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6)}.health-section,.exp-section,.sp-section{background:#0000004d;border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-4)}.health-label,.exp-label,.sp-label{color:var(--text-tertiary);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-2)}.health-bar-section{display:flex;align-items:center;gap:var(--space-3)}.exp-value,.sp-value{color:var(--accent-primary);font-size:var(--font-size-xl);font-weight:700;text-shadow:0 0 10px var(--glow-primary)}.equipment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-4)}.equipment-item{background:#0000004d;border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-4);display:flex;justify-content:space-between;align-items:center}.equipment-slot{color:var(--text-tertiary);font-size:var(--font-size-sm);font-weight:600}.equipment-name{color:var(--text-secondary);font-weight:600}.spells-section{background:#0000004d;border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-6)}.spell-level{margin-bottom:var(--space-6)}.spell-level:last-child{margin-bottom:0}.spell-level h4{color:var(--accent-secondary);font-size:var(--font-size-lg);margin-bottom:var(--space-3);text-shadow:0 0 10px var(--glow-secondary)}.spell-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.spell-item{background:#0028004d;border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:600}.no-spells{color:var(--text-tertiary);font-style:italic;text-align:center;padding:var(--space-6)}.character-detail-footer{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-primary);display:flex;justify-content:center}@media(max-width:768px){.character-detail-header{flex-direction:column;gap:var(--space-4);align-items:center;text-align:center}.character-detail-status{align-items:center}.attributes-grid{grid-template-columns:repeat(2,1fr)}.health-exp-grid,.equipment-grid{grid-template-columns:1fr}.character-detail-modal .modal-content{width:98%;max-height:95%}.character-detail-modal .modal-body{padding:var(--space-4)}}.town-center-interface{display:flex;flex-direction:column;width:98vw;height:98vh;margin:1vh auto;padding:var(--space-4);background:#101828;color:var(--text-primary);font-family:var(--font-primary);overflow:hidden;overflow-y:auto;box-sizing:border-box}.game-header{text-align:center;margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:2px solid var(--border-accent)}.game-title{font-size:var(--font-size-3xl);color:var(--accent-primary);margin-bottom:var(--space-4);text-shadow:0 0 20px var(--glow-primary);animation:glow 3s ease-in-out infinite;font-weight:700;letter-spacing:2px}.game-subtitle{font-size:var(--font-size-lg);color:var(--accent-secondary);text-shadow:0 0 10px var(--glow-secondary);font-style:italic;margin:0}.town-center-content{flex:1;display:flex;flex-direction:column}.town-name{font-size:var(--font-size-2xl);color:var(--accent-primary);text-align:center;margin-bottom:var(--space-4);text-shadow:0 0 15px var(--glow-primary)}.town-description{font-size:var(--font-size-base);color:var(--text-secondary);text-align:center;margin-bottom:var(--space-8);line-height:1.6;max-width:600px;margin-left:auto;margin-right:auto}.town-locations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--space-6);margin-bottom:var(--space-8);flex:1;align-content:center}.location-card{position:relative;border-radius:var(--radius-xl);overflow:visible;transition:all var(--transition-normal)}.location-card.full-width{grid-column:1 / -1;max-width:600px;margin:0 auto}.location-card.primary{animation:pulse 2s ease-in-out infinite}.location-btn{width:100%;height:350px;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;padding:var(--space-6);background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));border:2px solid var(--border-primary);border-radius:var(--radius-xl);color:var(--text-primary);cursor:pointer;transition:all var(--transition-normal);font-family:var(--font-primary);text-align:left;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.location-btn:before{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:linear-gradient(180deg,transparent,rgba(255,255,255,.05),transparent);transition:top var(--transition-slow)}.location-btn:hover:not(:disabled):before{top:100%}.location-btn.primary{background:linear-gradient(145deg,var(--accent-primary),var(--accent-secondary));border-color:var(--accent-secondary);color:#fff;box-shadow:var(--shadow-glow),var(--shadow-md)}.location-btn.primary:hover:not(:disabled){background:linear-gradient(145deg,var(--accent-secondary),var(--accent-tertiary));box-shadow:var(--shadow-glow-lg),var(--shadow-lg);transform:translateY(-5px) scale(1.02);color:#fff;z-index:10}.location-btn.enabled:hover:not(:disabled){background:linear-gradient(145deg,var(--accent-primary),var(--accent-secondary));border-color:var(--accent-secondary);color:#fff;box-shadow:var(--shadow-glow),var(--shadow-lg);transform:translateY(-5px);z-index:10}.location-btn.disabled{opacity:.6;cursor:not-allowed;background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));border-color:var(--border-primary);color:var(--text-muted)}.location-btn:disabled:hover{transform:none;box-shadow:var(--shadow-sm)}.location-icon{font-size:4rem;margin-bottom:var(--space-4);flex-shrink:0;filter:drop-shadow(0 0 5px currentColor)}.card-content-top{width:100%;margin-bottom:var(--space-4)}.card-stats{width:100%;margin-top:auto;border-top:1px solid rgba(255,255,255,.1);padding-top:var(--space-3);flex-grow:1;display:flex;flex-direction:column}.live-status{display:flex;align-items:center;font-size:var(--font-size-xs);font-weight:700;color:var(--accent-secondary);margin-bottom:var(--space-2);background:#3b82f61a;padding:4px 8px;border-radius:var(--radius-sm);display:inline-flex;align-self:flex-start}.status-text.warning{color:var(--accent-alert)}.pulse-dot{display:inline-block;width:8px;height:8px;background-color:var(--accent-success);border-radius:50%;margin-right:8px;box-shadow:0 0 #10b98166;animation:pulse-green 2s infinite}.pulse-dot.red{background-color:var(--accent-alert);box-shadow:0 0 #ef444466;animation:pulse-red 2s infinite}@keyframes pulse-green{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 10px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}@keyframes pulse-red{0%{transform:scale(.95);box-shadow:0 0 #ef4444b3}70%{transform:scale(1);box-shadow:0 0 0 10px #ef444400}to{transform:scale(.95);box-shadow:0 0 #ef444400}}.popular-times-label{font-size:10px;text-transform:uppercase;color:var(--text-muted);letter-spacing:1px;margin-bottom:var(--space-2)}.stat-bars{display:flex;align-items:flex-end;gap:4px;height:60px;width:100%;padding-bottom:2px}.stat-bar{flex:1;background:var(--accent-primary);border-radius:2px 2px 0 0;min-height:2px;opacity:.8;transition:height .5s ease-out}.location-btn:hover .stat-bar{opacity:1;box-shadow:0 0 5px var(--glow-primary)}.stat-labels{display:flex;justify-content:space-between;font-size:12px;font-weight:700;color:var(--text-secondary);margin-top:4px;font-family:Courier New,monospace}.location-info{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.location-info h3{font-size:2.5rem;margin:0;font-weight:800;text-shadow:0 0 5px currentColor;text-transform:uppercase;letter-spacing:2px}.location-info p{font-size:var(--font-size-sm);margin:0;opacity:.9;line-height:1.4}.location-status{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:1px;opacity:.8}.game-status-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) var(--space-4);background:linear-gradient(145deg,var(--bg-tertiary),var(--bg-secondary));border:1px solid var(--border-accent);border-radius:var(--radius-lg);box-shadow:inset 0 1px #ffffff1a;margin-top:auto;min-height:60px}.status-section{background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-md);padding:var(--space-1) var(--space-3);min-height:40px;display:flex;align-items:center}.status-content{display:flex;flex-direction:column;gap:var(--space-1);width:100%}.status-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.status-value{font-size:var(--font-size-sm);font-weight:600}.status-value.active{color:var(--success);text-shadow:0 0 5px var(--success)}.status-value.inactive{color:var(--text-muted)}.town-header{display:flex;align-items:center;gap:var(--space-4);padding-bottom:var(--space-6);margin-bottom:var(--space-4);border-bottom:2px solid var(--border-accent)}.town-logo{font-size:3rem;filter:drop-shadow(0 0 10px var(--glow-primary))}.town-title-group{display:flex;flex-direction:column;gap:var(--space-1)}.town-main-title{font-size:var(--font-size-3xl);font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--text-primary);text-shadow:0 0 20px var(--glow-primary);margin:0}.town-main-subtitle{font-size:var(--font-size-lg);font-style:italic;color:var(--text-secondary);margin:0}.town-grid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);align-content:start;overflow-y:auto;padding:var(--space-4);padding-bottom:var(--space-6)}@media(max-width:1200px){.town-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.town-grid{grid-template-columns:1fr}}.town-grid::-webkit-scrollbar{width:8px;background:var(--bg-primary)}.town-grid::-webkit-scrollbar-thumb{background:var(--border-accent);border-radius:var(--radius-sm)}.town-grid::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.town-footer{display:flex;justify-content:center;align-items:center;padding:var(--space-3) var(--space-6);margin-top:auto;border-top:1px solid var(--border-primary);background:linear-gradient(90deg,transparent,rgba(239,68,68,.1),transparent)}.footer-text{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:2px;color:var(--text-muted)}.footer-divider{margin:0 var(--space-3);color:var(--accent-alert);opacity:.6}.location-card-new{position:relative;background:#1a2d63;border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-xl);overflow:visible;transition:all var(--transition-normal)}.location-card-new:before{content:"";position:absolute;top:8px;left:8px;width:20px;height:20px;border-top:2px solid var(--accent-primary);border-left:2px solid var(--accent-primary);pointer-events:none;z-index:10;transition:all var(--transition-fast)}.location-card-new:after{content:"";position:absolute;bottom:8px;right:8px;width:20px;height:20px;border-bottom:2px solid var(--accent-primary);border-right:2px solid var(--accent-primary);pointer-events:none;z-index:10;transition:all var(--transition-fast)}.location-card-new:hover:before{width:calc(100% - 16px);height:calc(100% - 16px);border-color:var(--accent-secondary);box-shadow:-2px -2px 10px var(--glow-primary)}.location-card-new:hover:after{width:calc(100% - 16px);height:calc(100% - 16px);border-color:var(--accent-secondary);box-shadow:2px 2px 10px var(--glow-primary)}.location-card-new:hover{background:#1a2d6366;border-color:#3b82f680;box-shadow:0 0 30px #3b82f626}.location-card-new.disabled{opacity:.6}.location-card-new.disabled:before,.location-card-new.disabled:after{border-color:var(--text-muted)}.card-header-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);border-bottom:1px solid var(--border-primary)}.card-icon-lg{font-size:2.5rem;filter:drop-shadow(0 0 8px currentColor)}.card-title-new{font-size:var(--font-size-xl);font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text-primary);margin:0}.card-action-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-primary)}.status-group{display:flex;gap:var(--space-2)}.status-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:1px;border:1px solid currentColor;background:#0009;text-shadow:0 0 8px currentColor;box-shadow:0 0 10px #00000080}.status-badge.open{color:var(--accent-success);border-color:var(--accent-success);background:#00ff881a}.status-badge.closed{color:var(--accent-alert);border-color:var(--accent-alert);background:#ff33331a}.status-badge.busy{color:var(--accent-warning);border-color:var(--accent-warning);background:#ffcc001a}.status-badge.locked{color:var(--text-muted);border-color:var(--border-accent)}.status-badge.grid-active{color:var(--accent-alert);border-color:var(--accent-alert);animation:status-pulse 2s ease-in-out infinite}.status-badge.grid-active:before{content:"";display:inline-block;width:6px;height:6px;background:var(--accent-alert);border-radius:50%;box-shadow:0 0 6px var(--accent-alert);animation:dot-pulse 1.5s ease-in-out infinite}@keyframes status-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 8px #ef444466}}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}.action-btn-group{display:flex;align-items:center;gap:var(--space-2)}.card-action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-lg);position:relative;overflow:hidden}.card-action-btn:before{display:none!important}.card-action-btn:hover:not(:disabled){background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:0 0 10px var(--glow-primary)}.card-action-btn:disabled{opacity:.4;cursor:not-allowed}.card-action-btn.primary:hover:not(:disabled){background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 15px var(--glow-primary);color:#fff}.metadata-badge{font-size:var(--font-size-xs);color:var(--text-muted);margin-left:var(--space-2)}.card-data-row{padding:var(--space-6)}.data-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:var(--space-3)}.data-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#00000080;border:1px solid var(--accent-primary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-primary);box-shadow:0 0 8px #3b82f64d}.data-chip:before{content:"";display:inline-block;width:6px;height:6px;background:var(--accent-primary);border-radius:50%;box-shadow:0 0 6px var(--accent-primary)}.data-chip .chip-value{color:var(--accent-secondary);font-weight:700}.data-chip.success{border-color:var(--accent-success);box-shadow:0 0 8px #10b9814d}.data-chip.success:before{background:var(--accent-success);box-shadow:0 0 6px var(--accent-success)}.data-chip.warning{border-color:var(--accent-warning);box-shadow:0 0 8px #facc154d}.data-chip.warning:before{background:var(--accent-warning);box-shadow:0 0 6px var(--accent-warning)}.data-chip.alert{border-color:var(--accent-alert);box-shadow:0 0 8px #ef44444d}.data-chip.alert:before{background:var(--accent-alert);box-shadow:0 0 6px var(--accent-alert)}.histogram-new{display:flex;align-items:flex-end;gap:3px;height:50px;padding:var(--space-2) 0;margin-top:var(--space-2)}.histogram-bar-new{flex:1;background:var(--accent-primary);border-radius:2px 2px 0 0;min-height:4px;transition:height .3s ease;box-shadow:0 0 10px var(--glow-primary)}.histogram-bar-new.current{background:var(--accent-alert);box-shadow:0 0 8px var(--glow-alert);opacity:1}.histogram-bar-new.closed{background:var(--text-muted);opacity:.3}@media(max-width:1024px){#ui-overlay{grid-template-columns:150px 1fr 150px}button{font-size:10px;padding:6px 8px}}@media(max-width:768px){#ui-overlay{grid-template-columns:1fr;grid-template-rows:auto auto 1fr;gap:5px}#character-panel{grid-column:1;grid-row:1;max-height:150px}#control-panel{grid-column:1;grid-row:2}#game-panel{grid-column:1;grid-row:3}.viewport{min-height:200px}.message-log{height:100px}}.combat-interface{width:100%;height:100vh;max-height:100vh;background:var(--bg-secondary);border:2px solid var(--border-accent);border-radius:var(--radius-lg);padding:var(--space-2);display:flex;flex-direction:column;color:var(--text-primary);font-family:var(--font-primary);box-shadow:0 0 20px var(--glow-primary);overflow:hidden}.combat-header{text-align:center;margin-bottom:var(--space-2);border-bottom:1px solid var(--border-primary);padding-bottom:var(--space-2)}.combat-header h2{margin:0 0 var(--space-1) 0;color:var(--accent-primary);font-size:var(--font-size-lg);text-shadow:0 0 10px var(--glow-primary)}.encounter-message{color:var(--text-secondary);font-style:italic;margin-top:var(--space-1);font-size:var(--font-size-sm)}.combat-body{flex:1;display:flex;flex-direction:column;gap:var(--space-2);overflow:hidden;min-height:0}.combat-status{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary);flex:0 1 auto;max-height:35vh;overflow:hidden}.combatant-status{padding:var(--space-3);background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-primary);margin-bottom:var(--space-2)}.combatant-name{font-weight:700;color:var(--accent-secondary);margin-bottom:var(--space-1)}.combatant-hp{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-1)}.combatant-weapon{color:var(--text-muted);font-size:var(--font-size-xs);font-style:italic}.combatant-threat{color:var(--danger);font-size:var(--font-size-xs);font-weight:700}.wave-info{margin-bottom:var(--space-3)}.wave-counter{background:var(--accent-primary);color:#fff;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:700;text-align:center;box-shadow:0 0 10px var(--glow-secondary)}.mode-toggle-section{white-space:nowrap}.mode-toggle-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all .2s ease;max-width:120px;justify-content:center}.mode-toggle-btn:hover{background:var(--bg-secondary);border-color:var(--accent-primary);box-shadow:0 0 5px var(--glow-secondary)}.mode-toggle-btn.cyber-mode{background:linear-gradient(135deg,#0a0f1c,#1a1f3c);border-color:#0ff;color:#0ff}.mode-toggle-btn.cyber-mode:hover{box-shadow:0 0 10px #00ffff4d}.mode-toggle-btn.classic-mode{background:linear-gradient(135deg,#1a0a0f,#3c1a1f);border-color:#fa0;color:#fa0}.mode-toggle-btn.classic-mode:hover{box-shadow:0 0 10px #ffaa004d}.toggle-icon{font-size:var(--font-size-lg);line-height:1}#current-mode-display{font-weight:700;min-width:60px;text-align:center}.monster-classification{font-size:.8em!important;color:#0ff!important;font-style:italic;margin-left:var(--space-1)}.equipment-name[data-cyber-enhanced=true],.spell-item[data-cyber-enhanced=true]{color:#0ff;text-shadow:0 0 3px rgba(0,255,255,.3);font-family:var(--font-primary)}.equipment-slot{font-weight:700;margin-bottom:var(--space-1)}.spell-item[data-cyber-enhanced=true]:before{content:"► ";color:#0ff;font-size:.8em}.equipment-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2);border-bottom:1px solid var(--border-primary)}.equipment-item:last-child{border-bottom:none}.party-status h3,.enemy-status h3{margin:0 0 var(--space-3) 0;color:var(--accent-secondary);font-size:var(--font-size-lg)}.party-status,.enemy-status{display:flex;flex-direction:column;max-height:30vh;overflow:hidden}.party-status h3,.enemy-status h3{flex-shrink:0;margin:0 0 var(--space-3) 0;color:var(--accent-secondary);font-size:var(--font-size-lg);text-align:center}#party-combat-status,#enemy-combat-status{overflow-y:auto;flex:1;padding-right:var(--space-2)}#party-combat-status::-webkit-scrollbar,#enemy-combat-status::-webkit-scrollbar{width:8px}#party-combat-status::-webkit-scrollbar-track,#enemy-combat-status::-webkit-scrollbar-track{background:var(--bg-primary);border-radius:4px}#party-combat-status::-webkit-scrollbar-thumb,#enemy-combat-status::-webkit-scrollbar-thumb{background:var(--border-accent);border-radius:4px}#party-combat-status::-webkit-scrollbar-thumb:hover,#enemy-combat-status::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.combat-actions{flex-shrink:0;flex-basis:auto;min-height:200px;margin-top:var(--space-4);padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.combat-actions h3{margin:0 0 var(--space-4) 0;color:var(--accent-secondary);font-size:var(--font-size-lg);text-align:center}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.combat-action-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-primary);border:2px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-primary);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-fast);min-height:60px}.combat-action-btn:hover{border-color:var(--accent-primary);background:var(--bg-secondary);box-shadow:0 0 15px var(--glow-secondary);transform:translateY(-2px)}.combat-action-btn:active{transform:translateY(0);box-shadow:0 0 10px var(--glow-secondary)}.combat-action-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-secondary);border-color:var(--border-secondary);color:var(--text-muted);transform:none;box-shadow:none}.combat-action-btn:disabled:hover{border-color:var(--border-secondary);background:var(--bg-secondary);box-shadow:none;transform:none}.action-number{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--accent-primary);color:#fff;border-radius:50%;font-weight:700;font-size:var(--font-size-sm)}.action-text{flex:1;text-align:left;font-weight:500}@media(max-width:768px){.combat-status{grid-template-columns:1fr;gap:var(--space-4)}.action-buttons{grid-template-columns:1fr}.combat-action-btn{min-height:50px;padding:var(--space-3)}}.combat-interface{animation:combatFadeIn .3s ease-out}@keyframes combatFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.combat-wave-indicator{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:2px solid var(--border-accent);border-radius:var(--radius-md);padding:var(--space-2);margin-bottom:var(--space-2);text-align:center}.wave-display{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:600;text-shadow:0 0 8px var(--glow-primary)}.combat-main-area{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-2);height:100%;max-height:calc(100vh - 450px)}.combat-monster-visual{background:linear-gradient(135deg,#0a0f1a,#0d1117,#0a0f1a);border:2px solid #1e3a5f;border-radius:var(--radius-md);padding:var(--space-2);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;position:relative;overflow:hidden;box-shadow:inset 0 0 30px #3b82f61a,0 4px 12px #0009;background-image:linear-gradient(rgba(59,130,246,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.03) 1px,transparent 1px);background-size:20px 20px}.combat-monster-visual:before{content:"";position:absolute;top:8px;left:8px;width:30px;height:30px;border-top:3px solid var(--accent-primary);border-left:3px solid var(--accent-primary);opacity:.6;z-index:10}.combat-monster-visual:after{content:"";position:absolute;bottom:8px;right:8px;width:30px;height:30px;border-bottom:3px solid var(--accent-primary);border-right:3px solid var(--accent-primary);opacity:.6;z-index:10}.monster-ascii-art{font-family:Courier New,monospace;font-size:2rem;line-height:1;color:var(--accent-secondary);margin-bottom:var(--space-3);white-space:pre;text-shadow:0 0 10px var(--glow-secondary)}#monster-portrait-canvas{border:2px solid var(--border-secondary);border-radius:var(--radius-sm);background:var(--bg-primary);margin:0 auto var(--space-2);box-shadow:0 0 20px #00ff004d;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;width:95%;height:auto;aspect-ratio:1;max-width:400px;flex-shrink:0;position:relative;display:block}.monster-name{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.monster-status{font-size:var(--font-size-sm);color:var(--text-secondary)}.combat-party-status{background:linear-gradient(135deg,#0a0f1a,#0d1117,#0a0f1a);border:2px solid #1e3a5f;border-radius:var(--radius-md);padding:var(--space-2);overflow-y:auto;box-shadow:inset 0 0 20px #3b82f614,0 2px 8px #00000080}.combat-party-status h3{margin:0 0 var(--space-3) 0;color:var(--accent-primary);text-align:center;border-bottom:1px solid var(--border-primary);padding-bottom:var(--space-2)}.combat-actions-context{background:linear-gradient(135deg,#0a0f1a,#0d1117,#0a0f1a);border:2px solid #1e3a5f;border-radius:var(--radius-md);padding:var(--space-2);display:flex;flex-direction:column;box-shadow:inset 0 0 20px #3b82f614,0 2px 8px #00000080}.action-context-header h3{margin:0 0 var(--space-3) 0;color:var(--accent-secondary);text-align:center;border-bottom:1px solid var(--border-primary);padding-bottom:var(--space-2)}.action-buttons{display:flex;flex-direction:column;gap:var(--space-2);flex:1}.combat-action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);border:2px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all .2s ease;cursor:pointer;min-height:36px}.combat-action-btn:hover{background:var(--accent-primary);border-color:var(--accent-secondary);transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.combat-action-btn:active{transform:translateY(0)}.combat-action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.action-number{background:var(--accent-secondary);color:var(--bg-primary);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600;flex-shrink:0}.action-text{flex:1;text-align:left}.action-enemy-turn{text-align:center}.enemy-turn-info h3{color:var(--accent-secondary);margin-bottom:var(--space-3)}.continue-btn{background:var(--accent-primary);color:var(--text-primary);justify-content:center;font-weight:600}.continue-btn:hover{background:var(--accent-secondary)}.enemy-action-processing{color:var(--text-secondary);font-style:italic;margin-bottom:var(--space-2)}.enemy-action-description{color:var(--text-primary);font-weight:600;margin-bottom:var(--space-2)}.enemy-action-details{color:var(--text-secondary);font-size:var(--font-size-sm)}.party-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4);margin:var(--space-4) 0}.dungeon-party-card{background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-3);transition:all .2s ease}.dungeon-party-card:hover{border-color:var(--accent-primary);box-shadow:0 4px 8px #0000004d}.entrance-message{color:var(--text-secondary);margin:var(--space-3) 0;text-align:center}.entrance-warning{color:var(--accent-secondary);text-align:center;margin:var(--space-4) 0;padding:var(--space-2);background:#ffc1071a;border-radius:var(--radius-md);border:1px solid var(--accent-secondary)}.dungeon-entrance-actions,.dungeon-casualty-actions{display:flex;gap:var(--space-3);justify-content:center;margin-top:var(--space-4)}.casualties-of-war{margin:var(--space-4) 0}.casualties-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin:var(--space-4) 0}.survivors-section,.casualties-section{background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-4)}.survivors-section{border-color:var(--accent-primary)}.casualties-section{border-color:#dc2626}.survivors-section h3{color:var(--accent-primary);margin:0 0 var(--space-3) 0;text-align:center;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-primary)}.casualties-section h3{color:#dc2626;margin:0 0 var(--space-3) 0;text-align:center;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-primary)}.survivor-list,.casualty-list{display:flex;flex-direction:column;gap:var(--space-2)}.survivor-item,.casualty-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2);background:var(--bg-secondary);border-radius:var(--radius-sm);border-left:4px solid var(--accent-primary)}.casualty-item{border-left-color:#dc2626}.survivor-name,.casualty-name{font-weight:600;color:var(--text-primary)}.survivor-status{color:var(--accent-primary);font-size:var(--font-size-sm)}.casualty-status{color:#dc2626;font-size:var(--font-size-sm)}@media(max-width:768px){.party-cards-grid,.casualties-grid{grid-template-columns:1fr;gap:var(--space-3)}.dungeon-entrance-actions,.dungeon-casualty-actions{flex-direction:column;align-items:center}}.strike-team-management-modal{width:90vw;max-width:1200px;height:80vh;max-height:800px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000}.strike-team-management-modal .modal-content{background:var(--panel-bg, #1A1A2E);border:2px solid var(--border-color, #16213E);border-radius:8px;box-shadow:0 4px 20px #00000080;padding:1.5rem}.strike-team-management-modal ::-webkit-scrollbar{width:8px;background:var(--panel-bg, #1A1A2E)}.strike-team-management-modal ::-webkit-scrollbar-track{background:var(--panel-bg, #1A1A2E);border-radius:4px}.strike-team-management-modal ::-webkit-scrollbar-thumb{background:var(--border-color, #16213E);border-radius:4px;border:1px solid var(--panel-bg, #1A1A2E)}.strike-team-management-modal ::-webkit-scrollbar-thumb:hover{background:var(--primary-blue, #4A9EFF)}.strike-team-management-modal{scrollbar-width:thin;scrollbar-color:var(--border-color, #16213E) var(--panel-bg, #1A1A2E)}.delete-confirmation-modal{max-width:500px;margin:0 auto;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1001}.delete-confirmation-modal:before{content:"";position:fixed;inset:0;background:linear-gradient(45deg,#001,#012,#001);z-index:-1;animation:matrixGlow 3s ease-in-out infinite alternate}.delete-confirmation-modal:after{content:"011001";position:fixed;inset:0;color:#0f0c;font-family:Courier New,monospace;font-size:24em;line-height:1;word-wrap:break-word;animation:matrixRain 5s linear infinite;z-index:-1;pointer-events:none;overflow:hidden}@keyframes matrixGlow{0%{background:linear-gradient(45deg,#001,#012,#001);opacity:.8}to{background:linear-gradient(45deg,#012,#024,#012);opacity:1}}@keyframes matrixRain{0%{transform:translateY(-100vh);opacity:0}10%{opacity:.3}90%{opacity:.3}to{transform:translateY(100vh);opacity:0}}.delete-confirmation-modal .modal-content{background:var(--panel-bg, #1A1A2E);border:2px solid var(--danger, #FF4444);border-radius:8px;padding:2rem;position:relative;z-index:10;box-shadow:0 0 20px #ff444480,0 0 40px #ff44444d,0 0 80px #ff44441a}.delete-confirmation-content,.delete-prevention-content{text-align:center}.warning-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;text-align:center;justify-content:center}.warning-icon{font-size:2rem;color:var(--warning, #FFB800)}.warning-header h3{color:var(--danger, #FF4444);font-size:1.5rem;margin:0;font-weight:600}.warning-content{text-align:center;margin-bottom:2rem}.warning-content p{color:var(--text-primary, #FFFFFF);margin-bottom:1rem;font-size:1rem}.party-name{font-size:1.2rem;color:var(--primary-blue, #4A9EFF);margin-bottom:1.5rem!important;font-weight:600}.danger-warning{display:flex;align-items:flex-start;gap:1rem;background:#ff44441a;border:1px solid var(--danger, #FF4444);border-radius:4px;padding:1rem;margin-top:1rem;text-align:left}.danger-icon{font-size:1.5rem;color:var(--danger, #FF4444);flex-shrink:0}.danger-warning p{color:var(--text-secondary, #B0B0B0);font-size:.9rem;margin:0;text-align:left}.info-box{display:flex;align-items:flex-start;gap:1rem;background:#4a9eff1a;border:1px solid rgba(74,158,255,.3);border-radius:8px;padding:1rem;margin-top:1rem}.info-icon{font-size:1.5rem;color:var(--primary-blue, #4A9EFF);flex-shrink:0}.info-box p{color:var(--text-secondary, #B0B0B0);font-size:.9rem;margin:0;text-align:left}.confirmation-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.action-btn.danger{background:var(--danger, #FF4444);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1rem}.action-btn.danger:hover{background:var(--danger-hover, #FF6666);transform:translateY(-1px);box-shadow:0 4px 12px #f446}.action-btn.secondary{background:var(--bg-secondary, #16213E);color:var(--text-primary, #FFFFFF);border:1px solid var(--border-color, #16213E);padding:.75rem 1.5rem;border-radius:4px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:1rem}.action-btn.secondary:hover{background:var(--border-color, #16213E);border-color:var(--primary-blue, #4A9EFF);transform:translateY(-1px);box-shadow:0 4px 12px #4a9eff33}.manifest-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border-color, #16213E);background:linear-gradient(135deg,#4a9eff1a,#4a9eff0d);border-radius:8px;padding:1.5rem}.manifest-title{color:var(--primary-blue, #4A9EFF);font-size:2rem;margin-bottom:.5rem;font-weight:600}.manifest-subtitle{color:var(--text-secondary, #B0B0B0);font-size:1rem}.teams-section h3{display:flex;align-items:center;gap:.5rem;color:var(--primary-blue, #4A9EFF);margin-bottom:1rem;font-weight:500}.section-icon{font-size:1.2rem}.camping-teams-section,.in-town-teams-section,.lost-teams-section{margin-bottom:2rem}.camping-teams-grid,.in-town-teams-grid,.lost-teams-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.party-card{background:var(--panel-bg, #1A1A2E);border:1px solid var(--border-color, #16213E);border-radius:8px;padding:1rem;margin-bottom:1rem;transition:all .2s ease;box-shadow:0 2px 8px #0000004d}.party-card:hover{border-color:var(--accent-primary, #4A9EFF);box-shadow:0 4px 16px #4a9eff4d;transform:translateY(-2px)}.party-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.party-status-icon{font-size:1.5rem}.party-header h4{flex-grow:1;margin:0;color:var(--text-primary, #FFFFFF)}.party-status{padding:.25rem .5rem;border-radius:4px;font-size:.875rem;font-weight:700}.party-status.camping{background:var(--warning-bg);color:var(--warning-text)}.party-status.inactive{background:var(--info-bg);color:var(--info-text)}.party-status.lost{background:var(--error-bg);color:var(--error-text)}.party-location{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-subtle)}.location-label{color:var(--text-secondary);font-weight:700}.location-value{color:var(--text-primary)}.party-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.manifest-actions{display:flex;justify-content:center;margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border-color)}.no-parties{text-align:center;color:var(--text-secondary, #B0B0B0);font-style:italic;padding:2rem;background:var(--bg-secondary, #0F0F23);border-radius:8px;border:2px dashed var(--border-color, #16213E);box-shadow:inset 0 2px 4px #0000004d}@media(max-width:768px){.strike-team-management-modal{width:98vw;height:95vh}.camping-teams-grid,.in-town-teams-grid,.lost-teams-grid{grid-template-columns:1fr;gap:.75rem}.party-actions{flex-direction:column}.manifest-header{margin-bottom:1rem;padding-bottom:.75rem}.manifest-title{font-size:1.5rem}}@media(max-width:768px){.combat-main-area{grid-template-columns:1fr;grid-template-rows:auto auto;gap:var(--space-3)}.combat-monster-visual{order:1}.combat-actions-context{order:2}.monster-ascii-art{font-size:1.5rem}#monster-portrait-canvas{max-width:400px}}.post-combat-results{padding:var(--space-6);max-width:600px;margin:0 auto}.reward-section{margin-bottom:var(--space-6);padding:var(--space-4);background:#3b82f61a;border:1px solid var(--accent-primary);border-radius:var(--radius-lg);animation:rewardPulse 2s ease-in-out infinite}.reward-section h3{color:var(--accent-primary);margin-bottom:var(--space-3);font-size:var(--font-size-xl);text-shadow:0 0 10px var(--glow-primary)}.experience-reward{font-size:var(--font-size-3xl);font-weight:700;color:gold;text-align:center;margin:var(--space-4) 0;text-shadow:0 0 15px rgba(255,215,0,.5);animation:goldGlow 1.5s ease-in-out infinite}.gold-reward{font-size:var(--font-size-2xl);font-weight:700;color:gold;text-align:center;margin:var(--space-4) 0;text-shadow:0 0 15px rgba(255,215,0,.5)}.loot-list{display:flex;flex-direction:column;gap:var(--space-2)}.loot-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background:#0000004d;border-radius:var(--radius-md);border-left:4px solid var(--border-primary);transition:all .3s ease}.loot-item:hover{background:#00000080;transform:translate(5px)}.loot-item.magical{border-left-color:#9d4edd;background:#9d4edd1a}.loot-item.normal{border-left-color:var(--border-primary)}.treasure-modal-content{text-align:center;padding:var(--space-4)}.treasure-modal-content h3{color:var(--success);font-size:var(--font-size-xl);margin-bottom:var(--space-4);text-shadow:0 0 10px var(--success)}.treasure-modal-content .loot-list{text-align:left;max-height:300px;overflow-y:auto;margin-bottom:var(--space-6)}.treasure-modal-content .loot-item{padding:var(--space-3);border:1px solid var(--border-primary);border-left:4px solid var(--success);background:#10b9811a;border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--space-3)}.treasure-modal-content .loot-icon{font-size:var(--font-size-lg);min-width:24px}.treasure-modal-content .loot-name{flex:1;font-weight:700;color:var(--text-primary)}.treasure-modal-content .loot-type{color:var(--text-muted);font-size:var(--font-size-sm);text-transform:capitalize}.treasure-modal-content .no-loot{color:var(--text-muted);font-style:italic;margin:var(--space-6) 0}.treasure-modal-content .modal-actions{margin-top:var(--space-6)}.item-name{font-weight:700;color:var(--text-primary)}.item-type{color:var(--text-secondary);font-style:italic}.item-value{color:gold;font-weight:700}.no-loot{text-align:center;color:var(--text-muted);font-style:italic;margin:var(--space-6) 0}.death-screen{padding:var(--space-8);max-width:500px;margin:0 auto;text-align:center}.death-screen h2{color:var(--danger);font-size:var(--font-size-3xl);margin-bottom:var(--space-6);text-shadow:0 0 20px rgba(239,68,68,.5);animation:deathPulse 2s ease-in-out infinite}.death-message{font-size:var(--font-size-xl);margin-bottom:var(--space-6);color:var(--text-primary)}.death-details{background:#ef44441a;border:1px solid var(--danger);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.casualty-list{display:flex;flex-direction:column;gap:var(--space-3)}.casualty-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:#0000004d;border-radius:var(--radius-md);border-left:4px solid var(--danger)}.casualty-name{font-weight:700;color:var(--text-primary)}.casualty-status{color:var(--danger);font-style:italic}.death-actions{display:flex;gap:var(--space-4);justify-content:center;margin-top:var(--space-6)}@keyframes goldGlow{0%,to{text-shadow:0 0 15px rgba(255,215,0,.5)}50%{text-shadow:0 0 25px rgba(255,215,0,.8)}}@keyframes deathPulse{0%,to{text-shadow:0 0 20px rgba(239,68,68,.5)}50%{text-shadow:0 0 30px rgba(239,68,68,.8)}}.party-setup-modal .modal-content{max-width:500px;margin:10% auto}.party-setup-content{padding:1rem}.party-setup-modal .mode-toggle-section{margin-bottom:2rem;padding:1rem;border:1px solid #444;border-radius:8px;background-color:#0000004d}.party-setup-modal .mode-toggle-section .status-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.party-setup-modal .status-label{color:#0f0;font-weight:700;font-size:1.1rem}.party-name-section{margin-bottom:2rem}.party-name-input{width:100%;padding:.75rem;background-color:#00000080;border:2px solid #444;border-radius:4px;color:#fff;font-size:1rem;font-family:Courier New,monospace}.party-name-input:focus{outline:none;border-color:#0f0;box-shadow:0 0 5px #00ff004d}.party-name-input::placeholder{color:#999;font-style:italic}.input-help{display:block;margin-top:.5rem;color:#888;font-size:.85rem}.party-setup-actions{text-align:center;margin-top:2rem}.party-setup-actions .btn-primary{min-width:200px;padding:1rem 2rem;font-size:1.1rem}.strike-teams-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-4);align-items:start;max-width:100%}@media(min-width:900px){.strike-teams-container{grid-template-columns:repeat(3,1fr)}}.strike-team-section{background:linear-gradient(145deg,var(--bg-primary),var(--bg-secondary));border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-4);transition:all var(--transition-fast)}.strike-team-section.disconnected{border-left:4px solid var(--warning);background:linear-gradient(145deg,#f59e0b0d,#f59e0b05)}.strike-team-section.active{border-left:4px solid var(--success);background:linear-gradient(145deg,#10b9810d,#10b98105)}.strike-team-section.camping{border-left:4px solid var(--accent-primary);background:linear-gradient(145deg,#3b82f60d,#3b82f605)}.strike-team-section.lost{border-left:4px solid var(--danger);background:linear-gradient(145deg,#ef44440d,#ef444405)}.strike-team-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-primary)}.team-icon{font-size:var(--font-size-xl);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#3b82f61a;border:1px solid var(--border-primary);border-radius:var(--radius-md);flex-shrink:0}.team-name{font-size:var(--font-size-lg);font-weight:600;color:var(--accent-secondary);text-shadow:0 0 5px var(--glow-primary);flex:1}.team-member-count{font-size:var(--font-size-sm);color:var(--text-muted);background:var(--bg-tertiary);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);border:1px solid var(--border-primary)}.strike-team-members{display:flex;flex-direction:column;gap:var(--space-2)}.empty-team-message{display:flex;flex-direction:column;align-items:center;padding:var(--space-4);color:var(--text-muted);font-style:italic}.empty-team-icon{font-size:var(--font-size-2xl);margin-bottom:var(--space-2);opacity:.5}.empty-team-text{font-size:var(--font-size-sm)}.summary-character-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-primary);border-radius:var(--radius-md);margin-bottom:var(--space-2);transition:all var(--transition-fast);cursor:pointer}.summary-character-card:hover{border-color:var(--accent-primary);box-shadow:0 0 10px var(--glow-secondary)}.summary-character-card.escaped{border-left:4px solid var(--success);background:linear-gradient(145deg,#10b9811a,#10b9810d)}.summary-character-card.casualty{border-left:4px solid var(--danger);background:linear-gradient(145deg,#ef44441a,#ef44440d)}.summary-character-card.survivor{border-left:4px solid var(--accent-primary);background:linear-gradient(145deg,#3b82f61a,#3b82f60d)}.summary-card-icon{font-size:var(--font-size-2xl);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#3b82f61a;border:1px solid var(--border-primary);border-radius:var(--radius-md);flex-shrink:0}.summary-card-content{flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.summary-card-header{display:flex;justify-content:space-between;align-items:flex-start}.summary-card-name{font-size:var(--font-size-lg);font-weight:600;color:var(--accent-secondary);text-shadow:0 0 5px var(--glow-primary)}.summary-card-details{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-1)}.summary-card-platform{color:var(--text-muted);font-weight:500}.summary-card-specialization{color:var(--text-secondary);font-weight:500}.summary-card-health{display:flex;align-items:center;gap:var(--space-2)}.summary-health-bar{flex:1;height:6px;background:var(--bg-primary);border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-primary)}.summary-health-fill{height:100%;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.summary-health-fill.healthy{background:linear-gradient(90deg,var(--success),#22c55e)}.summary-health-fill.wounded{background:linear-gradient(90deg,var(--warning),#f59e0b)}.summary-health-fill.critical{background:linear-gradient(90deg,var(--danger),#ef4444)}.summary-health-fill.dead{background:linear-gradient(90deg,var(--text-muted),#6b7280)}.summary-health-text{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:600;min-width:60px;text-align:right}.summary-card-status{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-1)}.summary-status-badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.summary-status-badge.escaped{background:#f59e0b33;color:var(--warning);border:1px solid var(--warning)}.summary-status-badge.casualty{background:#ef444433;color:var(--danger);border:1px solid var(--danger)}.summary-status-badge.survivor{background:#3b82f633;color:var(--accent-primary);border:1px solid var(--accent-primary)}.party-defeat-modal .modal-body{padding:var(--space-6);max-width:800px;margin:0 auto;text-align:center}.party-defeat-modal h2{color:var(--accent-secondary);font-size:var(--font-size-2xl);margin-bottom:var(--space-4);text-shadow:0 0 15px var(--glow-primary)}.defeat-message{font-size:var(--font-size-lg);color:var(--accent-secondary);margin-bottom:var(--space-8);text-shadow:0 0 10px var(--glow-primary);font-weight:600;text-align:center}.victory-with-casualties{padding:var(--space-6);max-width:800px;margin:0 auto;text-align:center}.modal.victory-with-casualties{display:flex;align-items:center;justify-content:center;position:fixed;inset:0;width:100%;height:100%}.modal.victory-with-casualties .modal-content{max-width:900px;width:90%;margin:0;position:relative}.victory-with-casualties h2{color:var(--accent-secondary);font-size:var(--font-size-2xl);margin-bottom:var(--space-4);text-shadow:0 0 15px var(--glow-primary)}.victory-message{font-size:var(--font-size-lg);color:var(--accent-secondary);margin-bottom:var(--space-8);text-shadow:0 0 10px var(--glow-primary);font-weight:600;text-align:center}.defeat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}.escaped-section,.casualties-section{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:2px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-4)}.escaped-section{border-color:var(--warning)}.casualties-section{border-color:var(--danger)}.escaped-section h3,.casualties-section h3{color:var(--accent-primary);margin:0 0 var(--space-3) 0;text-align:center;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-primary);text-shadow:0 0 10px var(--glow-primary)}.escaped-list,.casualty-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-3)}.escaped-note,.casualty-note{font-size:var(--font-size-sm);color:var(--text-secondary);font-style:italic;text-align:center;margin-top:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--border-primary)}@media(max-width:768px){.defeat-grid{grid-template-columns:1fr;gap:var(--space-4)}.defeat-with-disconnect{padding:var(--space-4)}}@keyframes rewardPulse{0%,to{box-shadow:0 0 10px #3b82f64d}50%{box-shadow:0 0 20px #3b82f699}}@keyframes flashBlue{0%,to{box-shadow:0 0 5px var(--accent-primary);border-color:var(--accent-primary)}50%{box-shadow:0 0 20px var(--accent-secondary);border-color:var(--accent-secondary);background-color:#3b82f633}}.animate-flash-blue{animation:flashBlue 1.5s infinite;color:var(--accent-secondary)!important;font-weight:700}
