/* ============================================================
   styles.css — Nuclear Command III — Full AAA Stylesheet
   ============================================================ */

@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;
}
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;
}
@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;max-width:95vw;max-height:95vh;overflow-y:auto;}

.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;}
.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.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:62px;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);
}
.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:2px;border-left:1px solid var(--border);border-right:1px solid var(--border);}
.hud-main-title{font-size:.85rem;color:#fff;letter-spacing:4px;text-shadow:0 0 8px rgba(0,150,255,.6);}
.hud-sub-title{font-size:.5rem;color:var(--amber);letter-spacing:6px;}
.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:200px;height:4px;background:rgba(0,40,80,.5);border:1px solid var(--border);border-radius:2px;overflow:hidden;}
#yearTimerBar{height:100%;background:linear-gradient(90deg,var(--blue),var(--green));width:0%;transition:width 1s linear;box-shadow:0 0 5px var(--blue);}

/* ---- MAP ---- */
#mapContainer{flex:1;position:relative;overflow:hidden;background:radial-gradient(ellipse at 50% 45%,#0a1520 0%,#030810 100%);}
#worldMapDiv{position:absolute;inset:0;}
#worldMapDiv svg{width:100%;height:100%;}
#fxCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:50;}
#missileLayer{position:absolute;inset:0;pointer-events:none;z-index:45;}

.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%{}}

/* 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:60;
}
#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:175px;background:var(--hud);border-top:2px solid var(--border);
  display:flex;flex-shrink:0;z-index:100;
}
.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);}

/* 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);}

/* ---- SIDE PANELS ---- */
.side-panel{
  position:fixed;top:62px;right:0;bottom:175px;width:390px;
  background:rgba(2,8,18,.97);border-left:2px solid var(--border);
  z-index:300;display:flex;flex-direction:column;overflow:hidden;
  box-shadow:-12px 0 35px rgba(0,0,0,.85);transition:transform .3s ease;
}
.side-panel.hidden{display:none;}
.panel-hdr{
  padding:11px 14px;background:rgba(0,25,55,.85);border-bottom:1px solid var(--border);
  font-size:.68rem;color:var(--amber);letter-spacing:3px;
  display:flex;justify-content:space-between;align-items:center;flex-shrink:0;
}
.close-btn{background:none;border:none;color:#ff8888;cursor:pointer;font-size:1rem;padding:0 5px;transition:color .2s;}
.close-btn:hover{color:var(--red);}
.panel-body{flex:1;overflow-y:auto;padding:10px;}
.panel-body::-webkit-scrollbar{width:3px;}
.panel-body::-webkit-scrollbar-thumb{background:var(--border);}
.section-label{font-size:.55rem;color:var(--amber);letter-spacing:3px;margin:10px 0 6px;border-bottom:1px solid rgba(255,176,0,.25);padding-bottom:4px;}

/* Stockpile Grid */
.stockpile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
.stock-card{
  background:rgba(0,15,35,.7);border:1px solid var(--border);
  border-radius:3px;padding:10px;text-align:center;display:flex;flex-direction:column;gap:5px;
}
.stock-card svg{width:50px;height:70px;margin:0 auto;}
.stock-count{font-size:1.5rem;color:var(--red);font-weight:900;text-shadow:0 0 8px var(--red);}
.stock-name{font-size:.48rem;color:var(--text);letter-spacing:2px;}
.stock-yield{font-size:.5rem;color:var(--amber);}

/* Store Grid */
.store-grid{display:flex;flex-direction:column;gap:6px;}
.store-item{
  display:flex;align-items:center;gap:10px;padding:7px;
  background:rgba(0,12,28,.6);border:1px solid rgba(0,100,200,.2);
  cursor:pointer;transition:all .2s;border-radius:3px;
}
.store-item:hover{background:rgba(0,30,70,.7);border-color:var(--blue);}
.store-item svg{width:28px;height:38px;flex-shrink:0;}
.store-info{flex:1;}
.store-name{font-size:.6rem;color:var(--text);}
.store-price{font-size:.55rem;color:var(--green);}
.store-stock{font-size:.5rem;color:var(--amber);}
.store-btn{
  padding:5px 9px;background:rgba(0,50,110,.65);border:1px solid var(--border);
  color:var(--text);font-family:var(--main);font-size:.48rem;cursor:pointer;
  letter-spacing:1px;transition:all .2s;flex-shrink:0;
}
.store-btn:hover{background:rgba(0,100,220,.5);color:#fff;}

/* Commando */
.commando-box{background:rgba(30,15,0,.5);border:1px solid rgba(200,150,0,.3);padding:10px;border-radius:3px;}
.commando-desc{font-family:var(--mono);font-size:.58rem;color:var(--text);line-height:1.6;margin-bottom:8px;}
.cmd-select{
  width:100%;background:rgba(0,15,35,.85);border:1px solid var(--border);
  color:var(--amber);font-family:var(--mono);font-size:.6rem;padding:5px;
  outline:none;margin-bottom:8px;
}
.cmd-btn{
  width:100%;padding:8px;background:rgba(40,20,0,.7);border:1px solid rgba(200,150,0,.45);
  color:var(--amber);font-family:var(--main);font-size:.58rem;cursor:pointer;
  letter-spacing:2px;transition:all .2s;
}
.cmd-btn:hover{background:rgba(80,40,0,.7);border-color:var(--amber);box-shadow:0 0 12px rgba(200,150,0,.35);}
.commando-log{margin-top:8px;font-family:var(--mono);font-size:.58rem;min-height:50px;max-height:100px;overflow-y:auto;}

/* ---- DIPLOMACY ---- */
.diplo-card{
  background:rgba(0,12,28,.7);border:1px solid rgba(0,100,200,.2);
  border-radius:3px;padding:10px;margin-bottom:8px;
}
.diplo-name{font-size:.72rem;color:var(--text);letter-spacing:2px;margin-bottom:2px;}
.diplo-capital{font-size:.5rem;color:rgba(140,180,220,.6);font-family:var(--mono);margin-bottom:5px;}
.diplo-status{font-size:.58rem;font-family:var(--mono);margin-bottom:5px;padding:2px 6px;border-radius:2px;display:inline-block;}
.diplo-status.hostile{color:var(--red);background:rgba(100,0,0,.3);border:1px solid rgba(255,0,0,.3);}
.diplo-status.neutral{color:var(--amber);background:rgba(80,50,0,.3);border:1px solid rgba(255,176,0,.3);}
.diplo-status.allied{color:var(--green);background:rgba(0,60,30,.3);border:1px solid rgba(0,255,100,.3);}
.diplo-status.peace{color:#88ffaa;background:rgba(0,80,40,.3);border:1px solid rgba(0,255,100,.3);}
.diplo-pop{font-size:.55rem;font-family:var(--mono);color:rgba(140,180,220,.7);margin-bottom:6px;}
.diplo-btns{display:flex;gap:6px;flex-wrap:wrap;}
.diplo-btn{
  padding:4px 9px;background:rgba(0,35,80,.6);border:1px solid var(--border);
  color:var(--text);font-family:var(--main);font-size:.45rem;cursor:pointer;
  letter-spacing:1px;transition:all .2s;
}
.diplo-btn:hover{background:rgba(0,70,160,.6);color:#fff;}
.diplo-btn.strike{border-color:rgba(255,50,50,.45);color:#ff8888;}
.diplo-btn.strike:hover{background:rgba(110,0,0,.6);}
.diplo-btn.peace-btn{border-color:rgba(0,200,80,.4);color:#88ffaa;}
.diplo-btn.peace-btn:hover{background:rgba(0,80,30,.6);}

/* ---- 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);}

/* Game Over */
.gameover-box{
  background:linear-gradient(135deg,rgba(18,0,0,.99),rgba(5,0,0,.99));
  border:2px solid var(--red);padding:45px;text-align:center;max-width:520px;
  box-shadow:0 0 90px rgba(255,0,0,.45);
}
.go-skull{font-size:4rem;color:var(--red);text-shadow:0 0 30px var(--red);animation:goPulse 1s infinite alternate;}
@keyframes goPulse{from{text-shadow:0 0 20px var(--red);}to{text-shadow:0 0 50px var(--red),0 0 80px #ff4400;}}
.go-title{font-size:2.5rem;color:var(--red);text-shadow:0 0 25px var(--red);margin:10px 0;}
.go-sub{font-size:.78rem;color:var(--amber);letter-spacing:4px;margin-bottom:18px;}
.go-stats{font-family:var(--mono);font-size:.68rem;color:var(--text);line-height:2.1;margin-bottom:22px;text-align:left;background:rgba(0,0,0,.3);padding:12px;border:1px solid rgba(255,0,0,.2);}
.go-btns{display:flex;gap:12px;justify-content:center;}

/* Loading */
.loading-box{text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px;}
.loading-emblem{font-size:3.5rem;color:var(--blue);text-shadow:0 0 20px var(--blue);animation:spinRing 3s linear infinite;}
.loading-title{font-size:.95rem;color:var(--blue);letter-spacing:5px;text-shadow:0 0 10px var(--blue);}
.loading-bar-outer{width:420px;height:7px;background:rgba(0,40,90,.5);border:1px solid var(--border);border-radius:4px;overflow:hidden;}
.loading-bar-inner{height:100%;background:linear-gradient(90deg,var(--blue),var(--green));width:0%;transition:width .35s;box-shadow:0 0 12px var(--blue);}
.loading-status{font-family:var(--mono);font-size:.62rem;color:rgba(100,160,220,.7);letter-spacing:2px;}

/* Credits */
#creditsScreen{align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#050510 0%,#000 100%);}
.credits-wrap{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;}
.credits-logo{font-size:3rem;color:var(--red);text-shadow:0 0 20px var(--red);}
.credits-h1{font-size:2.5rem;color:var(--red);text-shadow:0 0 18px var(--red);}
.credits-h2{font-size:1rem;color:var(--amber);letter-spacing:5px;}
.credits-p{font-family:var(--mono);font-size:.7rem;color:var(--text);}

/* Nuclear Flash */
#nuclearFlash{position:fixed;inset:0;background:#fff;pointer-events:none;z-index:900;opacity:0;transition:opacity .08s;}
#nuclearWinterOverlay{
  position:fixed;inset:0;pointer-events:none;z-index:25;opacity:0;transition:opacity 3s;
  background:linear-gradient(180deg,rgba(50,35,20,0) 0%,rgba(70,50,28,.35) 100%);
}

/* Toast */
#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 */
.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;}

/* Scrollbars */
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:rgba(0,8,20,.4);}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}

/* Country Selection Styles */
.country-path{
  transition: all 0.3s ease;
}
.country-path:hover{
  fill: rgba(255,255,0,0.4) !important;
  stroke: rgba(255,255,0,0.8) !important;
  stroke-width: 3px !important;
}
.country-path.selected{
  fill: rgba(255,0,0,0.5) !important;
  stroke: rgba(255,0,0,0.9) !important;
  stroke-width: 3px !important;
  animation: pulse 1s ease-in-out infinite alternate;
}
.country-path.destroyed{
  fill: rgba(128,128,128,0.5) !important;
  stroke: rgba(64,64,64,0.8) !important;
  stroke-width: 2px !important;
}
.country-path.nuked{
  fill: rgba(255,255,0,0.8) !important;
  stroke: rgba(255,128,0,1) !important;
  stroke-width: 4px !important;
}
@keyframes pulse{
  0%{opacity: 0.7;}
  100%{opacity: 1;}
}
