@import"https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;600;700;800;900&display=swap";@import"https://fonts.googleapis.com/css2?family=Rajdhani:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&display=swap";#root{min-height:100vh;display:flex;flex-direction:column}.v7-compositor{position:relative;display:inline-block}.v7-layer{position:absolute;top:0;left:0;width:100%;height:100%;image-rendering:pixelated;image-rendering:crisp-edges}.v7-layer-bevel{z-index:1;filter:drop-shadow(1px 1px 0 rgba(0,0,0,.5))}.v7-layer-greeble{z-index:2;opacity:.7;mix-blend-mode:overlay}.v7-layer-glow{z-index:3;mix-blend-mode:screen;animation:v7-pulse 2s ease-in-out infinite}.v7-layer-modules{z-index:4}@keyframes v7-pulse{0%,to{opacity:.6}50%{opacity:1}}.v7-module{position:absolute;border:1px solid rgba(0,212,255,.3);border-radius:2px;transition:all .2s}.v7-module:hover{border-color:#00d4ff;box-shadow:0 0 8px #00d4ff80}.v7-module.weapon{background:linear-gradient(135deg,#ff64644d,#c832324d)}.v7-module.defense{background:linear-gradient(135deg,#6496ff4d,#3264c84d)}.v7-module.power{background:linear-gradient(135deg,#ffc8324d,#c896324d)}.v7-module.engine{background:linear-gradient(135deg,#64ff964d,#32c8644d)}.v7-module.command{background:linear-gradient(135deg,#c864ff4d,#9632c84d)}.v7-module.utility{background:linear-gradient(135deg,#9696964d,#6464644d)}.v7-module.disabled{opacity:.4;filter:grayscale(100%)}.v7-module.damaged{animation:v7-damaged-flash .5s ease-in-out infinite}@keyframes v7-damaged-flash{0%,to{background-color:#ff00001a}50%{background-color:#ff00004d}}.v7-shield-arc{position:absolute;top:-10%;left:-10%;width:120%;height:120%;border:2px solid rgba(0,200,255,.5);border-radius:50%;pointer-events:none;animation:v7-shield-rotate 8s linear infinite}@keyframes v7-shield-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.v7-shield-arc:before{content:"";position:absolute;top:-4px;left:50%;width:8px;height:8px;background:#00d4ff;border-radius:50%;box-shadow:0 0 10px #00d4ff}.v7-thruster{position:absolute;width:4px;height:16px;background:linear-gradient(180deg,#00d4ff 0%,#0066aa 50%,transparent 100%);border-radius:2px;animation:v7-thruster-flicker .1s ease-in-out infinite}@keyframes v7-thruster-flicker{0%,to{opacity:.8;height:16px}50%{opacity:1;height:20px}}.v7-radar{position:absolute;width:12px;height:12px;border:2px solid rgba(0,255,100,.6);border-radius:50%;animation:v7-radar-ping 2s ease-out infinite}@keyframes v7-radar-ping{0%{transform:scale(.5);opacity:1}to{transform:scale(2);opacity:0}}.v7-faction-aetherial .v7-layer-glow{filter:hue-rotate(180deg)}.v7-faction-bulwark .v7-layer-glow{filter:hue-rotate(30deg) saturate(.5)}.v7-faction-scourge .v7-layer-glow{filter:hue-rotate(90deg)}.v7-faction-umbra .v7-layer-glow{filter:hue-rotate(270deg)}.v7-hp-bar{position:absolute;bottom:-8px;left:0;width:100%;height:4px;background:#00000080;border-radius:2px;overflow:hidden}.v7-hp-fill{height:100%;background:linear-gradient(90deg,#f44,#fa0,#4f4);transition:width .3s ease}.v7-selected{outline:2px solid #00d4ff;outline-offset:4px;animation:v7-selected-pulse 1s ease-in-out infinite}@keyframes v7-selected-pulse{0%,to{outline-color:#00d4ff}50%{outline-color:#00d4ff80}}.ship-editor{display:flex;gap:var(--space-6);padding:var(--space-6);animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.editor-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-5)}.editor-sidebar h3{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-pure);margin:0;padding-bottom:var(--space-3);border-bottom:1px solid var(--border-gold)}.module-list{display:flex;flex-direction:column;gap:var(--space-2);max-height:400px;overflow-y:auto;padding-right:var(--space-2)}.module-button{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#d4a85308;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);text-align:left;transition:all var(--duration-fast) var(--ease-out-expo)}.module-button:hover{background:#d4a85314;border-color:var(--gold-pure);transform:translate(4px)}.module-info-primary{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:8px}.module-category{font-size:.7rem;color:var(--holo-teal);letter-spacing:1px}.module-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;width:100%}.module-stats-grid .stat{font-size:.75rem;color:var(--text-muted)}.module-stats-grid .stat small{color:var(--gold-dim);margin-right:4px}.module-button.selected{background:linear-gradient(90deg,#d4a85326,#d4a8530d);border-color:var(--gold-pure);box-shadow:inset 3px 0 0 var(--gold-pure)}.module-name{flex:1;font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.03em}.module-size{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);padding:var(--space-1) var(--space-2);background:#0000004d;border-radius:var(--radius-sm)}.module-power{font-family:var(--font-display);font-size:var(--text-xs);color:var(--holo-teal);min-width:32px;text-align:right}.power-meter{padding:var(--space-4);background:#0a0a1299;border:1px solid var(--border-gold);border-radius:var(--radius-md)}.power-meter span{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-secondary);display:block;margin-bottom:var(--space-2);letter-spacing:.05em}.power-bar{height:6px;background:var(--sovereign-abyss);border-radius:3px;overflow:hidden}.power-fill{height:100%;background:var(--gradient-command);transition:width var(--duration-normal) var(--ease-out-expo)}.power-fill.over{background:var(--gradient-danger);animation:pulse-danger .5s ease-in-out infinite}.save-button{padding:var(--space-4) var(--space-6);background:var(--gradient-command);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:.15em;text-transform:uppercase}.save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--glow-gold)}.save-button:disabled{background:var(--sovereign-raised);color:var(--text-disabled);cursor:not-allowed}.editor-main{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-5)}.ship-grid-container{position:relative;padding:var(--space-6);background:linear-gradient(135deg,#0a0a12e6,#10101ccc);border:1px solid var(--border-gold);border-radius:var(--radius-lg)}.ship-grid-container:before,.ship-grid-container:after{content:"";position:absolute;width:24px;height:24px;border:2px solid var(--gold-dim);pointer-events:none}.ship-grid-container:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.ship-grid-container:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.ship-grid{display:grid;gap:2px;background:#d4a8530d;padding:2px;border-radius:var(--radius-sm)}.grid-cell{width:36px;height:36px;background:#0a0a12cc;border:1px solid rgba(212,168,83,.15);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out-expo);display:flex;align-items:center;justify-content:center}.grid-cell:hover{background:#d4a8531a;border-color:var(--gold-dim)}.grid-cell.occupied{position:relative}.grid-cell.module-weapon{background:linear-gradient(135deg,#f356,#b41e324d);border-color:#ff335580}.grid-cell.module-defense{background:linear-gradient(135deg,#49f6,#2864c84d);border-color:#4499ff80}.grid-cell.module-power{background:linear-gradient(135deg,#d4a85366,#a078324d);border-color:#d4a85380}.grid-cell.module-engine{background:linear-gradient(135deg,#3dffc866,#28b48c4d);border-color:#3dffc880}.grid-cell.module-command{background:linear-gradient(135deg,#b464ff66,#783cb44d);border-color:#b464ff80}.grid-cell.module-utility{background:linear-gradient(135deg,#96969666,#6464644d);border-color:#96969680}.module-label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;color:#fff;text-shadow:0 0 8px rgba(0,0,0,.8)}.error-list{width:100%;max-width:400px;padding:var(--space-4);background:#ff33551a;border:1px solid rgba(255,51,85,.3);border-radius:var(--radius-md)}.error{font-family:var(--font-body);font-size:var(--text-sm);color:var(--alert-crimson);padding:var(--space-2) 0}.error:not(:last-child){border-bottom:1px solid rgba(255,51,85,.2)}.hull-warning{padding:var(--space-3) var(--space-4);background:#ffcc001a;border:1px solid var(--alert-amber);border-radius:var(--radius-sm);color:var(--alert-amber);font-size:var(--text-sm);margin-bottom:var(--space-3)}.grid-cell.hull-cell{background:#d4a85314;border-color:#d4a8534d}.grid-cell.hull-cell:hover{background:#d4a85326;border-color:var(--gold-dim)}.grid-cell.outside-hull{background:#0a0a124d;border-color:#32323233;cursor:not-allowed;opacity:.3}.grid-cell.outside-hull:hover{background:#0a0a124d;border-color:#32323233}.battle-viewer{display:flex;flex-direction:column;min-height:calc(100vh - 80px);padding:var(--space-lg, 24px);gap:var(--space-lg, 24px);animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.battle-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg, 24px);background:#0a0a1ecc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:16px}.battle-header h2{margin:0;font-size:24px;font-weight:700;background:linear-gradient(135deg,#00d4ff,#7b68ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tick-display{font-size:15px;color:#ffffffb3;padding:8px 16px;background:#0000004d;border-radius:8px}.battle-field{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-xl, 32px);padding:var(--space-xl, 32px);background:radial-gradient(ellipse at center,#1e1e3ccc,#0a0a1ee6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:16px;position:relative;overflow:hidden}.battle-field:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(0,255,136,.1) 0%,transparent 30%),radial-gradient(circle at 80% 70%,rgba(255,68,102,.1) 0%,transparent 30%);animation:battleGlow 4s ease-in-out infinite alternate;pointer-events:none}@keyframes battleGlow{0%{opacity:.5}to{opacity:1}}.ship-display{flex:1;max-width:350px;display:flex;flex-direction:column;gap:var(--space-md, 16px);padding:var(--space-lg, 24px);background:#0000004d;border-radius:16px;border:1px solid rgba(255,255,255,.08);position:relative;z-index:1;transition:all .3s ease}.ship-display.destroyed{opacity:.5;filter:grayscale(.5)}.ship-display h3{margin:0;font-size:18px;font-weight:700;text-align:center}.ship-display.attacker h3{color:#0f8}.ship-display.defender h3{color:#f68}.health-bar{height:32px;background:#00000080;border-radius:8px;overflow:hidden;position:relative}.health-fill{height:100%;transition:width .3s ease;position:relative}.health-fill:after{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(to bottom,rgba(255,255,255,.2),transparent)}.health-bar.shield .health-fill{background:linear-gradient(90deg,#00d4ff,#7b68ee);box-shadow:0 0 10px #00d4ff80}.health-bar.hull .health-fill{background:linear-gradient(90deg,#0f8,#0c6);box-shadow:0 0 10px #00ff8880}.health-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:13px;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.8)}.vs-indicator{font-size:48px;filter:drop-shadow(0 0 20px rgba(255,170,0,.5));animation:pulse 2s ease-in-out infinite;z-index:1}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.event-log{display:flex;gap:8px;flex-wrap:wrap;min-height:40px;padding:var(--space-md, 16px);background:#0a0a1e99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:12px}.event-item{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#0000004d;border-radius:6px;font-size:13px;animation:fadeIn .3s ease-out}.event-type{font-weight:600;color:#ffffffb3}.event-item.event-shield_damage .event-type{color:#00d4ff}.event-item.event-hull_damage .event-type{color:#f68}.event-item.event-attack .event-type{color:#fa0}.event-damage,.event-value{font-weight:700;color:#f68}.playback-controls{display:flex;align-items:center;gap:var(--space-md, 16px);padding:var(--space-md, 16px);background:#0a0a1ecc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:12px}.control-btn{padding:10px 20px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e0e0e0;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s ease}.control-btn:hover:not(:disabled){background:#ffffff1a;border-color:#fff3}.control-btn:disabled{opacity:.4;cursor:not-allowed}.control-btn.primary{background:linear-gradient(135deg,#00d4ff,#7b68ee);border:none;color:#fff}.control-btn.primary:hover:not(:disabled){box-shadow:0 0 20px #00d4ff4d;transform:translateY(-2px)}.speed-control{display:flex;align-items:center;gap:8px;margin-left:auto;font-size:14px;color:#ffffffb3}.speed-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#e0e0e0;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.speed-btn:hover{background:#00d4ff33;border-color:#00d4ff}.outcome-display{padding:16px 32px;border-radius:12px;font-size:24px;font-weight:700;text-align:center;animation:fadeIn .5s ease-out}.outcome-display.attacker_won{background:#0f83;color:#0f8;border:1px solid rgba(0,255,136,.4);box-shadow:0 0 30px #0f83}.outcome-display.defender_won{background:#f463;color:#f68;border:1px solid rgba(255,68,102,.4);box-shadow:0 0 30px #f463}.outcome-display.draw{background:#fa03;color:#fa0;border:1px solid rgba(255,170,0,.4);box-shadow:0 0 30px #fa03}.timeline{padding:var(--space-md, 16px);background:#0a0a1e99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:12px}.timeline-slider{width:100%;height:8px;background:#ffffff1a;border-radius:4px;cursor:pointer;-webkit-appearance:none;appearance:none}.timeline-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:linear-gradient(135deg,#00d4ff,#7b68ee);border:2px solid white;border-radius:50%;cursor:grab;box-shadow:0 0 10px #00d4ff80}.timeline-slider::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,#00d4ff,#7b68ee);border:2px solid white;border-radius:50%;cursor:grab;box-shadow:0 0 10px #00d4ff80}.star-map-container{display:flex;gap:var(--space-6);padding:var(--space-6);animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.star-map{position:relative;background:linear-gradient(135deg,var(--sovereign-abyss) 0%,var(--sovereign-deep) 100%);border:1px solid var(--border-gold);border-radius:var(--radius-lg);overflow:hidden}.star-map:before,.star-map:after{content:"";position:absolute;width:32px;height:32px;border:2px solid var(--gold-dim);pointer-events:none;z-index:10}.star-map:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.star-map:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.map-grid{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 49px,rgba(212,168,83,.1) 49px,rgba(212,168,83,.1) 50px),repeating-linear-gradient(90deg,transparent,transparent 49px,rgba(212,168,83,.1) 49px,rgba(212,168,83,.1) 50px);pointer-events:none}.travel-line-svg{position:absolute;top:0;left:0;pointer-events:none}.travel-line-svg line{stroke:var(--gold-pure);stroke-opacity:.6;animation:travel-dash 1s linear infinite}@keyframes travel-dash{to{stroke-dashoffset:-10}}.map-location{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-1);cursor:pointer;transition:all var(--duration-fast) var(--ease-out-expo)}.map-location:hover{transform:translate(-50%,-50%) scale(1.1)}.map-location.selected{transform:translate(-50%,-50%) scale(1.2)}.map-location.selected .location-icon{color:var(--gold-bright);text-shadow:0 0 20px var(--gold-glow)}.location-icon{font-size:24px;transition:all var(--duration-fast)}.map-location.planet .location-icon{color:var(--holo-teal);text-shadow:0 0 12px var(--holo-teal-glow)}.map-location.station .location-icon{color:var(--gold-pure);text-shadow:0 0 12px var(--gold-glow)}.map-location.asteroid .location-icon{color:var(--bronze-core);text-shadow:0 0 12px var(--bronze-glow)}.map-location.debris .location-icon{color:var(--text-muted)}.location-name{font-family:var(--font-display);font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;opacity:0;transition:opacity var(--duration-fast)}.map-location:hover .location-name,.map-location.selected .location-name{opacity:1}.map-ship{position:absolute;transform:translate(-50%,-50%);font-size:18px;cursor:pointer;z-index:20;transition:all var(--duration-fast)}.map-ship.player{color:var(--holo-teal);text-shadow:0 0 16px var(--holo-teal-glow);filter:drop-shadow(0 0 8px rgba(61,255,200,.5))}.map-ship.enemy{color:var(--alert-crimson);text-shadow:0 0 16px var(--alert-glow)}.map-ship.traveling{animation:ship-pulse 1s ease-in-out infinite}@keyframes ship-pulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.7;transform:translate(-50%,-50%) scale(1.1)}}.map-info{width:280px;display:flex;flex-direction:column;gap:var(--space-4)}.location-info{padding:var(--space-5);background:linear-gradient(135deg,var(--sovereign-surface) 0%,var(--sovereign-raised) 100%);border:1px solid var(--border-gold);border-radius:var(--radius-md);position:relative}.location-info:before,.location-info:after{content:"";position:absolute;width:16px;height:16px;border:2px solid var(--gold-dim);pointer-events:none}.location-info:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.location-info:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.location-info h3{font-family:var(--font-display);font-size:var(--text-lg);color:var(--gold-pure);margin:0 0 var(--space-2)}.location-type{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;margin:0}.location-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-3) 0 0;line-height:1.5}.travel-info{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-gold)}.travel-info p{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-1) 0;letter-spacing:.03em}.travel-btn{width:100%;margin-top:var(--space-4);padding:var(--space-3) var(--space-5);background:var(--gradient-command);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:.15em}.travel-btn:hover{transform:translateY(-2px);box-shadow:var(--glow-gold)}.no-selection{padding:var(--space-5);background:#0a0a1299;border:1px dashed var(--border-subtle);border-radius:var(--radius-md);text-align:center}.no-selection p{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin:0}.traveling-indicator{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:#3dffc81a;border:1px solid var(--holo-teal-dim);border-radius:var(--radius-md)}.traveling-indicator span{font-family:var(--font-display);font-size:var(--text-sm);color:var(--holo-teal);letter-spacing:.1em}.traveling-pulse{animation:pulse 1s ease-in-out infinite}.star-map-container{position:relative}.map-controls{position:absolute;top:var(--space-4);right:var(--space-4);display:flex;align-items:center;gap:var(--space-2);z-index:100;background:#0a0a12e6;border:1px solid var(--border-gold);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3)}.map-controls button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-gold);border-radius:var(--radius-sm);color:var(--gold-pure);font-size:var(--text-lg);font-weight:700;cursor:pointer;transition:all var(--duration-fast)}.map-controls button:hover{background:var(--sovereign-raised);transform:scale(1.05)}.zoom-level{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);min-width:40px;text-align:center}.map-coords{position:absolute;bottom:var(--space-4);left:var(--space-4);z-index:100;background:#0a0a12e6;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3)}.map-coords span{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--holo-teal);letter-spacing:.05em}.star-map{cursor:grab}.star-map.panning{cursor:grabbing}.map-ship.enemy{z-index:10}.map-ship.enemy:not(.player):not([data-owner-id]){filter:drop-shadow(0 0 5px rgba(255,68,68,.5))}.map-ship.enemy:not(.player):not([data-owner-id]):after{content:"NPC";position:absolute;top:-15px;left:50%;transform:translate(-50%);font-size:8px;background:#ff5959cc;color:#fff;padding:1px 3px;border-radius:2px}.engagement-range{position:absolute;transform:translate(-50%,-50%);border:1px dashed rgba(61,255,200,.3);border-radius:50%;pointer-events:none;z-index:5}.map-ship.selected{transform:translate(-50%,-50%) scale(1.3)}.map-ship.in-range{animation:in-range-pulse .8s ease-in-out infinite}.map-ship.in-range:after{content:"⚔";position:absolute;top:-10px;right:-10px;font-size:10px;color:var(--alert-crimson)}@keyframes in-range-pulse{0%,to{opacity:1;filter:drop-shadow(0 0 8px rgba(255,89,89,.5))}50%{opacity:.8;filter:drop-shadow(0 0 16px rgba(255,89,89,.8))}}.map-ship.in_battle{animation:battle-ship-pulse .5s ease-in-out infinite}@keyframes battle-ship-pulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.15)}}.map-battle{position:absolute;transform:translate(-50%,-50%);cursor:pointer;z-index:25}.map-battle .battle-icon{font-size:28px;color:var(--alert-crimson);text-shadow:0 0 20px var(--alert-glow)}.map-battle .battle-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;border:2px solid var(--alert-crimson);border-radius:50%;animation:battle-location-pulse 1.5s ease-out infinite;pointer-events:none}@keyframes battle-location-pulse{0%{width:30px;height:30px;opacity:1}to{width:80px;height:80px;opacity:0}}.battle-indicator{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:#ff59591a;border:1px solid var(--alert-crimson);border-radius:var(--radius-md)}.battle-indicator span{font-family:var(--font-display);font-size:var(--text-sm);color:var(--alert-crimson);letter-spacing:.1em}.battle-indicator .battle-pulse{animation:pulse .5s ease-in-out infinite}.ship-info{padding:var(--space-5);background:linear-gradient(135deg,var(--sovereign-surface) 0%,var(--sovereign-raised) 100%);border:1px solid var(--alert-crimson);border-radius:var(--radius-md)}.ship-info h3{font-family:var(--font-display);font-size:var(--text-lg);color:var(--alert-crimson);margin:0 0 var(--space-2)}.ship-status{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;margin:0}.ship-distance{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-3) 0 0}.engage-btn{width:100%;margin-top:var(--space-4);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--alert-crimson) 0%,#951a1a 100%);border:none;border-radius:var(--radius-sm);color:#fff;font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:.15em;cursor:pointer;transition:all var(--duration-fast)}.engage-btn:hover{transform:translateY(-2px);box-shadow:0 0 20px var(--alert-glow)}.join-battle-btn{width:100%;margin-top:var(--space-4);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--holo-teal) 0%,#1a8066 100%);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:.15em;cursor:pointer;transition:all var(--duration-fast)}.join-battle-btn:hover{transform:translateY(-2px);box-shadow:0 0 20px var(--holo-teal-glow)}.no-selection .hint{font-size:var(--text-xs);color:var(--text-muted);opacity:.7;margin-top:var(--space-2)}.auth-form-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.auth-form{width:100%;max-width:400px;padding:var(--space-8);background:linear-gradient(135deg,#0a0a12f2,#10101ce6);border:1px solid var(--border-gold);border-radius:var(--radius-lg);position:relative;animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.auth-form:before,.auth-form:after{content:"";position:absolute;width:32px;height:32px;border:2px solid var(--gold-dim);pointer-events:none}.auth-form:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.auth-form:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.auth-form h2{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--gold-pure);text-align:center;margin:0 0 var(--space-6);letter-spacing:.15em}.auth-logo{display:block;text-align:center;font-size:48px;margin-bottom:var(--space-4);color:var(--gold-pure);text-shadow:var(--glow-text)}.auth-form form{display:flex;flex-direction:column;gap:var(--space-5)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em}.form-group input{padding:var(--space-4);background:var(--sovereign-abyss);border:1px solid var(--border-gold);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-base);transition:all var(--duration-fast)}.form-group input::placeholder{color:var(--text-disabled)}.form-group input:focus{outline:none;border-color:var(--gold-pure);box-shadow:0 0 0 3px var(--gold-glow)}.auth-submit{padding:var(--space-4) var(--space-6);background:var(--gradient-command);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-top:var(--space-3)}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--glow-gold)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-toggle{text-align:center;margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--border-subtle)}.auth-toggle button{background:transparent;border:none;color:var(--gold-pure);font-family:var(--font-display);font-size:var(--text-sm);letter-spacing:.1em;text-transform:uppercase;cursor:pointer}.auth-toggle button:hover{color:var(--gold-bright);text-shadow:var(--glow-text)}.auth-error{padding:var(--space-3) var(--space-4);background:#ff33551a;border:1px solid rgba(255,51,85,.3);border-radius:var(--radius-sm);color:var(--alert-crimson);font-size:var(--text-sm);text-align:center}.resource-bar{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-2) var(--space-4);background:linear-gradient(90deg,rgba(212,168,83,.05) 0%,transparent 50%,rgba(212,168,83,.05) 100%);border:1px solid var(--border-gold);border-radius:var(--radius-sm);margin-left:auto;position:relative}.resource-bar:before{content:"";position:absolute;top:-1px;left:-1px;width:8px;height:8px;border-top:2px solid var(--gold-pure);border-left:2px solid var(--gold-pure)}.resource-bar:after{content:"";position:absolute;bottom:-1px;right:-1px;width:8px;height:8px;border-bottom:2px solid var(--gold-pure);border-right:2px solid var(--gold-pure)}.resource-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);transition:all var(--duration-fast) var(--ease-out-expo)}.resource-item:hover{background:#d4a8531a}.resource-icon{font-family:var(--font-display);font-size:var(--text-sm);opacity:.8}.resource-value{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;min-width:50px;font-variant-numeric:tabular-nums;letter-spacing:.05em}.resource-item.credits .resource-value{color:var(--gold-bright);text-shadow:0 0 8px rgba(245,215,142,.4)}.resource-item.metal .resource-value{color:var(--bronze-core);text-shadow:0 0 8px rgba(196,122,62,.3)}.resource-item.energy .resource-value{color:var(--holo-teal);text-shadow:0 0 8px rgba(61,255,200,.3)}.resource-tick{display:flex;align-items:center;gap:var(--space-2);padding-left:var(--space-4);border-left:1px solid var(--border-gold);font-family:var(--font-display);font-size:var(--text-xs);letter-spacing:.05em}.tick-label{color:var(--text-muted);text-transform:uppercase}.tick-time{color:var(--holo-teal);font-weight:600}.collect-btn{padding:var(--space-1) var(--space-3);background:var(--gradient-command);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.1em}.collect-btn:hover{transform:translateY(-1px);box-shadow:var(--glow-gold)}.resource-rate{font-family:var(--font-display);font-size:var(--text-xs);font-weight:500;opacity:.8;margin-left:var(--space-1);letter-spacing:.02em}.resource-rate.positive{color:var(--holo-teal)}.resource-rate.negative{color:var(--alert-crimson)}.doctrine-editor{max-width:700px;padding:var(--space-6);background:linear-gradient(135deg,var(--sovereign-surface) 0%,var(--sovereign-raised) 100%);border:1px solid var(--border-gold);border-radius:var(--radius-lg);position:relative;animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.doctrine-editor:before,.doctrine-editor:after{content:"";position:absolute;width:24px;height:24px;border:2px solid var(--gold-dim);pointer-events:none}.doctrine-editor:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.doctrine-editor:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.doctrine-editor h3{font-family:var(--font-display);font-size:var(--text-xl);color:var(--gold-pure);margin:0 0 var(--space-3);letter-spacing:.1em}.doctrine-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-5);line-height:1.6}.doctrine-rules{margin-bottom:var(--space-6)}.doctrine-rules h4,.default-priorities h4{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.15em;margin:0 0 var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-gold)}.no-rules{font-size:var(--text-sm);color:var(--text-muted);font-style:italic;margin:var(--space-4) 0}.doctrine-rule{background:#0a0a1299;border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-3);overflow:hidden;transition:all var(--duration-fast)}.doctrine-rule:hover{border-color:var(--border-gold)}.doctrine-rule.expanded{border-color:var(--gold-pure);box-shadow:0 0 20px #d4a8531a}.rule-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--duration-fast)}.rule-header:hover{background:#d4a8530d}.rule-number{font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;color:var(--gold-dim);min-width:28px}.rule-condition{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-primary);letter-spacing:.03em}.rule-priorities{flex:1;font-size:var(--text-xs);color:var(--text-muted);text-align:right;letter-spacing:.02em}.rule-actions{display:flex;gap:var(--space-1)}.rule-actions button{width:28px;height:28px;padding:0;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--text-sm);display:flex;align-items:center;justify-content:center}.rule-actions button:hover:not(:disabled){background:#d4a8531a;border-color:var(--gold-dim);color:var(--gold-pure)}.rule-actions button:disabled{opacity:.3}.rule-actions button.delete:hover{background:#ff33551a;border-color:var(--alert-crimson);color:var(--alert-crimson)}.rule-details{padding:var(--space-4);border-top:1px solid var(--border-subtle);background:#0003;display:flex;flex-direction:column;gap:var(--space-4)}.rule-details label{display:flex;flex-direction:column;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em}.rule-details select,.rule-details input[type=number]{padding:var(--space-2) var(--space-3);background:var(--sovereign-abyss);border:1px solid var(--border-gold);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-sm)}.rule-details select:focus,.rule-details input:focus{outline:none;border-color:var(--gold-pure);box-shadow:0 0 0 2px var(--gold-glow)}.priority-checkboxes{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-2)}.priority-checkboxes>span{width:100%;font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-1)}.priority-checkboxes label{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-secondary);text-transform:capitalize;cursor:pointer;padding:var(--space-2) var(--space-3);background:#0a0a1299;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:all var(--duration-fast)}.priority-checkboxes label:hover{border-color:var(--border-gold)}.priority-checkboxes label:has(input:checked){background:#d4a8531a;border-color:var(--gold-dim);color:var(--gold-pure)}.priority-checkboxes input[type=checkbox]{width:16px;height:16px;accent-color:var(--gold-pure)}.add-rule-btn{width:100%;padding:var(--space-3) var(--space-5);background:transparent;border:1px dashed var(--border-gold);border-radius:var(--radius-md);color:var(--gold-dim);font-family:var(--font-display);font-size:var(--text-sm);letter-spacing:.1em;margin-top:var(--space-3)}.add-rule-btn:hover{background:#d4a8530d;border-style:solid;color:var(--gold-pure)}.default-priorities{margin-bottom:var(--space-6)}.default-priorities p{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-3)}.save-btn{width:100%;padding:var(--space-4) var(--space-6);background:var(--gradient-command);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:.15em}.save-btn:hover{transform:translateY(-2px);box-shadow:var(--glow-gold)}.alliance-panel{max-width:400px;padding:var(--space-6);background:linear-gradient(135deg,var(--sovereign-surface) 0%,var(--sovereign-raised) 100%);border:1px solid var(--border-gold);border-radius:var(--radius-lg);position:relative;animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.alliance-panel:before,.alliance-panel:after{content:"";position:absolute;width:20px;height:20px;border:2px solid var(--gold-dim);pointer-events:none}.alliance-panel:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.alliance-panel:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.alliance-panel.no-alliance h3{font-family:var(--font-display);font-size:var(--text-xl);color:var(--gold-pure);margin:0 0 var(--space-4);letter-spacing:.1em}.no-alliance-text{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-5)}.pending-invites{margin-bottom:var(--space-5)}.pending-invites h4{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin:0 0 var(--space-3)}.invite-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:#0a0a1299;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);margin-bottom:var(--space-2)}.invite-alliance{font-family:var(--font-display);font-size:var(--text-sm);color:var(--gold-pure);font-weight:600}.invite-from{flex:1;font-size:var(--text-sm);color:var(--text-muted)}.invite-actions{display:flex;gap:var(--space-1)}.accept-btn,.decline-btn{width:32px;height:32px;padding:0;border-radius:var(--radius-sm);font-size:var(--text-base);display:flex;align-items:center;justify-content:center}.accept-btn{background:#3dffc833;border:1px solid var(--holo-teal-dim);color:var(--holo-teal)}.accept-btn:hover{background:#3dffc84d}.decline-btn{background:#f353;border:1px solid rgba(255,51,85,.4);color:var(--alert-crimson)}.decline-btn:hover{background:#ff33554d}.create-alliance-btn{width:100%;padding:var(--space-4) var(--space-6);background:var(--gradient-command);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:.15em}.create-alliance-btn:hover{transform:translateY(-2px);box-shadow:var(--glow-gold)}.alliance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-gold)}.alliance-header h3{font-family:var(--font-display);font-size:var(--text-lg);color:var(--gold-pure);margin:0;letter-spacing:.08em}.member-count{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.alliance-stats{display:flex;gap:var(--space-4);margin-bottom:var(--space-5)}.stat{flex:1;padding:var(--space-3);background:#0a0a1299;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);text-align:center}.stat-label{display:block;font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-1)}.stat-value{font-family:var(--font-display);font-size:var(--text-lg);color:var(--gold-pure);font-weight:600}.stat-value.role-leader{color:var(--gold-bright)}.stat-value.role-officer{color:var(--holo-teal)}.stat-value.role-member{color:var(--text-primary)}.member-list h4{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin:0 0 var(--space-3)}.member-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:#0a0a1266;border-radius:var(--radius-sm);margin-bottom:var(--space-2)}.member-role{font-size:var(--text-base);min-width:20px;text-align:center}.member-role.role-leader{color:var(--gold-bright)}.member-role.role-officer{color:var(--holo-teal)}.member-name{flex:1;font-size:var(--text-sm);color:var(--text-primary)}.member-contribution{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted)}.member-overflow{font-size:var(--text-sm);color:var(--text-muted);text-align:center;padding:var(--space-2)}.leave-btn{width:100%;margin-top:var(--space-5);padding:var(--space-3) var(--space-5);background:transparent;border:1px solid rgba(255,51,85,.3);border-radius:var(--radius-sm);color:var(--alert-crimson);font-family:var(--font-display);font-size:var(--text-sm);letter-spacing:.1em}.leave-btn:hover{background:#ff33551a;border-color:var(--alert-crimson)}.repair-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #3d5a80;border-radius:12px;padding:1.5rem;color:#e0e0e0;max-width:400px}.repair-panel h3{margin:0 0 1rem;color:#64b5f6;font-size:1.2rem}.repair-panel.no-damage{background:linear-gradient(135deg,#1a2e1a,#163e16);border-color:#4caf50}.repair-status{display:flex;align-items:center;gap:.5rem;font-size:1rem}.status-icon{font-size:1.5rem}.damage-overview{margin-bottom:1.5rem}.damage-item{margin-bottom:1rem}.damage-item .label{display:block;font-size:.85rem;color:#9e9e9e;margin-bottom:.25rem}.damage-bar{height:8px;background:#333;border-radius:4px;overflow:hidden;margin-bottom:.25rem}.damage-fill{height:100%;background:linear-gradient(90deg,#f44336,#ffeb3b,#4caf50);border-radius:4px;transition:width .3s ease}.damage-item .value{font-size:.9rem;color:#e0e0e0}.damage-amount{font-size:.8rem;color:#f44336;margin-left:.5rem}.damaged-modules{background:#0003;border-radius:8px;padding:.75rem}.damaged-modules .label{display:block;font-size:.85rem;color:#9e9e9e;margin-bottom:.5rem}.damaged-modules ul{list-style:none;margin:0;padding:0}.damaged-modules li{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.85rem;border-bottom:1px solid rgba(255,255,255,.1)}.damaged-modules li:last-child{border-bottom:none}.module-name{color:#e0e0e0}.module-hp{color:#ffeb3b}.repair-cost{margin-bottom:1.5rem}.repair-cost h4{margin:0 0 .75rem;font-size:.95rem;color:#64b5f6}.cost-items{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.cost-item.time{border-color:#2196f3}.repair-button{width:100%;padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease}.repair-button.can-afford{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.repair-button.can-afford:hover:not(:disabled){background:linear-gradient(135deg,#66bb6a,#43a047);transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.repair-button.cannot-afford{background:linear-gradient(135deg,#616161,#424242);color:#9e9e9e;cursor:not-allowed}.repair-button:disabled{opacity:.7;cursor:not-allowed}.battle-history{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #3d5a80;border-radius:12px;padding:1.5rem;color:#e0e0e0;max-width:500px}.battle-history h3{margin:0 0 1rem;color:#64b5f6;font-size:1.2rem}.battle-history.loading,.battle-history.empty,.battle-history.error{text-align:center;padding:2rem}.loading-spinner{font-size:2rem;animation:spin 1s linear infinite}.empty-icon{font-size:3rem;opacity:.5;margin-bottom:.5rem}.empty-hint{font-size:.85rem;color:#9e9e9e}.battle-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.battle-item{display:grid;grid-template-columns:100px 1fr auto auto;align-items:center;gap:1rem;padding:.75rem 1rem;background:#0003;border-radius:8px;border-left:4px solid transparent;cursor:pointer;transition:all .2s ease}.battle-item:hover{background:#0000004d;transform:translate(4px)}.battle-item.victory{border-left-color:#4caf50}.battle-item.defeat{border-left-color:#f44336}.battle-item.draw{border-left-color:#ff9800}.battle-outcome{display:flex;align-items:center;gap:.5rem}.outcome-icon{font-size:1.25rem}.outcome-text{font-weight:700;font-size:.9rem}.victory .outcome-text{color:#4caf50}.defeat .outcome-text{color:#f44336}.draw .outcome-text{color:#ff9800}.battle-details{display:flex;flex-direction:column;gap:.25rem}.battle-type{font-size:.85rem;color:#bdbdbd}.battle-ticks{font-size:.75rem;color:#9e9e9e}.battle-time{font-size:.8rem;color:#9e9e9e}.battle-view{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#64b5f633;border-radius:50%;transition:all .2s ease}.battle-item:hover .battle-view{background:#64b5f666}.view-icon{color:#64b5f6;font-size:.8rem}.load-more-btn{width:100%;padding:.75rem;background:#64b5f633;border:1px solid #3d5a80;border-radius:8px;color:#64b5f6;font-size:.9rem;cursor:pointer;transition:all .2s ease}.load-more-btn:hover:not(:disabled){background:#64b5f64d}.load-more-btn:disabled{opacity:.5;cursor:not-allowed}.battle-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.5rem;font-weight:700;color:#fff}.stat-label{font-size:.75rem;color:#9e9e9e;text-transform:uppercase}.hull-upgrade{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #3d5a80;border-radius:12px;padding:1.5rem;color:#e0e0e0;max-width:400px}.hull-upgrade h3{margin:0 0 1rem;color:#64b5f6;font-size:1.2rem}.hull-upgrade.loading,.hull-upgrade.error,.hull-upgrade.max-level{text-align:center;padding:2rem}.loading-spinner{font-size:2rem;animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.max-icon{font-size:3rem;margin-bottom:.5rem}.max-level p{color:#4caf50;font-weight:700}.current-level{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}.level-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#424242,#303030);border-radius:8px;font-weight:700;font-size:1rem}.level-badge.next{background:linear-gradient(135deg,#64b5f6,#1976d2);color:#fff}.arrow{font-size:1.5rem;color:#64b5f6}.improvements{margin-bottom:1.5rem}.improvements h4{margin:0 0 .75rem;font-size:.95rem;color:#9e9e9e}.improvement-list{display:flex;flex-direction:column;gap:.5rem}.improvement{display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;align-items:center;padding:.5rem;background:#0003;border-radius:6px}.improvement .icon{font-size:1.25rem}.improvement .label{font-size:.9rem;color:#bdbdbd}.improvement .value{font-size:.9rem;font-weight:700;color:#4caf50}.upgrade-cost{margin-bottom:1.5rem}.upgrade-cost h4{margin:0 0 .75rem;font-size:.95rem;color:#9e9e9e}.cost-items{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.cost-item{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:#0003;border-radius:8px;border:1px solid transparent}.cost-item.affordable{border-color:#4caf50}.cost-item.expensive{border-color:#f44336}.cost-item .icon{font-size:1.25rem;margin-bottom:.25rem}.cost-item .amount{font-size:1.1rem;font-weight:700;color:#fff}.cost-item .label{font-size:.7rem;color:#9e9e9e;text-transform:uppercase}.upgrade-button{width:100%;padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease}.upgrade-button.can-afford{background:linear-gradient(135deg,#2196f3,#1565c0);color:#fff}.upgrade-button.can-afford:hover:not(:disabled){background:linear-gradient(135deg,#42a5f5,#1976d2);transform:translateY(-2px);box-shadow:0 4px 12px #2196f366}.upgrade-button.cannot-afford{background:linear-gradient(135deg,#616161,#424242);color:#9e9e9e;cursor:not-allowed}.upgrade-button:disabled{opacity:.7;cursor:not-allowed}.insufficient-warning{margin-top:.75rem;padding:.5rem;background:#f4433633;border:1px solid #f44336;border-radius:6px;font-size:.85rem;color:#f44336;text-align:center}.player-profile{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #3d5a80;border-radius:12px;padding:1.5rem;color:#e0e0e0;max-width:350px;position:relative}.player-profile.loading,.player-profile.error{text-align:center;padding:2rem}.loading-spinner{font-size:2.5rem;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.close-btn{position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;border:none;background:#ffffff1a;color:#e0e0e0;border-radius:50%;font-size:1.25rem;cursor:pointer;transition:all .2s ease}.profile-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.avatar{width:60px;height:60px;background:linear-gradient(135deg,#64b5f6,#1976d2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem}.name-section{display:flex;flex-direction:column;gap:.25rem}.name-section h2{margin:0;font-size:1.3rem;color:#fff}.alliance-tag{font-size:.9rem;color:#64b5f6;font-weight:700}.alliance-info{display:flex;justify-content:space-between;padding:.75rem;background:#64b5f61a;border-radius:8px;margin-bottom:1.25rem}.alliance-info .label{color:#9e9e9e;font-size:.85rem}.alliance-info .value{color:#64b5f6;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1.25rem}.stat{display:flex;flex-direction:column;align-items:center;padding:.75rem .25rem;background:#0003;border-radius:8px}.stat-value{font-size:1.25rem;font-weight:700;color:#fff}.stat-label{font-size:.7rem;color:#9e9e9e;text-transform:uppercase}.member-since{display:flex;justify-content:space-between;font-size:.85rem;color:#9e9e9e;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1)}.member-since .value{color:#bdbdbd}.alliance-chat{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #3d5a80;border-radius:12px;padding:1rem;color:#e0e0e0;display:flex;flex-direction:column;height:400px}.alliance-chat h3{margin:0 0 .75rem;color:#64b5f6;font-size:1rem}.alliance-chat.loading{justify-content:center;align-items:center}.messages-container{flex:1;overflow-y:auto;padding-right:.5rem;margin-bottom:.75rem}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:#0003;border-radius:3px}.messages-container::-webkit-scrollbar-thumb{background:#3d5a80;border-radius:3px}.no-messages{text-align:center;color:#9e9e9e;padding:2rem;font-size:.9rem}.message{margin-bottom:.75rem;padding:.5rem .75rem;background:#0003;border-radius:8px;border-left:3px solid #3d5a80}.message.own{border-left-color:#64b5f6;background:#64b5f61a}.message-header{display:flex;justify-content:space-between;margin-bottom:.25rem}.sender{font-weight:700;font-size:.8rem;color:#64b5f6}.message.own .sender{color:#81c784}.time{font-size:.7rem;color:#9e9e9e}.message-content{font-size:.9rem;line-height:1.4;word-wrap:break-word}.message-input{display:flex;gap:.5rem}.message-input input{flex:1;padding:.75rem;background:#0000004d;border:1px solid #3d5a80;border-radius:8px;color:#e0e0e0;font-size:.9rem}.message-input input:focus{outline:none;border-color:#64b5f6}.message-input input::placeholder{color:#9e9e9e}.message-input button{width:44px;height:44px;background:linear-gradient(135deg,#64b5f6,#1976d2);border:none;border-radius:8px;color:#fff;font-size:1.2rem;cursor:pointer;transition:all .2s ease}.message-input button:hover:not(:disabled){transform:scale(1.05)}.message-input button:disabled{opacity:.5;cursor:not-allowed}.match-lobby{max-width:900px;margin:0 auto;padding:var(--space-6);animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.match-lobby h2{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--gold-pure);margin:0 0 var(--space-5);letter-spacing:.1em}.lobby-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-5);border-bottom:1px solid var(--border-gold);padding-bottom:var(--space-3)}.lobby-tab{padding:var(--space-3) var(--space-5);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-display);font-size:var(--text-sm);letter-spacing:.1em;text-transform:uppercase}.lobby-tab:hover{color:var(--text-primary);background:#d4a8530d}.lobby-tab.active{color:var(--gold-pure);border-color:var(--border-gold);background:#d4a8531a}.error-banner{padding:var(--space-3) var(--space-4);background:#ff33551a;border:1px solid rgba(255,51,85,.3);border-radius:var(--radius-md);color:var(--alert-crimson);font-size:var(--text-sm);margin-bottom:var(--space-4)}.tab-content{display:flex;flex-direction:column;gap:var(--space-4)}.tab-header{display:flex;justify-content:space-between;align-items:center}.refresh-btn{padding:var(--space-2) var(--space-4);background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);color:#00d4ff;font-size:.8rem;font-weight:700;cursor:pointer;border-radius:4px}.match-list{display:flex;flex-direction:column;gap:var(--space-3)}.empty-state{text-align:center;padding:var(--space-8);color:var(--text-muted)}.match-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);background:linear-gradient(135deg,var(--sovereign-surface) 0%,var(--sovereign-raised) 100%);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.match-info h3{font-family:var(--font-display);font-size:var(--text-base);color:var(--text-primary);margin:0 0 var(--space-1)}.match-meta{display:flex;gap:var(--space-4)}.match-meta span{font-size:var(--text-xs);color:var(--text-muted)}.join-btn{padding:var(--space-2) var(--space-5);background:var(--gradient-command);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600}.lobby-details{display:flex;flex-direction:column;gap:var(--space-5)}.lobby-actions{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-5)}.ready-btn{width:100%;padding:var(--space-4) var(--space-6);background:transparent;border:2px solid var(--holo-teal-dim);border-radius:var(--radius-sm);color:var(--holo-teal);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:.15em}.ready-btn.is-ready{background:#3dffc833;border-color:var(--holo-teal)}.start-match-btn{background:linear-gradient(135deg,#a67c00,#ffbf00);color:#000;border:1px solid #ffcc33;padding:var(--space-4) var(--space-6);border-radius:var(--radius-sm);font-family:var(--font-display);font-weight:700;cursor:pointer;letter-spacing:2px;box-shadow:0 0 15px #ffbf004d}.start-match-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 0 25px #ffbf0080;background:linear-gradient(135deg,#ffbf00,gold)}.start-match-btn:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(1);box-shadow:none}.faction-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.faction-card{padding:var(--space-4);background:#0a0a1299;border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer}.faction-card.selected{border-color:var(--gold-pure);background:#d4a8531a}.player-list{display:flex;flex-direction:column;gap:var(--space-2)}.player-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:#0a0a1280;border-radius:var(--radius-sm)}.hull-painter{max-width:900px;margin:0 auto;padding:var(--space-6);animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.hull-painter h2{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--gold-pure);margin:0 0 var(--space-2);letter-spacing:.1em}.hull-painter-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-5)}.hull-stats{display:flex;gap:var(--space-5);margin-bottom:var(--space-5);padding:var(--space-4);background:#0a0a1299;border:1px solid var(--border-gold);border-radius:var(--radius-md)}.hull-stat{display:flex;flex-direction:column;gap:var(--space-1)}.hull-stat-label{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em}.hull-stat-value{font-family:var(--font-display);font-size:var(--text-lg);color:var(--gold-pure);font-weight:600}.hull-stat-value.warning{color:var(--alert-amber)}.hull-stat-value.error{color:var(--alert-crimson)}.hull-toolbar{display:flex;gap:var(--space-2);margin-bottom:var(--space-5)}.hull-tool-btn{padding:var(--space-2) var(--space-4);background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-display);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase}.hull-tool-btn:hover:not(:disabled){border-color:var(--border-gold);color:var(--gold-pure)}.hull-tool-btn:disabled{opacity:.4;cursor:not-allowed}.hull-grid-container{display:flex;gap:var(--space-6);margin-bottom:var(--space-5)}.hull-grid{display:grid;gap:2px;padding:var(--space-4);background:linear-gradient(135deg,var(--sovereign-abyss) 0%,var(--sovereign-deep) 100%);border:1px solid var(--border-gold);border-radius:var(--radius-md)}.hull-cell{width:24px;height:24px;background:#d4a8530d;border:1px solid rgba(212,168,83,.1);border-radius:2px;cursor:pointer;transition:all var(--duration-fast)}.hull-cell:hover{background:#d4a85326;border-color:var(--gold-dim)}.hull-cell.filled{background:linear-gradient(135deg,var(--gold-pure) 0%,var(--gold-dim) 100%);border-color:var(--gold-bright);box-shadow:0 0 8px var(--gold-glow)}.hull-cell.disconnected{background:linear-gradient(135deg,#f359,#b41e3266);border-color:var(--alert-crimson);animation:pulse-danger .8s ease-in-out infinite}@keyframes pulse-danger{0%,to{opacity:1}50%{opacity:.6}}.hull-presets{min-width:200px}.hull-presets h4{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin:0 0 var(--space-3)}.preset-btn{display:block;width:100%;padding:var(--space-3);background:#0a0a1299;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);text-align:left;margin-bottom:var(--space-2);transition:all var(--duration-fast)}.preset-btn:hover{border-color:var(--border-gold);background:#d4a8530d}.preset-name{display:block;font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-1)}.preset-desc{display:block;font-size:var(--text-xs);color:var(--text-muted)}.hull-errors{padding:var(--space-4);background:#ff33551a;border:1px solid rgba(255,51,85,.3);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.hull-error{font-size:var(--text-sm);color:var(--alert-crimson);padding:var(--space-1) 0}.hull-save-btn{width:100%;padding:var(--space-4) var(--space-6);background:var(--gradient-command);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:.15em;text-transform:uppercase}.hull-save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--glow-gold)}.hull-save-btn:disabled{opacity:.5;cursor:not-allowed}.main-menu{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);background:radial-gradient(ellipse at center,rgba(212,168,83,.03) 0%,transparent 50%),var(--gradient-void);position:relative}.main-menu:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(212,168,83,.02) 40px,rgba(212,168,83,.02) 41px),repeating-linear-gradient(-45deg,transparent,transparent 40px,rgba(212,168,83,.02) 40px,rgba(212,168,83,.02) 41px);pointer-events:none}.menu-header{text-align:center;margin-bottom:var(--space-8);position:relative;z-index:1}.menu-title{font-family:var(--font-display);font-size:clamp(2rem,6vw,4rem);font-weight:700;color:var(--gold-pure);letter-spacing:.2em;margin:0;text-shadow:0 0 40px var(--gold-glow);animation:titleGlow 3s ease-in-out infinite}@keyframes titleGlow{0%,to{text-shadow:0 0 40px var(--gold-glow)}50%{text-shadow:0 0 60px var(--gold-glow),0 0 80px var(--gold-glow)}}.menu-subtitle{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-muted);letter-spacing:.3em;margin-top:var(--space-2)}.menu-content{max-width:500px;width:100%;position:relative;z-index:1;animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.menu-welcome{display:flex;flex-direction:column;align-items:center;margin-bottom:var(--space-8);padding:var(--space-4);background:#0a0a1299;border:1px solid var(--border-gold);border-radius:var(--radius-md)}.welcome-label{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.2em}.welcome-name{font-family:var(--font-display);font-size:var(--text-xl);color:var(--gold-pure);letter-spacing:.1em;margin-top:var(--space-1)}.menu-nav{display:flex;flex-direction:column;gap:var(--space-3)}.menu-btn{display:flex;align-items:center;gap:var(--space-4);width:100%;padding:var(--space-5) var(--space-6);background:#0a0a1299;border:1px solid var(--border-subtle);border-radius:var(--radius-md);text-align:left;transition:all var(--duration-fast);cursor:pointer}.menu-btn:hover{border-color:var(--border-gold);background:#d4a8530d;transform:translate(8px)}.menu-btn.primary{border-color:var(--border-gold);background:linear-gradient(135deg,#d4a8531a,#a27d371a)}.menu-btn.primary:hover{background:linear-gradient(135deg,#d4a85333,#a27d3733);box-shadow:0 0 30px var(--gold-glow)}.menu-btn.exit{border-color:#f353}.menu-btn.exit:hover{border-color:var(--alert-crimson);background:#ff33551a}.btn-icon{font-size:var(--text-lg);color:var(--gold-dim);width:24px;text-align:center}.btn-text{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-primary);letter-spacing:.15em}.back-btn{padding:var(--space-2) var(--space-4);background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-display);font-size:var(--text-xs);letter-spacing:.1em;margin-bottom:var(--space-5)}.back-btn:hover{border-color:var(--border-gold);color:var(--gold-pure)}.profile-section,.settings-section{padding:var(--space-6);background:#0a0a1299;border:1px solid var(--border-gold);border-radius:var(--radius-md)}.profile-section h2,.settings-section h2{font-family:var(--font-display);font-size:var(--text-lg);color:var(--gold-pure);margin:0 0 var(--space-5);letter-spacing:.1em}.profile-stats{display:flex;flex-direction:column;gap:var(--space-3)}.stat-row{display:flex;justify-content:space-between;padding:var(--space-3);background:#0a0a1280;border-radius:var(--radius-sm)}.stat-label{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.15em}.stat-value{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-primary)}.profile-note,.settings-note{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--text-muted);text-align:center}.menu-footer{position:absolute;bottom:var(--space-6);text-align:center}.version{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.1em}.match-view{min-height:100vh;display:flex;flex-direction:column;background:var(--gradient-void)}.match-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);color:var(--text-muted)}.match-loading .loading-spinner{font-size:var(--text-3xl);color:var(--gold-pure);animation:spin 2s linear infinite}.match-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:linear-gradient(180deg,#0a0a12f2,#0a0a12cc);border-bottom:1px solid var(--border-gold);position:sticky;top:0;z-index:100}.match-info{display:flex;align-items:center;gap:var(--space-4)}.match-name{font-family:var(--font-display);font-size:var(--text-lg);color:var(--gold-pure);letter-spacing:.1em;margin:0}.match-status{padding:var(--space-1) var(--space-3);font-family:var(--font-display);font-size:var(--text-xs);letter-spacing:.1em;border-radius:var(--radius-sm)}.match-status.status-lobby{background:#fc03;color:var(--alert-amber);border:1px solid var(--alert-amber)}.match-status.status-active{background:#3dffc833;color:var(--holo-teal);border:1px solid var(--holo-teal)}.match-nav{display:flex;gap:var(--space-1)}.match-nav button{padding:var(--space-2) var(--space-4);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-display);font-size:var(--text-xs);letter-spacing:.1em;transition:all var(--duration-fast)}.match-nav button:hover:not(:disabled){color:var(--text-primary);background:#d4a8530d}.match-nav button.active{color:var(--gold-pure);border-color:var(--border-gold);background:#d4a8531a}.match-nav button:disabled{opacity:.4;cursor:not-allowed}.leave-match-btn{padding:var(--space-2) var(--space-4);background:transparent;border:1px solid rgba(255,51,85,.3);border-radius:var(--radius-sm);color:var(--alert-crimson);font-family:var(--font-display);font-size:var(--text-xs);letter-spacing:.1em}.leave-match-btn:hover{background:#ff33551a;border-color:var(--alert-crimson)}.hull-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.5rem 1rem;background:#0a142880;border-radius:4px}.save-status{font-weight:700;font-size:.9rem;letter-spacing:1px}.save-status.success{color:#0f8}.save-status.error{color:#f44}.match-content{flex:1;overflow:auto}.tab-content{padding:var(--space-6);max-width:1200px;margin:0 auto}.no-battle{text-align:center;padding:var(--space-10);color:var(--text-muted)}.no-battle h3{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-secondary);margin:0 0 var(--space-2)}.no-battle p{margin:0}.lobby-container{max-width:900px;margin:0 auto;padding:var(--space-6)}.lobby-actions{margin-top:var(--space-6);text-align:center}.enter-match-btn{padding:var(--space-4) var(--space-8);background:var(--gradient-command);border:none;border-radius:var(--radius-md);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-base);font-weight:700;letter-spacing:.15em;cursor:pointer;transition:all var(--duration-fast)}.enter-match-btn:hover{transform:translateY(-2px);box-shadow:var(--glow-gold)}.lobby-btn{background:#3dffc81a!important;border-color:var(--holo-teal)!important;color:var(--holo-teal)!important}.resource-bar{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-2) var(--space-4);background:#0a0a12cc;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.sync-indicator{font-size:.75rem;color:#00d4ff;margin-right:1rem;letter-spacing:1px;animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}.resource-item{font-size:var(--text-base)}.resource-value{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.resource.credits .resource-value{color:var(--gold-pure)}.resource.metal .resource-value{color:var(--bronze-core)}.resource.energy .resource-value{color:var(--holo-teal)}.battle-overlay{position:fixed;inset:0;background:#0a0a12f2;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn var(--duration-fast) ease-out}.battle-overlay-content{position:relative;width:95%;max-width:1200px;max-height:90vh;overflow:auto;padding:var(--space-6);background:linear-gradient(135deg,var(--sovereign-surface) 0%,var(--sovereign-raised) 100%);border:2px solid var(--alert-crimson);border-radius:var(--radius-lg);box-shadow:0 0 60px var(--alert-glow)}.close-battle-btn{position:absolute;top:var(--space-4);right:var(--space-4);padding:var(--space-2) var(--space-4);background:transparent;border:1px solid var(--alert-crimson);border-radius:var(--radius-sm);color:var(--alert-crimson);font-family:var(--font-display);font-size:var(--text-xs);letter-spacing:.1em;cursor:pointer;transition:all var(--duration-fast);z-index:10}.close-battle-btn:hover{background:#f353}.hull-cost-info{margin-bottom:var(--space-4);padding:var(--space-3) var(--space-4);background:#0a0a1299;border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.hull-cost-info span{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-muted);letter-spacing:.05em}.fleet-commander{background:linear-gradient(135deg,#0a0a1a,#1a1a3a);border:1px solid #3a3a6a;border-radius:12px;padding:24px;max-width:500px;color:#e0e0ff}.fleet-commander-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.fleet-commander-header h2{margin:0;font-size:1.5rem;color:#8080ff}.close-btn{background:none;border:none;color:gray;font-size:1.5rem;cursor:pointer;padding:4px 8px;transition:color .2s}.close-btn:hover{color:#ff6060}.fleet-error{background:#ff3c3c33;border:1px solid #ff6060;border-radius:6px;padding:12px;margin-bottom:16px;color:#ff9090}.fleet-section{margin-bottom:20px}.fleet-section h3{font-size:.9rem;color:#6060a0;margin:0 0 12px;text-transform:uppercase;letter-spacing:1px}.select-all-btn{background:#5050a04d;border:1px solid #5050a0;border-radius:6px;color:#a0a0ff;padding:8px 16px;cursor:pointer;font-size:.85rem;margin-bottom:12px;transition:all .2s}.select-all-btn:hover{background:#5050a080}.ship-list{max-height:200px;overflow-y:auto;border:1px solid #2a2a4a;border-radius:8px}.no-ships{padding:20px;text-align:center;color:#606080;font-style:italic}.ship-item{display:flex;align-items:center;gap:12px;padding:12px;border-bottom:1px solid #2a2a4a;cursor:pointer;transition:background .2s}.ship-item:last-child{border-bottom:none}.ship-item:hover{background:#5050a033}.ship-item.selected{background:#50a05033;border-left:3px solid #60ff60}.ship-item input[type=checkbox]{width:18px;height:18px;accent-color:#60ff60}.ship-info{display:flex;flex-direction:column;gap:4px}.ship-name{font-weight:500;color:#c0c0ff}.ship-meta{font-size:.8rem;color:#707090}.destination-inputs{display:flex;gap:16px}.coord-input{display:flex;align-items:center;gap:8px}.coord-input label{color:#8080a0;font-weight:500}.coord-input input{width:80px;background:#1a1a2a;border:1px solid #3a3a6a;border-radius:6px;padding:8px 12px;color:#e0e0ff;font-size:1rem}.coord-input input:focus{outline:none;border-color:#6060ff}.fleet-name-input{width:100%;background:#1a1a2a;border:1px solid #3a3a6a;border-radius:6px;padding:10px 14px;color:#e0e0ff;font-size:1rem;box-sizing:border-box}.fleet-name-input::placeholder{color:#505060}.fleet-name-input:focus{outline:none;border-color:#6060ff}.fleet-summary{background:#28285080;border-radius:8px;padding:16px;margin-bottom:20px}.summary-item{display:flex;justify-content:space-between;padding:6px 0}.summary-item:not(:last-child){border-bottom:1px solid #3a3a5a}.summary-value{font-weight:600;color:#80ff80}.launch-btn{width:100%;background:linear-gradient(135deg,#4040a0,#6060c0);border:none;border-radius:8px;padding:14px 24px;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s}.launch-btn:hover:not(:disabled){background:linear-gradient(135deg,#5050b0,#7070d0);transform:translateY(-2px);box-shadow:0 4px 12px #5050c866}.launch-btn:disabled{opacity:.5;cursor:not-allowed}.scout-report{background:linear-gradient(135deg,#0a1a0a,#1a2a1a);border:1px solid #2a4a2a;border-radius:12px;padding:16px;max-width:400px;color:#c0e0c0}.scout-report.loading{display:flex;align-items:center;justify-content:center;min-height:100px}.loading-spinner{color:#60a060;animation:pulse 1.5s ease-in-out infinite}.scout-report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #2a4a2a}.scout-report-header h3{margin:0;font-size:1.2rem;color:#80ff80}.snapshot-count{font-size:.85rem;color:#609060;background:#3c783c33;padding:4px 10px;border-radius:12px}.no-intel{text-align:center;padding:20px;color:#608060}.no-intel .hint{font-size:.85rem;color:#506050;margin-top:8px}.snapshot-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto}.snapshot-item{background:#14281499;border:1px solid #2a4a2a;border-radius:8px;padding:12px;cursor:pointer;transition:all .2s}.snapshot-item:hover{background:#1e3c1e99;border-color:#3a6a3a}.snapshot-item.expanded{background:#1e3c1ecc;border-color:#4a8a4a}.snapshot-item.expiring{border-color:#aa6030}.snapshot-item.expiring .expiry-badge{color:#ffaa60;background:#ffa05033}.snapshot-header{display:flex;align-items:center;gap:12px}.faction-badge{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:1.1rem;flex-shrink:0}.snapshot-main{flex:1;min-width:0}.target-info{display:flex;flex-direction:column;gap:2px}.target-id{font-weight:500;color:#a0e0a0;font-size:.9rem}.faction-name{font-size:.75rem;color:#709070}.location-info{font-size:.8rem;color:#608060;margin-top:4px}.expiry-badge{font-size:.75rem;color:#80b080;background:#50a05033;padding:4px 8px;border-radius:8px;white-space:nowrap}.snapshot-details{margin-top:12px;padding-top:12px;border-top:1px solid #2a4a2a}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:.9rem}.stat-value{font-weight:500;color:#80ff80}.health-bar{width:150px;height:16px;background:#1a2a1a;border-radius:4px;position:relative;overflow:hidden}.health-fill{height:100%;background:linear-gradient(90deg,#60c060,#80ff80);transition:width .3s}.health-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:500;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.module-list{margin-top:10px;padding-top:10px;border-top:1px dashed #2a4a2a}.module-header{font-size:.8rem;color:#609060;display:block;margin-bottom:6px}.module-item{display:flex;gap:8px;padding:4px 0;font-size:.85rem}.module-cat{font-size:.7rem;padding:2px 6px;border-radius:4px;text-transform:uppercase;background:#2a4a2a;color:#80a080}.module-cat.weapon{background:#4a2a2a;color:#ffa0a0}.module-cat.defense{background:#2a2a4a;color:#a0a0ff}.module-cat.command{background:#4a4a2a;color:#ffff80}.module-cat.engine{background:#2a4a4a;color:#80ffff}.module-name{color:#a0c0a0}.scouted-by{margin-top:10px;font-size:.75rem;color:#506050;font-style:italic}.target-btn{width:100%;margin-top:12px;background:linear-gradient(135deg,#306030,#408040);border:none;border-radius:6px;padding:10px;color:#fff;font-weight:500;cursor:pointer;transition:all .2s}.target-btn:hover{background:linear-gradient(135deg,#408040,#50a050);transform:translateY(-1px)}.settings-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid #3d5a80;border-radius:12px;padding:1.5rem;color:#e0e0e0;max-width:450px;position:relative}.settings-panel h2{margin:0 0 1.25rem;color:#64b5f6;font-size:1.3rem}.close-btn{position:absolute;top:.75rem;right:.75rem;width:32px;height:32px;border:none;background:#ffffff1a;color:#e0e0e0;border-radius:50%;font-size:1.25rem;cursor:pointer;transition:all .2s ease}.close-btn:hover{background:#fff3}section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}section:last-of-type{border-bottom:none;margin-bottom:1rem}section h3{margin:0 0 .75rem;font-size:1rem;color:#9e9e9e}.setting-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.75rem;margin-bottom:.75rem}.setting-row label{font-size:.9rem}.setting-row input[type=range]{width:120px;accent-color:#64b5f6}.setting-row span{width:40px;text-align:right;font-size:.85rem;color:#9e9e9e}.setting-row.toggle{grid-template-columns:1fr auto}.setting-row select{padding:.4rem .75rem;background:#0000004d;border:1px solid #3d5a80;border-radius:6px;color:#e0e0e0;font-size:.85rem}.setting-row select:focus{outline:none;border-color:#64b5f6}.toggle-btn{padding:.4rem .75rem;border:none;border-radius:6px;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;min-width:70px}.toggle-btn.on{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.toggle-btn.off{background:#ffffff1a;color:#9e9e9e}.toggle-btn:hover:not(:disabled){transform:scale(1.02)}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.settings-footer{display:flex;justify-content:center}.reset-btn{padding:.6rem 1.25rem;background:#f4433633;border:1px solid rgba(244,67,54,.5);border-radius:8px;color:#f44336;font-size:.85rem;cursor:pointer;transition:all .2s ease}.reset-btn:hover{background:#f443364d}.tutorial-overlay{position:fixed;inset:0;background:#000000b3;z-index:9998}.tutorial-box{position:fixed;z-index:9999;background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #64b5f6;border-radius:16px;padding:1.5rem;max-width:400px;box-shadow:0 0 40px #64b5f64d;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.tutorial-box.position-center{top:50%;left:50%;transform:translate(-50%,-50%)}.tutorial-box.position-top{top:20%;left:50%;transform:translate(-50%)}.tutorial-box.position-bottom{bottom:20%;left:50%;transform:translate(-50%)}.tutorial-box.position-left{top:50%;left:20%;transform:translateY(-50%)}.tutorial-box.position-right{top:50%;right:20%;transform:translateY(-50%)}.tutorial-progress{display:flex;justify-content:center;gap:.5rem;margin-bottom:1rem}.progress-dot{width:10px;height:10px;border-radius:50%;background:#fff3;transition:all .3s ease}.progress-dot.active{background:#64b5f6;transform:scale(1.2)}.progress-dot.completed{background:#4caf50}.tutorial-box h3{margin:0 0 .75rem;color:#fff;font-size:1.25rem;text-align:center}.tutorial-box p{margin:0 0 1.25rem;color:#bdbdbd;font-size:.95rem;line-height:1.5;text-align:center}.tutorial-actions{display:flex;justify-content:space-between;align-items:center}.skip-btn{padding:.5rem .75rem;background:none;border:none;color:#9e9e9e;font-size:.85rem;cursor:pointer;transition:color .2s}.skip-btn:hover{color:#e0e0e0}.nav-buttons{display:flex;gap:.5rem}.prev-btn,.next-btn{padding:.6rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease}.prev-btn{background:#ffffff1a;color:#e0e0e0}.prev-btn:hover{background:#fff3}.next-btn{background:linear-gradient(135deg,#64b5f6,#1976d2);color:#fff}.next-btn:hover{transform:scale(1.02)}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem}.loading-spinner-container.fullscreen{position:fixed;inset:0;z-index:9999}.loading-overlay{position:fixed;inset:0;background:#000c;z-index:9999;display:flex;align-items:center;justify-content:center}.spinner{position:relative;display:flex;align-items:center;justify-content:center}.loading-spinner-container.small .spinner{width:40px;height:40px}.loading-spinner-container.medium .spinner{width:64px;height:64px}.loading-spinner-container.large .spinner{width:96px;height:96px}.spinner-ring{position:absolute;border-radius:50%;border:3px solid transparent;border-top-color:#64b5f6;animation:spin 1s linear infinite}.loading-spinner-container.small .spinner-ring{width:40px;height:40px;border-width:2px}.loading-spinner-container.medium .spinner-ring{width:64px;height:64px}.loading-spinner-container.large .spinner-ring{width:96px;height:96px;border-width:4px}.spinner-ring:nth-child(2){width:80%;height:80%;border-top-color:#4caf50;animation-duration:1.2s;animation-direction:reverse}.spinner-ring:nth-child(3){width:60%;height:60%;border-top-color:#ff9800;animation-duration:.8s}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-core{font-size:1.25rem;animation:pulse 1s ease-in-out infinite}.loading-spinner-container.small .spinner-core{font-size:.9rem}.loading-spinner-container.large .spinner-core{font-size:1.75rem}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.loading-message{color:#bdbdbd;font-size:.9rem;margin:0;animation:fadeInOut 1.5s ease-in-out infinite}@keyframes fadeInOut{0%,to{opacity:.6}50%{opacity:1}}.skeleton{background:linear-gradient(90deg,#ffffff1a 25%,#fff3,#ffffff1a 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;margin-bottom:.5rem}.skeleton:last-child{margin-bottom:0}.skeleton-text{border-radius:4px}.skeleton-rounded{border-radius:8px}.skeleton-circular{border-radius:50%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.error-banner-container{position:fixed;top:1rem;right:1rem;z-index:10000;display:flex;flex-direction:column;gap:.5rem;max-width:400px}.error-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;cursor:pointer;animation:slideIn .3s ease;box-shadow:0 4px 12px #0000004d;transition:all .2s ease}.error-banner:hover{transform:translate(-4px)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.error-banner.error{background:linear-gradient(135deg,#f44336,#c62828);border:1px solid #ff5252;color:#fff}.error-banner.warning{background:linear-gradient(135deg,#ff9800,#f57c00);border:1px solid #ffb74d;color:#fff}.error-banner.success{background:linear-gradient(135deg,#4caf50,#388e3c);border:1px solid #81c784;color:#fff}.error-banner.info{background:linear-gradient(135deg,#2196f3,#1976d2);border:1px solid #64b5f6;color:#fff}.error-icon{font-size:1.25rem;line-height:1}.error-message{flex:1;font-size:.9rem;line-height:1.3}.dismiss-hint{font-size:.7rem;opacity:.7;white-space:nowrap}@media(max-width:600px){.error-banner-container{left:1rem;right:1rem;max-width:none}}:root{--sovereign-void: #030306;--sovereign-abyss: #0a0a12;--sovereign-deep: #10101c;--sovereign-surface: #181828;--sovereign-raised: #1e1e32;--gold-pure: #d4a853;--gold-bright: #f5d78e;--gold-dim: #a67c32;--gold-glow: rgba(212, 168, 83, .4);--gold-subtle: rgba(212, 168, 83, .08);--bronze-core: #c47a3e;--bronze-glow: rgba(196, 122, 62, .3);--holo-teal: #3dffc8;--holo-teal-dim: #1a997a;--holo-teal-glow: rgba(61, 255, 200, .3);--alert-crimson: #ff3355;--alert-glow: rgba(255, 51, 85, .3);--nav-blue: #4499ff;--nav-blue-glow: rgba(68, 153, 255, .3);--text-command: #ffffff;--text-primary: #e8e4dc;--text-secondary: #a09888;--text-muted: #605848;--text-disabled: #3a3428;--border-gold: rgba(212, 168, 83, .3);--border-subtle: rgba(232, 228, 220, .08);--border-active: rgba(212, 168, 83, .6);--grid-line: rgba(212, 168, 83, .12);--gradient-command: linear-gradient(135deg, var(--gold-dim) 0%, var(--gold-pure) 50%, var(--gold-bright) 100%);--gradient-void: linear-gradient(180deg, var(--sovereign-void) 0%, var(--sovereign-abyss) 40%, var(--sovereign-deep) 100%);--gradient-surface: linear-gradient(135deg, var(--sovereign-surface) 0%, var(--sovereign-raised) 100%);--gradient-danger: linear-gradient(135deg, #cc2244 0%, var(--alert-crimson) 100%);--gradient-teal: linear-gradient(135deg, var(--holo-teal-dim) 0%, var(--holo-teal) 100%);--glass-gold: linear-gradient(180deg, rgba(212, 168, 83, .05) 0%, transparent 100%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .5);--shadow-md: 0 4px 24px rgba(0, 0, 0, .6);--shadow-lg: 0 8px 48px rgba(0, 0, 0, .7);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .04);--glow-gold: 0 0 20px var(--gold-glow), 0 0 40px rgba(212, 168, 83, .15);--glow-teal: 0 0 20px var(--holo-teal-glow), 0 0 40px rgba(61, 255, 200, .1);--glow-danger: 0 0 20px var(--alert-glow), 0 0 40px rgba(255, 51, 85, .1);--glow-text: 0 0 10px rgba(212, 168, 83, .5);--font-display: "Orbitron", monospace;--font-body: "Rajdhani", sans-serif;--font-accent: "Cinzel", serif;--text-xs: .65rem;--text-sm: .8rem;--text-base: .95rem;--text-lg: 1.15rem;--text-xl: 1.4rem;--text-2xl: 1.8rem;--text-3xl: 2.4rem;--text-4xl: 3.2rem;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-8: 48px;--space-10: 64px;--radius-sm: 2px;--radius-md: 4px;--radius-lg: 8px;--radius-xl: 12px;--ease-out-expo: cubic-bezier(.19, 1, .22, 1);--ease-in-out-expo: cubic-bezier(.87, 0, .13, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-instant: .1s;--duration-fast: .2s;--duration-normal: .35s;--duration-slow: .6s;--duration-dramatic: 1s}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{margin:0;padding:0;font-family:var(--font-body);font-size:var(--text-base);font-weight:500;letter-spacing:.02em;background:var(--sovereign-void);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 60px,var(--grid-line) 60px,var(--grid-line) 61px),repeating-linear-gradient(-45deg,transparent,transparent 60px,var(--grid-line) 60px,var(--grid-line) 61px),radial-gradient(ellipse at center,transparent 0%,var(--sovereign-void) 70%);pointer-events:none;z-index:-2}body:after{content:"";position:fixed;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--gold-glow) 50%,transparent 100%);animation:scanline 8s linear infinite;pointer-events:none;z-index:9999;opacity:.6}@keyframes scanline{0%{top:0;opacity:0}5%{opacity:.6}95%{opacity:.6}to{top:100%;opacity:0}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--sovereign-abyss);border-left:1px solid var(--border-gold)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--gold-dim) 0%,var(--bronze-core) 100%);border-radius:0}::-webkit-scrollbar-thumb:hover{background:var(--gold-pure)}::selection{background:var(--gold-dim);color:var(--sovereign-void)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin:0;color:var(--text-command)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}a{color:var(--gold-pure);text-decoration:none;transition:color var(--duration-fast) var(--ease-out-expo);position:relative}a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--gold-bright);transition:width var(--duration-normal) var(--ease-out-expo)}a:hover:after{width:100%}a:hover{color:var(--gold-bright);text-shadow:var(--glow-text)}button{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all var(--duration-normal) var(--ease-out-expo);border:none;outline:none;position:relative;overflow:hidden}button:disabled{cursor:not-allowed;opacity:.35;filter:grayscale(.5)}.btn-primary,button.active{background:var(--gradient-command);color:var(--sovereign-void);padding:var(--space-3) var(--space-5);border-radius:var(--radius-sm);box-shadow:var(--glow-gold)}.btn-primary:hover:not(:disabled),button.active:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--glow-gold),0 8px 24px #0006}.btn-secondary{background:transparent;color:var(--gold-pure);padding:var(--space-3) var(--space-5);border:1px solid var(--border-gold);border-radius:var(--radius-sm)}.btn-secondary:hover:not(:disabled){background:var(--gold-subtle);border-color:var(--gold-pure);box-shadow:inset 0 0 20px var(--gold-glow)}.btn-danger{background:var(--gradient-danger);color:#fff;padding:var(--space-3) var(--space-5);border-radius:var(--radius-sm)}.btn-danger:hover:not(:disabled){box-shadow:var(--glow-danger);transform:translateY(-2px)}.panel{background:var(--gradient-surface);border:1px solid var(--border-gold);border-radius:var(--radius-md);position:relative;overflow:hidden}.panel:before,.panel:after{content:"";position:absolute;width:20px;height:20px;border:2px solid var(--gold-dim);pointer-events:none}.panel:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.panel:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.text-gold{color:var(--gold-pure)}.text-teal{color:var(--holo-teal)}.text-danger{color:var(--alert-crimson)}.text-muted{color:var(--text-muted)}.bg-void{background:var(--sovereign-void)}.bg-surface{background:var(--sovereign-surface)}.border-gold{border:1px solid var(--border-gold)}.border-active{border-color:var(--border-active)}.glow-gold{box-shadow:var(--glow-gold)}.glow-teal{box-shadow:var(--glow-teal)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 20px var(--gold-glow)}50%{box-shadow:0 0 40px var(--gold-glow),0 0 60px #d4a85333}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.animate-in{animation:fadeIn var(--duration-slow) var(--ease-out-expo) forwards}.animate-slide{animation:slideInRight var(--duration-slow) var(--ease-out-expo) forwards}.animate-pulse{animation:pulseGlow 3s ease-in-out infinite}.stagger-children>*{opacity:0;animation:fadeIn var(--duration-normal) var(--ease-out-expo) forwards}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:50ms}.stagger-children>*:nth-child(3){animation-delay:.1s}.stagger-children>*:nth-child(4){animation-delay:.15s}.stagger-children>*:nth-child(5){animation-delay:.2s}.stagger-children>*:nth-child(6){animation-delay:.25s}.stagger-children>*:nth-child(7){animation-delay:.3s}.stagger-children>*:nth-child(8){animation-delay:.35s}:focus-visible{outline:2px solid var(--gold-pure);outline-offset:2px}button:focus-visible{box-shadow:0 0 0 3px var(--gold-glow)}.app{min-height:100vh;position:relative;display:flex;flex-direction:column}.nav-bar{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:linear-gradient(180deg,#0a0a12f2,#10101ceb);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-gold);position:sticky;top:0;z-index:1000;position:relative}.nav-bar:before{content:"";position:absolute;bottom:0;left:0;width:100%;height:1px;background:linear-gradient(90deg,transparent 0%,var(--gold-dim) 20%,var(--gold-pure) 50%,var(--gold-dim) 80%,transparent 100%)}.nav-bar h1{margin:0;font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;letter-spacing:.15em;color:var(--gold-pure);text-shadow:var(--glow-text);position:relative;padding-left:var(--space-8)}.nav-bar h1:before{content:"◇";position:absolute;left:0;top:50%;transform:translateY(-50%);font-size:var(--text-2xl);color:var(--gold-bright);animation:pulseGlow 3s ease-in-out infinite}.nav-buttons{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:center}.nav-buttons button{padding:var(--space-2) var(--space-4);background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-display);font-size:var(--text-xs);font-weight:500;letter-spacing:.12em;text-transform:uppercase;position:relative;overflow:hidden}.nav-buttons button:hover:not(:disabled){background:var(--gold-subtle);border-color:var(--border-gold);color:var(--gold-pure);transform:translateY(-1px)}.nav-buttons button.active{background:linear-gradient(180deg,#d4a85326,#d4a8530d);border-color:var(--gold-pure);color:var(--gold-bright);box-shadow:inset 0 1px #d4a85333,0 0 20px #d4a85326}.nav-buttons button.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gradient-command)}.nav-buttons button:disabled{opacity:.25;color:var(--text-disabled)}.nav-buttons .battle-btn{background:var(--gradient-danger);border:none;color:#fff;font-weight:600;padding:var(--space-2) var(--space-5);letter-spacing:.15em}.nav-buttons .battle-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--glow-danger)}.nav-buttons .battle-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2s linear infinite}.nav-buttons .signout-btn{background:transparent;border:1px solid rgba(255,51,85,.3);color:var(--text-muted);margin-left:var(--space-4)}.nav-buttons .signout-btn:hover{background:#ff33551a;border-color:var(--alert-crimson);color:var(--alert-crimson)}.loading-screen,.error-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-6);background:var(--sovereign-void);position:relative}.loading-screen:before{content:"";position:absolute;width:200px;height:200px;border:2px solid var(--border-gold);transform:rotate(45deg);animation:rotate-frame 20s linear infinite}.loading-screen:after{content:"";position:absolute;width:260px;height:260px;border:1px solid rgba(212,168,83,.2);transform:rotate(22.5deg);animation:rotate-frame 30s linear infinite reverse}@keyframes rotate-frame{0%{transform:rotate(45deg)}to{transform:rotate(405deg)}}.loading-spinner{font-size:64px;filter:drop-shadow(0 0 30px var(--gold-glow));animation:float 3s ease-in-out infinite;z-index:1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.loading-screen p{font-family:var(--font-display);font-size:var(--text-sm);color:var(--gold-pure);letter-spacing:.3em;text-transform:uppercase;z-index:1;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.error-screen h2{font-family:var(--font-display);color:var(--alert-crimson);font-size:var(--text-2xl);letter-spacing:.1em;text-shadow:var(--glow-danger)}.error-screen p{color:var(--text-secondary);max-width:400px;text-align:center;font-size:var(--text-base)}.error-screen button{padding:var(--space-4) var(--space-8);background:var(--gradient-command);border:none;border-radius:var(--radius-sm);color:var(--sovereign-void);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;letter-spacing:.15em;text-transform:uppercase}.error-screen button:hover{transform:translateY(-2px);box-shadow:var(--glow-gold)}.main-content{flex:1;padding:var(--space-6);animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.main-content>*{animation:fadeIn var(--duration-normal) var(--ease-out-expo) forwards}[class*=viewer],[class*=editor],[class*=panel]{animation:slideInRight var(--duration-slow) var(--ease-out-expo) forwards}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}
