/* ============================================================
   styles.css — Nuclear Command III Total War Edition — Classic Military UI
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;600;700;900&family=Share+Tech+Mono&family=Rajdhani:wght@400;600;700&display=swap');

/* ---- RESET & BASE ---- */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --red:#ff1a1a;--dred:#8b0000;--green:#00ff88;--dgreen:#004422;
  --amber:#ffb000;--blue:#00aaff;--dblue:#003366;
  --panel:#050d1a;--hud:#020c18;--border:rgba(0,160,255,0.35);
  --text:#b8d4f0;--mono:'Share Tech Mono',monospace;
  --main:'Orbitron',monospace;--body:'Rajdhani',sans-serif;
  --display:var(--main);--muted:rgba(155,192,228,0.74);
  --line:rgba(112,182,255,0.18);--shadow:0 18px 38px rgba(0,0,0,0.42);
  --ocean:radial-gradient(circle at 50% 45%,rgba(16,55,90,0.28),rgba(0,0,0,0));
}
html,body{width:100%;height:100%;overflow:hidden;background:#000;color:var(--text);}
#app{width:100%;height:100%;position:relative;font-family:var(--main);}

/* ---- SCREENS ---- */
.screen{position:absolute;inset:0;display:none;}
.screen.active{display:flex;flex-direction:column;}

/* ---- MAIN MENU ---- */
#mainMenu{
  align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 50% 40%,#0a0515 0%,#000 100%);
  overflow:hidden;
}
.menu-bg-anim{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 50%,rgba(139,0,0,0.18) 0%,transparent 55%),
    radial-gradient(circle at 80% 50%,rgba(0,50,120,0.18) 0%,transparent 55%),
    radial-gradient(circle at 50% 80%,rgba(80,0,0,0.12) 0%,transparent 40%);
  animation:bgPulse 5s ease-in-out infinite alternate;
  pointer-events:none;
}
@keyframes bgPulse{0%{opacity:.6;}100%{opacity:1;}}
.menu-scanlines{
  position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0.15) 0px,rgba(0,0,0,0.15) 1px,transparent 1px,transparent 3px);
}
.menu-content{position:relative;z-index:5;display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px;}

.title-emblem{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center;}
.emblem-ring{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid rgba(255,30,30,0.6);
  animation:spinRing 8s linear infinite;
  box-shadow:0 0 15px rgba(255,0,0,0.4),inset 0 0 15px rgba(255,0,0,0.2);
}
.emblem-ring.r2{
  inset:10px;border-color:rgba(255,150,0,0.5);
  animation:spinRing 5s linear infinite reverse;
}
@keyframes spinRing{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
.emblem-inner{font-size:3rem;color:#ff3333;text-shadow:0 0 20px #ff0000,0 0 40px #ff0000;z-index:2;}

.title-glow{
  font-size:clamp(1.5rem,4vw,3rem);font-weight:900;letter-spacing:8px;color:#fff;
  text-shadow:0 0 15px #ff2020,0 0 35px #ff2020,0 0 70px #ff4040,0 0 110px #ff0000;
  animation:titleFlick 4s infinite;
}
@keyframes titleFlick{0%,95%,100%{opacity:1;}97%{opacity:.7;}}
.subtitle-line{font-size:0.85rem;color:var(--amber);letter-spacing:6px;text-shadow:0 0 10px var(--amber);}
.classified-stamp{
  font-family:var(--mono);font-size:.65rem;color:#ff4444;letter-spacing:3px;
  border:1px solid rgba(255,50,50,0.4);padding:4px 12px;
  background:rgba(80,0,0,0.2);
}

.menu-buttons{display:flex;flex-direction:column;gap:10px;width:300px;align-items:center;}
.menu-btn{
  position:relative;padding:12px 24px;width:100%;
  background:linear-gradient(135deg,rgba(0,25,55,0.92),rgba(0,10,28,0.92));
  border:1px solid var(--border);color:var(--text);
  font-family:var(--main);font-size:.75rem;letter-spacing:2px;
  cursor:pointer;transition:all .2s;text-transform:uppercase;
  clip-path:polygon(10px 0%,100% 0%,calc(100% - 10px) 100%,0% 100%);
  display:flex;align-items:center;gap:8px;justify-content:center;
}
.menu-btn:hover{
  background:linear-gradient(135deg,rgba(0,70,150,0.9),rgba(0,35,80,0.9));
  border-color:#00aaff;color:#fff;box-shadow:0 0 22px rgba(0,160,255,0.45);
  transform:translateX(5px);
}
.menu-btn:disabled{
  opacity:.45;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}
.menu-btn.primary{background:linear-gradient(135deg,rgba(120,0,0,0.85),rgba(70,0,0,0.85));border-color:rgba(255,50,50,0.65);color:#fff;}
.menu-btn.primary:hover{background:linear-gradient(135deg,rgba(200,0,0,0.9),rgba(110,0,0,0.9));box-shadow:0 0 28px rgba(255,0,0,0.55);}
.menu-btn.danger{border-color:rgba(255,60,60,0.4);color:#ff8888;}
.menu-btn.danger:hover{background:rgba(100,0,0,0.5);}
.btn-icon{font-size:0.9rem;}

.menu-footer{
  font-family:var(--mono);font-size:.6rem;color:rgba(100,150,200,0.55);
  letter-spacing:2px;display:flex;gap:10px;align-items:center;
}
.howto-block{
  width:320px;background:rgba(0,12,28,0.78);
  border:1px solid rgba(0,160,255,0.3);padding:12px;margin-top:8px;
  border-radius:6px;box-shadow:0 0 15px rgba(0,80,160,0.25);
}
.howto-title{
  font-size:.75rem;letter-spacing:3px;color:var(--amber);
  margin-bottom:6px;text-align:center;text-transform:uppercase;
}
.howto-list{list-style:none;display:flex;flex-direction:column;gap:4px;font-family:var(--mono);font-size:.55rem;line-height:1.3;color:rgba(175,210,250,.9);}
.howto-list li{position:relative;padding-left:16px;}
.howto-list li::before{content:'▸';position:absolute;left:0;color:var(--green);}
.blink-dot{animation:blink .8s infinite;color:var(--green);}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}

/* ---- GAME SCREEN ---- */
#gameScreen{flex-direction:column;}

/* ---- TOP HUD ---- */
#topHUD{
  height:70px;background:var(--hud);border-bottom:2px solid var(--border);
  display:flex;align-items:stretch;flex-shrink:0;z-index:100;
  box-shadow:0 2px 20px rgba(0,80,200,0.3);
  overflow:visible;
}
.hud-seg{display:flex;align-items:center;gap:12px;padding:0 14px;}
.hud-left,.hud-right{flex-shrink:0;}
.hud-center{flex:1;flex-direction:column;justify-content:center;align-items:center;gap:1px;border-left:1px solid var(--border);border-right:1px solid var(--border);min-width:0;padding-top:4px;padding-bottom:4px;}
.hud-main-title{font-size:.76rem;line-height:1;color:#fff;letter-spacing:3px;text-shadow:0 0 8px rgba(0,150,255,.6);}
.hud-sub-title{font-size:.44rem;line-height:1.1;color:var(--amber);letter-spacing:4px;text-align:center;white-space:nowrap;}
.hud-phase{font-size:.5rem;line-height:1;color:var(--green);letter-spacing:3px;text-transform:uppercase;}
.hud-item{display:flex;flex-direction:column;align-items:center;padding:0 8px;border-right:1px solid rgba(0,120,200,0.2);}
.hud-lbl{font-size:.45rem;color:rgba(100,160,220,.7);letter-spacing:2px;font-family:var(--mono);}
.hud-val{font-size:.82rem;font-weight:700;color:var(--amber);letter-spacing:1px;}
.hud-val.red{color:var(--red);text-shadow:0 0 7px var(--red);}
.hud-val.green{color:var(--green);}
.hud-val.amber{color:var(--amber);}
.hud-val.blink{animation:blink 1.2s infinite;}
.hud-btn{
  padding:5px 10px;background:rgba(0,50,110,0.6);border:1px solid var(--border);
  color:var(--text);font-family:var(--main);font-size:.48rem;letter-spacing:2px;
  cursor:pointer;transition:all .2s;white-space:nowrap;
}
.hud-btn:hover{background:rgba(0,110,220,.45);border-color:var(--blue);color:#fff;}
.hud-btn.warn{border-color:rgba(255,176,0,.4);color:var(--amber);}
#yearTimerOuter{width:180px;height:4px;background:rgba(0,40,80,.5);border:1px solid var(--border);border-radius:2px;overflow:hidden;}

#yearTimerBar,
#yearProgress{height:100%;background:linear-gradient(90deg,var(--blue),var(--green));width:0%;transition:width 1s linear;box-shadow:0 0 5px var(--blue);}

/* ---- POPUP WINDOWS ---- */
.popup-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(4px);
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
}

.popup-overlay.active {
  display: flex;
}

.popup-window {
  background: linear-gradient(180deg, rgba(12, 22, 38, 0.98), rgba(5, 11, 20, 1));
  border: 2px solid rgba(117, 171, 255, 0.3);
  border-radius: 20px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
  max-width: 900px;
  max-height: 90vh;
  width: 95%;
  overflow: hidden;
  position: relative;
  margin: auto;
}

.popup-header {
  background: linear-gradient(180deg, rgba(117, 171, 255, 0.2), rgba(117, 171, 255, 0.1));
  padding: 20px;
  border-bottom: 1px solid rgba(117, 171, 255, 0.3);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.popup-title {
  color: #f4f8ff;
  font: 800 1.2rem var(--display);
  text-transform: uppercase;
  margin: 0;
}

.popup-close {
  background: rgba(255, 30, 30, 0.3);
  border: 1px solid rgba(255, 30, 30, 0.5);
  color: #ff4444;
  border-radius: 8px;
  padding: 8px 16px;
  cursor: pointer;
  font: 600 0.8rem var(--mono);
  text-transform: uppercase;
  transition: all 0.3s ease;
}

.popup-close:hover {
  background: rgba(255, 30, 30, 0.5);
  transform: translateY(-1px);
}

.popup-content {
  padding: 20px;
  overflow-y: auto;
  overflow-x: hidden;
  max-height: calc(90vh - 120px);
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
}

.popup-content::-webkit-scrollbar {
  width: 8px;
}
.popup-content::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border-radius: 4px;
}
.popup-content::-webkit-scrollbar-thumb {
  background: #2a4a6a;
  border-radius: 4px;
}
.popup-content::-webkit-scrollbar-thumb:hover {
  background: #3a5a7a;
}

/* ---- DEMAND TRIBUTE BUTTON ---- */
.demand-tribute-btn {
  background: linear-gradient(135deg, #ff6b35, #f7931e);
  border: 2px solid rgba(255, 107, 53, 0.5);
  color: white;
  border-radius: 12px;
  padding: 12px 20px;
  cursor: pointer;
  font: 700 0.9rem var(--mono);
  text-transform: uppercase;
  transition: all 0.3s ease;
  margin: 10px 0;
  box-shadow: 0 4px 15px rgba(255, 107, 53, 0.3);
}

.demand-tribute-btn:hover {
  background: linear-gradient(135deg, #ff8c5a, #ffa500);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(255, 107, 53, 0.5);
}

.demand-tribute-btn.active {
  background: linear-gradient(135deg, #4caf50, #8bc34a);
  border-color: rgba(76, 175, 80, 0.5);
  box-shadow: 0 4px 15px rgba(76, 175, 80, 0.3);
}

.demand-tribute-btn.active:hover {
  background: linear-gradient(135deg, #66bb6a, #9ccc65);
  box-shadow: 0 6px 20px rgba(76, 175, 80, 0.5);
}

/* ---- DIPLOMACY PANEL COUNTRIES GRID ---- */
.diplomacy-content {
  padding: 10px;
}

.countries-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 8px;
  max-height: 400px;
  overflow-y: auto;
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
}

.countries-grid::-webkit-scrollbar {
  width: 6px;
}
.countries-grid::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border-radius: 3px;
}
.countries-grid::-webkit-scrollbar-thumb {
  background: #2a4a6a;
  border-radius: 3px;
}
.countries-grid::-webkit-scrollbar-thumb:hover {
  background: #3a5a7a;
}

.country-card {
  background: rgba(117, 171, 255, 0.1);
  border: 2px solid rgba(117, 171, 255, 0.3);
  border-radius: 8px;
  padding: 10px;
  cursor: pointer;
  transition: all 0.3s ease;
  font-size: 0.75rem;
}

.country-card:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 6px 20px rgba(255, 255, 255, 0.4);
  filter: brightness(1.2);
}

.country-card.hostile {
  border: 2px solid #ff0000 !important;
  background: rgba(255, 82, 82, 0.1);
  box-shadow: 0 0 10px rgba(255, 0, 0, 0.3);
}

.country-card.neutral {
  border: 2px solid #0066ff !important;
  background: rgba(0, 102, 255, 0.1);
  box-shadow: 0 0 10px rgba(0, 102, 255, 0.3);
}

.country-card.allied {
  border: 2px solid #00ff00 !important;
  background: rgba(0, 255, 0, 0.1);
  box-shadow: 0 0 10px rgba(0, 255, 0, 0.3);
}

.country-card.selected {
  border: 3px solid #ff8800 !important;
  box-shadow: 0 0 25px rgba(255, 136, 0, 0.9) !important;
  background: rgba(255, 136, 0, 0.15) !important;
  transform: scale(1.05);
  animation: selectedPulse 2s infinite;
}

@keyframes selectedPulse {
  0% {
    box-shadow: 0 0 25px rgba(255, 136, 0, 0.9);
    border-color: #ff8800;
  }
  50% {
    box-shadow: 0 0 35px rgba(255, 136, 0, 1);
    border-color: #ffaa00;
  }
  100% {
    box-shadow: 0 0 25px rgba(255, 136, 0, 0.9);
    border-color: #ff8800;
  }
}

.country-name {
  font-weight: bold;
  color: #f4f8ff;
  margin-bottom: 4px;
}

.country-info {
  font-size: 0.7rem;
  color: #b0c4de;
  line-height: 1.3;
}

.diplomatic-result {
  display: none;
  margin-top: 15px;
  padding: 10px;
  background: rgba(117, 171, 255, 0.1);
  border-radius: 8px;
  max-height: 200px;
  overflow-y: auto;
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
}

.diplomatic-result::-webkit-scrollbar {
  width: 6px;
}
.diplomatic-result::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border-radius: 3px;
}
.diplomatic-result::-webkit-scrollbar-thumb {
  background: #2a4a6a;
  border-radius: 3px;
}
.diplomatic-result::-webkit-scrollbar-thumb:hover {
  background: #3a5a7a;
}

#resultMessage {
  font-size: 0.8rem;
  line-height: 1.3;
}
.diplomatic-action-btn {
  background: linear-gradient(135deg, rgba(117, 171, 255, 0.2), rgba(117, 171, 255, 0.1));
  border: 2px solid rgba(117, 171, 255, 0.3);
  color: #f4f8ff;
  border-radius: 12px;
  padding: 15px;
  cursor: pointer;
  font: 600 0.8rem var(--mono);
  text-transform: uppercase;
  transition: all 0.3s ease;
  text-align: center;
  min-height: 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.diplomatic-action-btn:hover {
  background: linear-gradient(135deg, rgba(117, 171, 255, 0.3), rgba(117, 171, 255, 0.2));
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(117, 171, 255, 0.3);
  border-color: rgba(117, 171, 255, 0.5);
}

.diplomatic-action-btn.demand-tribute {
  background: linear-gradient(135deg, rgba(255, 107, 53, 0.2), rgba(255, 107, 53, 0.1));
  border-color: rgba(255, 107, 53, 0.3);
}

.diplomatic-action-btn.demand-tribute:hover {
  background: linear-gradient(135deg, rgba(255, 107, 53, 0.3), rgba(255, 107, 53, 0.2));
  box-shadow: 0 6px 20px rgba(255, 107, 53, 0.3);
  border-color: rgba(255, 107, 53, 0.5);
}

.diplomatic-action-btn.ask-alliance {
  background: linear-gradient(135deg, rgba(76, 175, 80, 0.2), rgba(76, 175, 80, 0.1));
  border-color: rgba(76, 175, 80, 0.3);
}

.diplomatic-action-btn.ask-alliance:hover {
  background: linear-gradient(135deg, rgba(76, 175, 80, 0.3), rgba(76, 175, 80, 0.2));
  box-shadow: 0 6px 20px rgba(76, 175, 80, 0.3);
  border-color: rgba(76, 175, 80, 0.5);
}

.diplomatic-action-btn.sue-peace {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.2), rgba(255, 193, 7, 0.1));
  border-color: rgba(255, 193, 7, 0.3);
}

.diplomatic-action-btn.sue-peace:hover {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.3), rgba(255, 193, 7, 0.2));
  box-shadow: 0 6px 20px rgba(255, 193, 7, 0.3);
  border-color: rgba(255, 193, 7, 0.5);
}

/* ---- COUNTRY HOTSPOTS IN DIPLOMACY ---- */
.diplomacy-country-hotspot {
  position: absolute;
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.3s ease;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  font: 600 0.7rem var(--mono);
  text-transform: uppercase;
  color: white;
  border: 2px solid rgba(255, 255, 255, 0.3);
}

.diplomacy-country-hotspot.allied {
  background: rgba(76, 175, 80, 0.7);
  border-color: rgba(76, 175, 80, 0.8);
}

.diplomacy-country-hotspot.hostile {
  background: rgba(255, 82, 82, 0.7);
  border-color: rgba(255, 82, 82, 0.8);
}

.diplomacy-country-hotspot.neutral {
  background: rgba(255, 167, 38, 0.7);
  border-color: rgba(255, 167, 38, 0.8);
}

.diplomacy-country-hotspot:hover {
  transform: scale(1.2);
  box-shadow: 0 0 20px rgba(255, 255, 255, 0.5);
  z-index: 10;
}

.diplomacy-country-hotspot.selected {
  animation: selectedPulse 2s infinite;
  border-color: #ffd700;
  box-shadow: 0 0 25px rgba(255, 215, 0, 0.7);
}

@keyframes selectedPulse {
  0% { box-shadow: 0 0 0 0 rgba(255, 215, 0, 0.7); }
  70% { box-shadow: 0 0 0 15px rgba(255, 215, 0, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 215, 0, 0); }
}
.country-demandable {
  animation: demandPulse 2s infinite;
  cursor: pointer;
}

@keyframes demandPulse {
  0% { box-shadow: 0 0 0 0 rgba(255, 107, 53, 0.7); }
  70% { box-shadow: 0 0 0 10px rgba(255, 107, 53, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 107, 53, 0); }
}
#mapContainer{
  flex:1;
  position:relative;
  overflow:auto; /* Changed from hidden to auto for scrollbars */
  isolation:isolate;
  background:radial-gradient(ellipse at 50% 45%,#0a1520 0%,#030810 100%);
  /* Ensure scrolling works smoothly */
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
  /* Stretched map: 4 paces right, 2 paces left */
  width: 1400px; /* Increased from 1200px (200px more total) */
  height: 650px; /* Same height */
  min-width: 1400px;
  min-height: 650px;
  max-width: 1400px;
  max-height: 650px;
  margin: 0 40px 0 auto; /* More right offset for 4 paces right, 2 paces left */
}

/* Use old world.jpg map with standard sizing */
#worldMapImage {
  width: 100% !important; /* Standard size for old map */
  height: 100% !important; /* Standard size for old map */
  object-fit: cover;
  position: absolute;
  inset: 0;
  left: 0 !important; /* No offset for old map */
  top: 0 !important; /* No offset for old map */
  z-index: 1 !important;
}

/* Custom scrollbar styling */
#mapContainer::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}
#mapContainer::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border: 1px solid rgba(42, 74, 106, 0.3);
}
#mapContainer::-webkit-scrollbar-thumb {
  background: linear-gradient(135deg, #2a4a6a, #1a3a5a);
  border: 1px solid rgba(42, 74, 106, 0.5);
  border-radius: 6px;
}
#mapContainer::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(135deg, #3a5a7a, #2a4a6a);
}
#mapContainer::-webkit-scrollbar-corner {
  background: rgba(10, 21, 32, 0.8);
}
#mapWinterField{
  position:absolute;inset:0;pointer-events:none;z-index:88;
  opacity:0;transition:opacity 1.6s ease,filter 1.6s ease;
  background:
    radial-gradient(circle at 50% 18%, rgba(225,236,248,0.12), transparent 38%),
    linear-gradient(180deg, rgba(18,32,52,0.08) 0%, rgba(76,76,82,0.22) 58%, rgba(132,140,148,0.34) 100%);
  mix-blend-mode:normal;
  filter:contrast(1.08) saturate(.82);
}
#worldMapDiv{position:absolute;inset:0;z-index:30 !important;pointer-events:auto;}
#worldMapDiv svg{width:100%;height:100%;}
#fxCanvas{
  position:absolute;inset:0;width:100%;height:100%;pointer-events:none;
  z-index:999 !important;
  mix-blend-mode:none !important;
  isolation:isolate;
  contain:paint strict;
  image-rendering:-webkit-optimize-contrast;
  image-rendering:crisp-edges;
  will-change:transform;
  /* Ensure canvas scrolls with map content */
  position: sticky;
  top: 0;
  left: 0;
}
#mapImpactLayer{
  position:absolute;inset:0;pointer-events:none;z-index:110 !important;overflow:hidden;
}
#missileLayer{position:absolute;inset:0;pointer-events:none;z-index:100 !important;}

.country-path{cursor:pointer;transition:filter .2s;}
.country-path:hover{filter:brightness(1.8) saturate(1.6);}
.country-path.selected{fill:#ff3300!important;filter:brightness(1.4) drop-shadow(0 0 8px #ff4400);}
.country-path.destroyed{fill:#0d0500!important;filter:brightness(.35) saturate(.1);}
.country-path.nuked{animation:nukeFlash 0.5s ease-out;}
@keyframes nukeFlash{0%{fill:#ffffff;}50%{fill:#ff8800;}100%{}}

/* Damage Report Popup */
.damage-report-popup{
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:rgba(0,0,0,0.8);z-index:1000;
  display:none;align-items:center;justify-content:center;
  backdrop-filter:blur(4px);
}
.damage-report-popup.active{display:flex;}
.damage-report-content{
  background:var(--hud);border:2px solid var(--border);border-radius:12px;
  max-width:600px;width:90%;max-height:80vh;overflow-y:auto;
  box-shadow:0 0 30px rgba(255,176,0,0.3);
}
.damage-report-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 20px;border-bottom:1px solid var(--border);
  background:rgba(0,15,35,0.6);
}
.damage-report-header h3{
  color:var(--amber);font-size:1.1rem;margin:0;
  font-family:var(--mono);letter-spacing:2px;
}
.close-btn{
  background:none;border:none;color:var(--red);font-size:1.5rem;
  cursor:pointer;padding:0;width:30px;height:30px;
  display:flex;align-items:center;justify-content:center;
  border-radius:4px;transition:all 0.2s;
}
.close-btn:hover{background:rgba(255,0,0,0.2);}
.damage-report-body{
  display:flex;flex-direction:column;gap:20px;padding:20px;
}
.damage-visual{
  height:200px;background:rgba(0,15,35,0.8);
  border-radius:8px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.damage-details{
  display:flex;flex-direction:column;gap:16px;
}
.damage-stats h4,
.damage-intel h4{
  color:var(--amber);font-size:0.9rem;margin:0 0 8px 0;
  font-family:var(--mono);letter-spacing:1px;
}
.stat-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:4px 0;border-bottom:1px solid rgba(255,255,255,0.1);
}
.stat-row span{
  color:rgba(140,190,240,0.8);font-size:0.85rem;
}
.stat-row strong{
  color:var(--green);font-size:0.9rem;font-family:var(--mono);
}
.damage-intel{
  background:rgba(0,15,35,0.6);padding:12px;border-radius:6px;
  border:1px solid rgba(255,176,0,0.2);
}
.damage-intel p{
  color:rgba(140,190,240,0.9);font-size:0.85rem;line-height:1.4;
  margin:0;
}

/* Tooltip */
#mapTooltip{
  position:absolute;background:rgba(2,8,18,.97);border:1px solid var(--border);
  padding:10px 14px;font-family:var(--mono);font-size:.62rem;color:var(--text);
  z-index:200;min-width:170px;pointer-events:none;
  box-shadow:0 4px 20px rgba(0,0,0,.7);transition:opacity .15s;
}
#mapTooltip.hidden{opacity:0;pointer-events:none;}
.tt-name{color:var(--amber);font-size:.72rem;font-weight:bold;margin-bottom:5px;border-bottom:1px solid var(--border);padding-bottom:4px;}
.tt-row{display:flex;justify-content:space-between;gap:20px;margin-top:2px;}
.tt-lbl{color:rgba(140,180,220,.7);}
.tt-val{color:var(--green);}
.tt-val.red{color:var(--red);}
.tt-val.amber{color:var(--amber);}

/* Crosshair */
#targetCrosshair{
  position:absolute;width:40px;height:40px;transform:translate(-50%,-50%);
  pointer-events:none;z-index:140 !important;
}
#targetCrosshair.hidden{display:none;}
#targetCrosshair::before,#targetCrosshair::after{
  content:'';position:absolute;background:var(--red);
}
#targetCrosshair::before{width:2px;height:100%;left:50%;transform:translateX(-50%);}
#targetCrosshair::after{height:2px;width:100%;top:50%;transform:translateY(-50%);}

/* DEFCON Bar */
#defconBar{
  position:absolute;left:0;top:0;bottom:0;width:28px;
  background:rgba(0,8,18,.8);border-right:1px solid var(--border);
  display:flex;flex-direction:column;align-items:center;z-index:90;padding:4px 0;
  gap:2px;
}
.db-label{font-size:.38rem;color:rgba(0,150,255,.6);letter-spacing:1px;writing-mode:vertical-rl;transform:rotate(180deg);margin-bottom:4px;}
.db-seg{
  flex:1;width:20px;border-radius:2px;display:flex;align-items:center;justify-content:center;
  font-size:.48rem;font-weight:bold;cursor:default;transition:all .5s;
  background:rgba(0,20,40,.5);border:1px solid rgba(0,80,160,.3);color:rgba(100,140,180,.5);
}
.db-seg.active-5{background:#004400;border-color:#00aa00;color:#00ff88;box-shadow:0 0 8px #00aa00;}
.db-seg.active-4{background:#334400;border-color:#aaaa00;color:#ffff00;box-shadow:0 0 8px #aaaa00;}
.db-seg.active-3{background:#443300;border-color:#ff8800;color:#ffaa00;box-shadow:0 0 8px #ff8800;}
.db-seg.active-2{background:#440000;border-color:#ff3300;color:#ff6600;box-shadow:0 0 8px #ff3300;}
.db-seg.active-1{background:#550000;border-color:#ff0000;color:#ff2200;box-shadow:0 0 12px #ff0000;animation:defPulse .6s infinite alternate;}
@keyframes defPulse{from{box-shadow:0 0 8px #ff0000;}to{box-shadow:0 0 20px #ff0000,0 0 40px #ff4400;}}

/* ---- CONTROL PANEL ---- */
#controlPanel{
  height:248px;background:var(--hud);border-top:2px solid var(--border);
  display:flex;flex-shrink:0;z-index:100;
  overflow-x:auto;
}
.ctrl-section{padding:8px 12px;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:6px;}
.ctrl-section:last-child{border-right:none;}
.launch-ctrl{width:400px;flex-shrink:0;}
.intel-ctrl{flex:1;}
.hand-ctrl{width:155px;flex-shrink:0;align-items:center;justify-content:center;}
.ctrl-header{
  font-size:.58rem;color:var(--amber);letter-spacing:3px;
  border-bottom:1px solid rgba(255,176,0,.3);padding-bottom:4px;flex-shrink:0;
}
.ctrl-body{display:flex;flex-direction:column;gap:5px;flex:1;}
.ctrl-row{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.62rem;}
.ctrl-lbl{width:72px;flex-shrink:0;color:rgba(140,190,240,.7);}
.ctrl-row select,.ctrl-row input[type=range]{
  flex:1;background:rgba(0,15,35,.85);border:1px solid var(--border);
  color:var(--amber);font-family:var(--mono);font-size:.62rem;padding:3px 5px;outline:none;
}
.ctrl-row select option{background:#020c18;}
.ctrl-count{width:22px;text-align:center;color:var(--green);font-size:.72rem;font-weight:bold;}
.target-readout{
  flex:1;color:var(--red);font-size:.62rem;font-family:var(--mono);
  animation:targetAnim 1.2s infinite;
}
.target-readout.locked{color:var(--green);animation:none;}
@keyframes targetAnim{0%,100%{opacity:1;}50%{opacity:.4;}}

/* Launch Area */
.launch-area{display:flex;align-items:center;gap:10px;margin-top:2px;}
.safety-cover{
  width:58px;height:55px;
  background:linear-gradient(135deg,#1a0000,#440000);
  border:2px solid #880000;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .3s;flex-shrink:0;
  box-shadow:0 0 12px rgba(255,0,0,.35),inset 0 0 12px rgba(0,0,0,.5);
}
.safety-cover:hover{background:linear-gradient(135deg,#440000,#880000);box-shadow:0 0 22px rgba(255,0,0,.55);}
.safety-cover.lifted{transform:rotateX(-55deg) translateY(-8px);opacity:.35;}
.safety-text{font-size:.42rem;color:#ff8888;letter-spacing:1px;text-align:center;line-height:1.5;font-family:var(--mono);}

.launch-button{
  flex:1;height:58px;position:relative;overflow:hidden;
  background:radial-gradient(circle at 38% 32%,#ff7070 0%,#dd0000 28%,#990000 58%,#660000 100%);
  border:3px solid #ff3333;border-radius:55px;color:#fff;
  cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--main);transition:all .15s;
  box-shadow:0 0 22px rgba(255,0,0,.65),0 5px 10px rgba(0,0,0,.8),
    inset 0 2px 5px rgba(255,160,160,.35),inset 0 -3px 5px rgba(0,0,0,.5);
}
.launch-button::before{
  content:'';position:absolute;top:8%;left:14%;width:32%;height:38%;
  background:radial-gradient(ellipse,rgba(255,210,210,.45),transparent);border-radius:50%;
}
.launch-button:disabled{
  background:radial-gradient(circle,#444,#2a2a2a,#1a1a1a);
  border-color:#333;box-shadow:none;cursor:not-allowed;opacity:.6;
}
.launch-button:not(:disabled):hover{
  transform:scale(1.06);
  box-shadow:0 0 45px rgba(255,0,0,.95),0 5px 15px rgba(0,0,0,.8),inset 0 2px 5px rgba(255,160,160,.5);
}
.launch-button:not(:disabled):active{
  transform:scale(.96);
  box-shadow:0 0 65px rgba(255,120,0,1),0 2px 5px rgba(0,0,0,.8);
}
.launch-btn-ring{
  position:absolute;inset:4px;border-radius:50px;
  border:1px solid rgba(255,120,120,.35);pointer-events:none;
}
.launch-btn-inner{display:flex;flex-direction:column;align-items:center;z-index:2;}
.launch-word{font-size:.95rem;font-weight:900;letter-spacing:4px;}
.launch-sub{font-size:.42rem;letter-spacing:2px;opacity:.85;}

.launch-key{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;}
.key-label{font-size:.42rem;color:rgba(140,180,220,.7);letter-spacing:2px;font-family:var(--mono);}
.key-slot{
  width:42px;height:55px;background:rgba(0,15,35,.8);border:1px solid var(--border);
  border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:all .2s;box-shadow:inset 0 0 8px rgba(0,0,0,.6);
}
.key-slot:hover{border-color:var(--amber);}
.key-body{font-size:.45rem;color:rgba(140,180,220,.6);text-align:center;font-family:var(--mono);}
.key-body.inserted{color:var(--green);text-shadow:0 0 6px var(--green);}

/* Execute Command Section */
.exec-ctrl{width:380px;flex-shrink:0;}
.command-readout{
  display:flex;flex-direction:column;gap:4px;margin-bottom:8px;
  font-family:var(--mono);font-size:.62rem;color:rgba(140,190,240,.7);
}
.command-readout strong{
  color:var(--amber);font-size:.68rem;}
.command-exec{
  width:100%;margin-bottom:8px;justify-content:center;}
.session-buttons{
  display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:8px;}
.session-stats{
  font-family:var(--mono);font-size:.55rem;color:rgba(100,150,200,.6);
  line-height:1.4;
}
.session-stats strong{color:var(--green);}

.impact-panel{
  margin-top:10px;padding:10px 12px;border-radius:14px;
  background:rgba(6,14,26,0.86);border:1px solid rgba(114,183,255,0.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);
}
.impact-title{
  margin-bottom:8px;color:var(--amber);font:700 .62rem var(--mono);
  letter-spacing:1.8px;text-transform:uppercase;
}
.impact-timeline{
  max-height:108px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;
  scrollbar-width:thin;scrollbar-color:rgba(114,183,255,0.35) transparent;
}
.impact-row{
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;
  align-items:center;padding:8px 10px;border-radius:10px;
  background:rgba(255,255,255,0.03);border:1px solid rgba(114,183,255,0.12);
}
.impact-row.player{border-color:rgba(114,183,255,0.3);background:rgba(12,40,78,0.26);}
.impact-row.hostile{border-color:rgba(255,107,107,0.24);background:rgba(90,18,18,0.18);}
.impact-row.ally{border-color:rgba(106,255,175,0.18);}
.impact-row strong{
  display:block;color:#f7fbff;font:700 .62rem var(--main);letter-spacing:1px;text-transform:uppercase;
}
.impact-row span{
  display:block;margin-top:3px;color:var(--muted);font:700 .54rem/1.4 var(--mono);
}
.impact-row em{
  color:var(--amber);font:700 .72rem var(--mono);font-style:normal;text-shadow:0 0 8px rgba(255,176,0,0.3);
}
.impact-empty{
  color:var(--muted);font:700 .58rem/1.5 var(--mono);
}

/* Military Operations */
.military-ops{
  display:flex;flex-wrap:wrap;gap:8px;margin:8px 0;
  justify-content:center;
}
.op-card{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:6px;border:1px solid var(--border);
  border-radius:6px;background:rgba(0,15,35,.6);
  cursor:pointer;transition:all .2s;min-width:60px;
}
.op-card:hover{
  background:rgba(0,35,70,.8);border-color:var(--amber);
  transform:scale(1.05);
}
.op-card.active{
  background:rgba(255,176,0,.2);border-color:var(--amber);
  box-shadow:0 0 8px rgba(255,176,0,.4);
}
.op-icon{
  width:32px;height:32px;object-fit:cover;border-radius:4px;
  border:1px solid rgba(255,255,255,.2);
}
.op-label{
  font-family:var(--mono);font-size:.45rem;color:rgba(140,190,240,.8);
  text-align:center;line-height:1.1;
}

/* Battle Ribbon */
#battleRibbon{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(0,8,18,.92);border-top:1px solid var(--border);
  display:flex;justify-content:space-around;align-items:center;
  padding:8px 16px;z-index:40;
}
.ribbon-item{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  font-family:var(--mono);font-size:.55rem;
}
.ribbon-item span{
  color:rgba(140,190,240,.7);letter-spacing:1px;text-transform:uppercase;
}
.ribbon-item strong{
  color:var(--amber);font-size:.65rem;font-weight:bold;}

/* Country Hotspots */
.hotspot{
  transition:all .2s ease;box-shadow:0 0 8px rgba(0,160,255,0.3);
}
.hotspot:hover{
  transform:translate(-50%, -50%) scale(1.2);
  box-shadow:0 0 16px rgba(0,160,255,0.6);border-color:var(--blue)!important;
}
.hotspot.allied{border-color:var(--green);background:rgba(0,255,136,0.2);}
.hotspot.hostile{border-color:var(--red);background:rgba(255,26,26,0.2);}
.hotspot.neutral{border-color:rgba(255,255,255,0.5);background:rgba(255,255,255,0.1);}
.hotspot.destroyed{opacity:0.3;filter:grayscale(1);}

.impact-sprite{
  position:absolute;transform:translate(-50%,-50%);
  pointer-events:none;opacity:0;will-change:transform,opacity,filter;
  animation:impactFade var(--impact-life,1.8s) ease-out forwards;
}
.impact-report{
  position:absolute;transform:translate(-50%,-50%);pointer-events:none;
  min-width:146px;max-width:220px;padding:8px 10px;border-radius:12px;
  background:rgba(7,14,26,0.88);border:1px solid rgba(118,182,255,0.24);
  box-shadow:0 12px 24px rgba(0,0,0,0.34);
  color:#f3f8ff;font:700 .58rem/1.35 var(--mono);
  animation:impactReportFloat 2.45s ease-out forwards;
}
.impact-report strong{
  display:block;color:#fff;font:800 .62rem var(--main);letter-spacing:1px;text-transform:uppercase;
}
.impact-report span{
  display:block;margin-top:4px;color:rgba(235,243,255,0.86);
}
.impact-report.bad{border-color:rgba(255,116,116,0.34);background:rgba(60,10,10,0.88);}
.impact-report.good{border-color:rgba(108,255,174,0.24);background:rgba(8,28,18,0.88);}
.impact-report.amber{border-color:rgba(255,186,84,0.3);background:rgba(34,18,8,0.9);}
.impact-sprite svg{width:100%;height:100%;display:block;filter:drop-shadow(0 0 18px rgba(255,150,90,.35));}
.impact-sprite .ring-one{animation:shockwaveA 1.6s ease-out forwards;transform-origin:center;}
.impact-sprite .ring-two{animation:shockwaveB 1.9s ease-out forwards;transform-origin:center;}
.impact-sprite .ring-three{animation:shockwaveC 2.2s ease-out forwards;transform-origin:center;}
.impact-sprite .blast-core{animation:coreBloom 1.25s ease-out forwards;transform-origin:center;}
.impact-sprite .blast-cloud{animation:cloudRise 1.95s ease-out forwards;transform-origin:center;}
.impact-sprite .blast-stem{animation:stemRise 1.9s ease-out forwards;transform-origin:center;}
.impact-sprite .cyber-grid{animation:cyberPulse 1.35s ease-out forwards;transform-origin:center;}
.impact-sprite .target-reticle{animation:reticleLock 1.15s ease-out forwards;transform-origin:center;}

.impact-nuclear{width:calc(260px * var(--impact-scale,1));height:calc(260px * var(--impact-scale,1));}
.impact-air{width:calc(180px * var(--impact-scale,1));height:calc(180px * var(--impact-scale,1));}
.impact-ground,.impact-tank,.impact-naval{width:calc(160px * var(--impact-scale,1));height:calc(160px * var(--impact-scale,1));}
.impact-drone,.impact-cyber,.impact-commando{width:calc(150px * var(--impact-scale,1));height:calc(150px * var(--impact-scale,1));}

@keyframes impactFade{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.55);}
  10%{opacity:1;}
  72%{opacity:1;}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.14);}
}
@keyframes impactReportFloat{
  0%{opacity:0;transform:translate(-50%,-36%) scale(.92);}
  10%,70%{opacity:1;}
  100%{opacity:0;transform:translate(-50%,-88%) scale(1.05);}
}
@keyframes shockwaveA{
  0%{opacity:.88;transform:scale(.18);}
  100%{opacity:0;transform:scale(1.18);}
}
@keyframes shockwaveB{
  0%,18%{opacity:0;transform:scale(.22);}
  26%{opacity:.68;}
  100%{opacity:0;transform:scale(1.42);}
}
@keyframes shockwaveC{
  0%,32%{opacity:0;transform:scale(.24);}
  42%{opacity:.48;}
  100%{opacity:0;transform:scale(1.7);}
}
@keyframes coreBloom{
  0%{opacity:.2;transform:scale(.4);}
  18%{opacity:1;transform:scale(1);}
  100%{opacity:0;transform:scale(1.4);}
}
@keyframes cloudRise{
  0%{opacity:.22;transform:translateY(10px) scale(.62);}
  24%{opacity:1;}
  100%{opacity:0;transform:translateY(-30px) scale(1.24);}
}
@keyframes stemRise{
  0%{opacity:0;transform:translateY(24px) scaleY(.35);}
  25%{opacity:.9;}
  100%{opacity:0;transform:translateY(-12px) scaleY(1.2);}
}
@keyframes cyberPulse{
  0%{opacity:.18;transform:scale(.45) rotate(0deg);}
  22%{opacity:1;}
  100%{opacity:0;transform:scale(1.26) rotate(28deg);}
}
@keyframes reticleLock{
  0%{opacity:.15;transform:scale(1.3);}
  20%{opacity:.95;}
  100%{opacity:0;transform:scale(.75);}
}

/* Intel Feed */
.intel-feed{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:3px;}
.intel-item{
  font-family:var(--mono);font-size:.58rem;padding:3px 7px;
  background:rgba(0,15,35,.5);border-left:3px solid var(--border);
  animation:intelSlide .25s ease;line-height:1.5;flex-shrink:0;
}
@keyframes intelSlide{from{transform:translateX(-15px);opacity:0;}to{transform:translateX(0);opacity:1;}}
.intel-item.alert{border-color:var(--red);color:#ff9999;}
.intel-item.success{border-color:var(--green);color:#88ffaa;}
.intel-item.warn{border-color:var(--amber);color:#ffcc55;}
.intel-item.info{border-color:var(--blue);color:#88ccff;}
.intel-item.nuke{border-color:#ff6600;color:#ffaa44;background:rgba(80,20,0,.4);}
.intel-feed::-webkit-scrollbar{width:3px;}
.intel-feed::-webkit-scrollbar-thumb{background:var(--border);}

/* Presidential Hand */
#handContainer{display:flex;flex-direction:column;align-items:center;gap:5px;}
#presHand{width:110px;height:165px;filter:drop-shadow(0 5px 18px rgba(0,0,0,.85));animation:handHov 3.5s ease-in-out infinite alternate;}
@keyframes handHov{0%{transform:translateY(0) rotate(-2deg);}100%{transform:translateY(-6px) rotate(2deg);}}
.hand-label{font-size:.38rem;color:rgba(200,170,110,.6);letter-spacing:2px;text-align:center;font-family:var(--mono);}

/* ---- NUCLEAR EFFECTS ---- */
#nuclearFlash{
  position:absolute;
  inset:0;
  /* Completely uniform flash - no gradients, no blending to prevent any screen split */
  background: #ffffff;
  pointer-events:none;
  z-index:999999; /* Above everything to ensure uniform coverage */
  opacity:0;
  transition:opacity .05s linear; /* Faster transition */
  width:100vw; /* Use viewport width */
  height:100vh; /* Use viewport height */
  position:fixed; /* Fixed to viewport */
  left:0;
  top:0;
  /* Remove all blending that could cause division */
  mix-blend-mode: normal;
  isolation: auto;
}
#nuclearWinterOverlay{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:999998; /* Just below flash */
  opacity:0;
  transition:opacity 3s;
  /* Very subtle uniform winter effect */
  background: rgba(70,50,28,0.03);
  width:100vw;
  height:100vh;
  position:fixed;
  left:0;
  top:0;
  mix-blend-mode: normal;
  isolation: auto;
}

/* ---- TOAST NOTIFICATIONS ---- */
#toastContainer{position:fixed;top:75px;left:50%;transform:translateX(-50%);z-index:800;display:flex;flex-direction:column;gap:6px;align-items:center;}
.toast{
  background:rgba(2,10,25,.97);border:1px solid var(--border);padding:9px 20px;
  font-family:var(--mono);font-size:.68rem;color:var(--text);
  animation:toastIn .25s ease,toastOut .3s ease 2.7s forwards;
  box-shadow:0 4px 22px rgba(0,0,0,.65);letter-spacing:1px;text-align:center;min-width:240px;
}
.toast.talert{border-color:var(--red);color:#ff9999;}
.toast.tsuccess{border-color:var(--green);color:#88ffaa;}
.toast.twarn{border-color:var(--amber);color:var(--amber);}
.toast.tinfo{border-color:var(--blue);color:#88ccff;}
@keyframes toastIn{from{opacity:0;transform:translateY(-16px);}to{opacity:1;transform:translateY(0);}}
@keyframes toastOut{from{opacity:1;}to{opacity:0;transform:translateY(-10px);}}

/* ---- MISSILE DOT EFFECTS ---- */
.m-dot{
  position:absolute;width:7px;height:7px;border-radius:50%;
  background:#ff4400;box-shadow:0 0 10px #ff8800,0 0 20px #ff4400;
  transform:translate(-50%,-50%);z-index:46;pointer-events:none;
}
.m-dot.incoming{background:#ff00ff;box-shadow:0 0 10px #ff00ff,0 0 20px #cc00cc;}
.m-dot.anti{background:#00aaff;box-shadow:0 0 10px #00aaff,0 0 20px #0066ff;}

/* ---- OVERLAYS ---- */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:1000;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(5px);}
.overlay.hidden{display:none;}

.dialog-box{
  background:linear-gradient(135deg,rgba(3,12,28,.99),rgba(8,3,18,.99));
  border:2px solid var(--border);padding:28px;max-width:520px;width:90%;
  box-shadow:0 0 60px rgba(0,100,200,.35);
}
.dlg-title{font-size:.9rem;color:var(--amber);letter-spacing:3px;margin-bottom:14px;border-bottom:1px solid var(--border);padding-bottom:9px;}
.dlg-body{font-family:var(--mono);font-size:.68rem;color:var(--text);line-height:1.85;margin-bottom:16px;}
.dlg-btns{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;}
.dlg-btn{
  padding:8px 16px;background:rgba(0,35,80,.75);border:1px solid var(--border);
  color:var(--text);font-family:var(--main);font-size:.54rem;cursor:pointer;
  letter-spacing:2px;transition:all .2s;
}
.dlg-btn:hover{background:rgba(0,70,160,.75);color:#fff;}
.dlg-btn.accept{border-color:rgba(0,220,90,.45);color:var(--green);}
.dlg-btn.reject{border-color:rgba(255,50,50,.45);color:#ff8888;}
.dlg-btn.launch-now{background:rgba(120,0,0,.7);border-color:rgba(255,50,50,.7);color:#fff;}
.dlg-btn.launch-now:hover{background:rgba(200,0,0,.8);}

#yearProgress {
  width: 0%;
  height: 100%;
  background: linear-gradient(90deg, #66a4ff, #7cffcb);
}

#gameLayout {
  flex: 1;
  display: grid;
  grid-template-columns: 270px minmax(0, 1fr) 330px;
  gap: 14px;
  padding: 14px 16px 0;
  min-height: 0;
}

.sidebar {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
  overflow: hidden;
}

.sidebar.left { width: 270px; }
.sidebar.right { 
  width: 320px; /* Increased more for store display */
  position: absolute; /* Position against right wall */
  right: 0;
  top: 0;
}

.panel {
  padding: 16px;
  overflow: hidden;
  backdrop-filter: blur(6px);
}

.panel-title {
  margin-bottom: 12px;
  color: #f4f8ff;
  font: 800 0.86rem var(--display);
  text-transform: uppercase;
}

.summary-panel,
.quick-arsenal,
.command-tabs,
#panelAir,
#panelGround,
#panelNaval,
#panelIntel,
#panelNuclear,
#panelDiplomacy,
#panelStore,
#panelOverview {
  background:
    linear-gradient(180deg, rgba(12, 22, 38, 0.92), rgba(5, 11, 20, 0.96));
  overflow-y: auto; /* Add scroll bars to panel overview */
  overflow-x: hidden;
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
  max-height: 400px; /* Limit height for scrolling */
}

/* Custom scrollbar for panel overview */
#panelOverview::-webkit-scrollbar {
  width: 8px;
}
#panelOverview::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border-radius: 4px;
}
#panelOverview::-webkit-scrollbar-thumb {
  background: #2a4a6a;
  border-radius: 4px;
}
#panelOverview::-webkit-scrollbar-thumb:hover {
  background: #3a5a7a;
}

.sidebar.right .panel {
  min-height: 0;
  height: calc(100vh - 92px - 150px - 40px);
  overflow-y: auto; /* Add vertical scrollbar */
  overflow-x: hidden; /* Hide horizontal scrollbar */
  scrollbar-width: auto; /* Enable scrollbar */
  scrollbar-color: #2a4a6a #0a1520; /* Custom scrollbar colors */
}

/* Special height for store panel */
#panelStore {
  height: calc(100vh - 92px - 90px - 40px) !important;
  max-height: none !important;
}

/* Move overview drawer up */
.overview-drawer {
  bottom: 90px !important;
}

/* Custom scrollbar for right panels */
.sidebar.right .panel::-webkit-scrollbar {
  width: 8px; /* Thinner scrollbar for panels */
}
.sidebar.right .panel::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border-radius: 4px;
}
.sidebar.right .panel::-webkit-scrollbar-thumb {
  background: #2a4a6a;
  border-radius: 4px;
}
.sidebar.right .panel::-webkit-scrollbar-thumb:hover {
  background: #3a5a7a;
}

.overview-drawer{
  flex:0 0 auto;
  border-radius:18px;
  border:1px solid rgba(117,171,255,0.16);
  background:linear-gradient(180deg, rgba(12, 22, 38, 0.94), rgba(5, 11, 20, 0.98));
  box-shadow:var(--shadow);
  padding: 12px;
  cursor: pointer;
  transition: all 0.3s ease;
}

.overview-drawer:hover {
  background:linear-gradient(180deg, rgba(12, 22, 38, 0.98), rgba(5, 11, 20, 1));
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}

.overview-drawer .overview-toggle-state {
  text-align: center;
  font-size: 0.9rem;
  margin: 0;
}

.diplomacy-drawer {
  flex:0 0 auto;
  border-radius:18px;
  border:1px solid rgba(117,171,255,0.16);
  background:linear-gradient(180deg, rgba(12, 22, 38, 0.94), rgba(5, 11, 20, 0.98));
  box-shadow:var(--shadow);
  padding: 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  margin-top: 10px;
}

.diplomacy-drawer:hover {
  background:linear-gradient(180deg, rgba(12, 22, 38, 0.98), rgba(5, 11, 20, 1));
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}

.diplomacy-toggle {
  background: none;
  border: none;
  color: #75abff;
  font: 700 0.8rem var(--mono);
  text-transform: uppercase;
  cursor: pointer;
  width: 100%;
  text-align: center;
  padding: 8px;
  transition: all 0.3s ease;
}

.diplomacy-toggle:hover {
  color: #94c6ff;
}

.right-status-panel{
  flex:0 0 auto;
  border-radius:18px;
  border:1px solid rgba(117,171,255,0.16);
  background:linear-gradient(180deg, rgba(12, 22, 38, 0.94), rgba(5, 11, 20, 0.98));
  box-shadow:var(--shadow);
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
  max-height: 300px;
  padding:14px 16px;
}

/* Custom scrollbar for status panel */
.right-status-panel::-webkit-scrollbar {
  width: 8px;
}
.right-status-panel::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border-radius: 4px;
}
.right-status-panel::-webkit-scrollbar-thumb {
  background: #2a4a6a;
  border-radius: 4px;
}
.right-status-panel::-webkit-scrollbar-thumb:hover {
  background: #3a5a7a;
}

.side-stats{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  margin-top:6px;
}

.side-stats div{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:8px 10px;
  border-radius:10px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(117,171,255,0.1);
}

.side-impact-panel{
  margin-top:12px;
}

.side-impact-panel .impact-timeline{
  max-height:190px;
}

.overview-drawer{
  overflow:hidden;
}

.overview-toggle{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  background:linear-gradient(180deg, rgba(18, 34, 56, 0.96), rgba(8, 18, 32, 0.96));
  border:none;
  border-bottom:1px solid rgba(117,171,255,0.12);
  color:#f4f8ff;
  font:800 .74rem var(--main);
  letter-spacing:2px;
  text-transform:uppercase;
  cursor:pointer;
}

.overview-toggle-state{
  color:var(--amber);
  font:700 .58rem var(--mono);
}

.overview-drawer-body{
  max-height:420px;
  overflow-y:auto;
  overflow-x:hidden;
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
  padding:14px 16px 16px;
  background:rgba(0,15,35,.8);
  border-radius:12px;
  transition:max-height .24s ease, opacity .2s ease, padding .24s ease;
}

/* Custom scrollbar for overview drawer body */
.overview-drawer-body::-webkit-scrollbar {
  width: 8px;
}
.overview-drawer-body::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border-radius: 4px;
}
.overview-drawer-body::-webkit-scrollbar-thumb {
  background: #2a4a6a;
  border-radius: 4px;
}
.overview-drawer-body::-webkit-scrollbar-thumb:hover {
  background: #3a5a7a;
}

.overview-drawer.collapsed .overview-drawer-body{
  max-height:0;
  opacity:0;
  padding-top:0;
  padding-bottom:0;
}

.overview-drawer-body .command-copy{
  margin-bottom:12px;
}

.overview-drawer-body .unit-grid{
  margin-bottom:12px;
}

.sidebar.right .command-panel{
  flex:1 1 auto;
  min-height:0;
  height:auto;
  overflow-y: auto; /* Ensure command panel scrolls */
  overflow-x: hidden;
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
}

/* Custom scrollbar for command panel */
.sidebar.right .command-panel::-webkit-scrollbar {
  width: 8px;
}
.sidebar.right .command-panel::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border-radius: 4px;
}
.sidebar.right .command-panel::-webkit-scrollbar-thumb {
  background: #2a4a6a;
  border-radius: 4px;
}
.sidebar.right .command-panel::-webkit-scrollbar-thumb:hover {
  background: #3a5a7a;
}

.quick-arsenal {
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
  max-height: 250px; /* Limit height for scrolling */
}

/* Custom scrollbar for quick arsenal */
.quick-arsenal::-webkit-scrollbar {
  width: 8px;
}
.quick-arsenal::-webkit-scrollbar-track {
  background: rgba(10, 21, 32, 0.8);
  border-radius: 4px;
}
.quick-arsenal::-webkit-scrollbar-thumb {
  background: #2a4a6a;
  border-radius: 4px;
}
.quick-arsenal::-webkit-scrollbar-thumb:hover {
  background: #3a5a7a;
}

.phase-meter {
  font: 700 0.72rem var(--mono);
  text-transform: uppercase;
}

.hud-center .phase-meter{
  width:min(320px,100%);
  transform:scale(.9);
  transform-origin:center top;
}

.meter-labels,
.meter-stages,
.control-row,
.session-stats,
.store-item,
.diplomacy-item {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.meter-bar {
  height: 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
  margin: 10px 0 8px;
}

#escalationBar {
  width: 18%;
  height: 100%;
  background: linear-gradient(90deg, #6affbe, #ffd36a 55%, #ff6a6a);
}

.meter-stages {
  color: var(--muted);
  font-size: 0.64rem;
}

.world-summary-grid,
.stock-grid,
.unit-grid,
.tab-grid,
.session-buttons {
  display: grid;
  gap: 10px;
}

.world-summary-grid {
  grid-template-columns: repeat(2, 1fr);
  margin-top: 14px;
}

.summary-card,
.stock-card,
.unit-card {
  padding: 12px;
  border-radius: 16px;
  background: rgba(120, 167, 255, 0.08);
  border: 1px solid rgba(119, 182, 255, 0.14);
}

.summary-card span,
.stock-card span,
.unit-card span {
  display: block;
  color: var(--muted);
  font: 700 0.7rem var(--mono);
  text-transform: uppercase;
}

.summary-card strong,
.stock-card strong,
.unit-card strong {
  display: block;
  margin-top: 6px;
  font: 800 1rem var(--display);
}

.tab-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tab-btn {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(114, 183, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(18, 34, 56, 0.96), rgba(8, 18, 32, 0.96)),
    radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.08), transparent 40%);
  color: var(--text);
  cursor: pointer;
  text-transform: uppercase;
  font: 700 0.74rem var(--display);
}

.tab-btn.active {
  background: linear-gradient(180deg, rgba(74, 117, 186, 0.96), rgba(42, 74, 127, 0.96));
  border-color: rgba(137, 208, 255, 0.42);
}

.stock-grid,
.unit-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.stock-card,
.unit-card {
  min-height: 118px;
}

.unit-card svg,
.stock-card svg {
  width: 100%;
  height: 58px;
  margin-bottom: 8px;
}

.store-item svg {
  width: 100%;
  max-width: 140px;
  height: 54px;
  display: block;
  margin-bottom: 8px;
}

#mapStage {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
  min-height: 0;
  background: radial-gradient(ellipse at 50% 45%, rgba(0, 25, 55, 0.85), rgba(0, 8, 18, 0.95));
}

#mapShell {
  position: relative;
  flex: 1;
  min-height: 0;
  border-radius: 24px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(5, 15, 28, 0.85), rgba(2, 8, 18, 0.96)),
    radial-gradient(circle at 45% 42%, rgba(12, 40, 70, 0.35), transparent 50%),
    radial-gradient(circle at 65% 70%, rgba(90, 44, 26, 0.25), transparent 50%),
    var(--ocean);
  border: 1px solid rgba(113, 182, 255, 0.18);
  box-shadow: var(--shadow);
}

#worldMapImage,
#routeCanvas,
#fxCanvas,
#mapHotspots {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

#worldMapImage {
  object-fit: cover;
  filter: brightness(0.9) saturate(1.05);
}

#routeCanvas,
#fxCanvas,
#mapHotspots {
  pointer-events: none;
}

#mapHotspots {
  pointer-events: auto;
}

.hotspot {
  position: absolute;
  width: 16px;
  height: 16px;
  margin-left: -8px;
  margin-top: -8px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.7);
  box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.2);
  cursor: pointer;
}

.hotspot::after {
  content: "";
  position: absolute;
  inset: -8px;
  border-radius: 999px;
  border: 1px solid currentColor;
  opacity: 0.45;
  animation: pulse 1.8s infinite;
}

.hotspot.allied {
  color: #67d1ff;
  background: rgba(103, 209, 255, 0.35);
}

.hotspot.hostile {
  color: #ff7f7f;
  background: rgba(255, 105, 105, 0.38);
}

.hotspot.neutral {
  color: #ffe58a;
  background: rgba(255, 229, 138, 0.34);
}

.hotspot.selected {
  transform: scale(1.25);
}

@keyframes pulse {
  0% { transform: scale(0.9); opacity: 0.7; }
  100% { transform: scale(1.5); opacity: 0; }
}

#targetMarker {
  position: absolute;
  width: 42px;
  height: 42px;
  margin-left: -21px;
  margin-top: -21px;
  border-radius: 999px;
  border: 2px solid #ff5b5b;
  box-shadow: 0 0 0 8px rgba(255, 91, 91, 0.16);
  pointer-events: none;
  z-index: 5;
}

#targetMarker::before,
#targetMarker::after {
  content: "";
  position: absolute;
  background: #ff5b5b;
}

#targetMarker::before {
  width: 2px;
  height: 100%;
  left: 50%;
  transform: translateX(-50%);
}

#targetMarker::after {
  height: 2px;
  width: 100%;
  top: 50%;
  transform: translateY(-50%);
}

#mapTooltip {
  position: absolute;
  min-width: 220px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(3, 8, 16, 0.94);
  border: 1px solid rgba(118, 190, 255, 0.28);
  box-shadow: var(--shadow);
  font: 700 0.74rem var(--mono);
  z-index: 10;
}

.hidden,
.hidden-panel {
  display: none !important;
}

#mapLegend {
  position: absolute;
  left: 14px;
  bottom: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  z-index: 2;
}

.legend {
  font-size: 0.68rem;
}

.legend.allied { background: rgba(83, 196, 255, 0.16); }
.legend.hostile { background: rgba(255, 90, 90, 0.18); }
.legend.neutral { background: rgba(255, 208, 106, 0.18); }
.legend.nuclear { background: rgba(255, 142, 87, 0.18); }

#battleRibbon {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  position: relative;
  z-index: 20;
}

.ribbon-item {
  padding: 14px 16px;
  border-radius: 16px;
  background: var(--panel);
  border: 1px solid var(--line);
}

.ribbon-item span {
  display: block;
  color: var(--muted);
  font: 700 0.66rem var(--mono);
  text-transform: uppercase;
}

.ribbon-item strong {
  display: block;
  margin-top: 8px;
  font: 800 0.95rem var(--display);
}

.active-panel {
  display: block;
}

.action-stack {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.action-btn {
  padding: 12px;
  font: 700 0.74rem var(--display);
  border-radius: 16px;
}

.action-btn.active-command {
  background: linear-gradient(180deg, rgba(158, 28, 28, 0.98), rgba(108, 10, 10, 0.98));
  border-color: rgba(255, 114, 114, 0.48);
  box-shadow: 0 0 24px rgba(255, 70, 70, 0.28);
}

.panel-copy,
.command-copy,
.nuclear-warning {
  color: var(--muted);
  font: 700 0.78rem/1.6 var(--mono);
}

.nuclear-warning {
  margin-bottom: 12px;
  color: #ffb2b2;
}

.inventory-list,
.diplomacy-list,
.store-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 6px;
  max-height: 800px;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 4px;
}

.intel-feed {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.store-item {
  padding: 6px;
  border-radius: 6px;
  background: linear-gradient(135deg, rgba(117, 171, 255, 0.12), rgba(117, 171, 255, 0.06));
  border: 1px solid rgba(117, 171, 255, 0.2);
  font: 700 0.58rem/1.1 var(--mono);
  display: flex;
  flex-direction: column;
  gap: 3px;
  transition: all 0.2s ease;
  cursor: pointer;
  min-width: 0; /* Prevents overflow */
  width: 100%;
  box-sizing: border-box;
}

.store-item:hover {
  background: linear-gradient(135deg, rgba(117, 171, 255, 0.18), rgba(117, 171, 255, 0.1));
  border-color: rgba(117, 171, 255, 0.4);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.store-item svg {
  width: 100%;
  height: 24px;
  margin-bottom: 1px;
}

.store-item .item-name {
  font-size: 0.58rem;
  color: #f6fbff;
  margin-bottom: 1px;
  font-weight: 700;
}

.store-item .item-price {
  font-size: 0.52rem;
  color: #ffb000;
  font-weight: 600;
}

.store-item .item-desc {
  font-size: 0.48rem;
  color: var(--muted);
  line-height: 1.0;
  margin-top: auto;
}

.store-item .buy-btn {
  margin-top: 3px;
  padding: 3px 6px;
  background: linear-gradient(135deg, rgba(0, 255, 136, 0.2), rgba(0, 200, 100, 0.15));
  border: 1px solid rgba(0, 255, 136, 0.4);
  border-radius: 3px;
  color: #00ff88;
  font: 600 0.50rem var(--mono);
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: center;
  width: 100%;
  box-sizing: border-box;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.store-item .buy-btn:hover {
  background: linear-gradient(135deg, rgba(0, 255, 136, 0.3), rgba(0, 200, 100, 0.25));
  border-color: rgba(0, 255, 136, 0.6);
  transform: scale(1.05);
}

.store-item .buy-btn:disabled {
  background: rgba(80, 80, 80, 0.2);
  border-color: rgba(80, 80, 80, 0.4);
  color: #666;
  cursor: not-allowed;
  transform: none;
}

.inventory-item,
.intel-item,
.diplomacy-item,
.country-card {
  padding: 12px;
  border-radius: 14px;
  background: rgba(117, 171, 255, 0.08);
  border: 1px solid rgba(117, 171, 255, 0.12);
  font: 700 0.74rem/1.5 var(--mono);
}

.inventory-item strong,
.country-card strong,
.diplomacy-item strong,
.store-item strong {
  color: #f6fbff;
}

.control-row {
  align-items: center;
  margin: 12px 0;
  font: 700 0.74rem var(--mono);
  text-transform: uppercase;
}

.control-row select,
.control-row input[type="range"] {
  flex: 1;
}

.control-row select {
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(10, 21, 36, 0.92);
  color: var(--text);
  border: 1px solid rgba(116, 185, 255, 0.16);
}

.launch-controls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.safety-btn,
.key-btn {
  padding: 12px;
  font: 700 0.72rem var(--display);
  background: linear-gradient(180deg, rgba(90, 21, 21, 0.95), rgba(50, 7, 7, 0.98));
  border-color: rgba(255, 96, 96, 0.26);
  cursor: pointer;
}

.safety-btn.armed,
.key-btn.armed {
  background: linear-gradient(180deg, rgba(50, 110, 71, 0.94), rgba(24, 64, 36, 0.98));
}

.overview-drawer {
  overflow-y: auto !important;
  scrollbar-width: auto;
  scrollbar-color: #2a4a6a #0a1520;
}

.overview-drawer-body {
  overflow-y: scroll !important;
  overscroll-behavior: contain;
}

.country-damage-brief {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(68, 18, 8, 0.9), rgba(28, 10, 4, 0.86));
  border: 1px solid rgba(255, 176, 0, 0.22);
  box-shadow: inset 0 1px 0 rgba(255, 214, 120, 0.08);
}

.country-damage-title {
  color: var(--amber);
  font: 700 0.56rem var(--mono);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.country-damage-brief strong {
  display: block;
  color: #fff1ca;
  margin-bottom: 6px;
}

.country-damage-brief span {
  display: block;
  color: rgba(241, 232, 214, 0.88);
  margin-top: 4px;
}

.damage-intel p {
  white-space: normal;
}

.damage-intel p strong {
  color: #f6fbff;
}

#launchHandWrap {
  margin-top: 14px;
  padding: 16px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 50% 15%, rgba(255, 130, 130, 0.1), transparent 52%),
    rgba(0, 0, 0, 0.28);
  border: 1px solid rgba(255, 111, 111, 0.2);
}

#handSvgWrap {
  width: 100%;
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#handSvgWrap svg {
  width: 180px;
  height: 180px;
  filter:
    drop-shadow(0 14px 24px rgba(0, 0, 0, 0.55))
    drop-shadow(0 4px 12px rgba(255, 140, 100, 0.12));
}

.launch-btn {
  width: 100%;
  margin-top: 8px;
  padding: 18px 20px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 30%, #ffb0b0 0%, #ff5d5d 24%, #d10d0d 46%, #7a0000 100%);
  border: 3px solid rgba(255, 133, 133, 0.4);
  color: #fff;
  font: 900 0.95rem var(--display);
  box-shadow:
    0 0 0 2px rgba(255, 255, 255, 0.05),
    0 14px 24px rgba(0, 0, 0, 0.4),
    0 0 26px rgba(255, 65, 65, 0.36);
  letter-spacing: 0.22em;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}

.launch-btn:disabled {
  cursor: not-allowed;
  filter: grayscale(0.48);
  opacity: 0.62;
}

.launch-btn::after {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 999px;
  border: 1px solid rgba(255, 220, 180, 0.2);
  pointer-events: none;
}

.launch-main {
  font-size: 1.05rem;
  font-weight: 900;
}

.launch-sub {
  margin-top: 4px;
  font: 700 0.55rem var(--mono);
  opacity: 0.88;
}

.launch-main {
  font-size: 1.05rem;
  font-weight: 900;
}

.launch-sub {
  margin-top: 4px;
  font: 700 0.55rem var(--mono);
  opacity: 0.88;
}

#bottomConsole {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 14px;
  height: 220px;
  flex: 0 0 220px;
  padding: 14px 16px 16px;
  background: linear-gradient(180deg, rgba(3, 7, 14, 0.95), rgba(2, 4, 10, 0.98));
  border-top: 1px solid rgba(120, 188, 255, 0.16);
}

.console-panel {
  min-height: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.intel-feed {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(120, 180, 255, 0.4) transparent;
}

.right-console .session-buttons {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.inventory-list,
.diplomacy-list,
.store-list {
  max-height: 280px;
  overflow-y: auto;
}

.command-deck {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 12px;
}

.command-readout {
  padding: 12px;
  border-radius: 14px;
  background: rgba(118, 171, 255, 0.08);
  border: 1px solid rgba(118, 171, 255, 0.14);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.command-readout span {
  display: block;
  color: var(--muted);
  font: 700 0.7rem var(--mono);
  text-transform: uppercase;
}

.command-readout strong {
  display: block;
  margin-top: 7px;
  color: #fff3ef;
  font: 800 0.84rem var(--display);
  text-transform: uppercase;
}

.command-exec {
  width: 100%;
}

.session-stats {
  margin-top: 12px;
  flex-direction: column;
  color: var(--muted);
  font: 700 0.74rem/1.7 var(--mono);
}

.overlay {
  position: fixed;
  inset: 0;
  z-index: 1100;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.62);
  padding: 24px;
}

.dialog-box {
  width: min(680px, 100%);
  padding: 24px;
  border-radius: 24px;
  border: 1px solid rgba(126, 197, 255, 0.24);
  background: linear-gradient(180deg, rgba(9, 19, 35, 0.98), rgba(4, 10, 18, 0.98));
  box-shadow: var(--shadow);
}

.dialog-box h2 {
  margin-top: 0;
  font: 800 1.3rem var(--display);
  text-transform: uppercase;
}

.dialog-box p,
.dialog-box li {
  font: 700 0.86rem/1.7 var(--mono);
  color: var(--text);
}

.dialog-actions {
  display: flex;
  gap: 10px;
  margin-top: 20px;
  flex-wrap: wrap;
}

#toastStack {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 1200;
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: min(360px, calc(100vw - 40px));
}

.toast {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(118, 190, 255, 0.16);
  background: rgba(8, 16, 28, 0.94);
  box-shadow: var(--shadow);
  font: 700 0.74rem/1.5 var(--mono);
}

.toast.good { border-color: rgba(117, 255, 176, 0.24); }
.toast.warn { border-color: rgba(255, 207, 102, 0.24); }
.toast.bad { border-color: rgba(255, 107, 107, 0.28); }

.muted {
  color: var(--muted);
}

@media (max-width: 1440px) {
  #gameLayout {
    grid-template-columns: 290px minmax(0, 1fr) 360px;
  }
}

@media (max-width: 1220px) {
  #mainMenu,
  #gameScreen {
    overflow: auto;
  }

  #gameLayout,
  #bottomConsole,
  .menu-hero,
  #topHud {
    grid-template-columns: 1fr;
  }

  .hud-cluster.stats {
    grid-template-columns: repeat(2, 1fr);
  }

  #gameLayout {
    min-height: auto;
  }
}
