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

:root {
  --blood: #cc1a1a;
  --bile: #4a7c2f;
  --ash: #1a1a1a;
  --bone: #d4c9a8;
  --hazard: #e0e62a;
  --steel: #4a5568;
  --steel-light: #718096;
  --panel-bg: rgba(10, 10, 12, 0.96);
  --panel-border: #3a3a3a;
  --text-primary: #d4c9a8;
  --text-dim: #6b7280;
  --font-main: 'Rajdhani', 'Arial Narrow', sans-serif;
  --font-mono: 'Share Tech Mono', 'Courier New', monospace;
}

*{box-sizing:border-box;margin:0;padding:0;user-select:none;-webkit-user-select:none;}
body,html{width:100%;height:100%;overflow:hidden;background:#000;font-family:var(--font-main);touch-action:none;}

#loadingScreen{position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at center,#0d0d0f 0%,#000 100%);z-index:1000;display:flex;flex-direction:column;justify-content:center;align-items:center;color:var(--hazard);font-family:var(--font-mono);}
#loadingScreen::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.04) 2px,rgba(0,0,0,0.04) 4px);pointer-events:none;}
#loadText{font-size:18px;letter-spacing:4px;color:var(--hazard);margin-bottom:12px;font-family:var(--font-mono);}
#loadBarContainer{width:360px;height:5px;background:rgba(255,255,255,0.05);border:1px solid rgba(224,230,42,0.2);margin-top:16px;position:relative;}
#loadBar{height:100%;background:linear-gradient(90deg,#4a7c2f,#e0e62a);box-shadow:0 0 12px rgba(224,230,42,0.8);transition:width 0.1s;position:relative;}
#loadBar::after{content:'';position:absolute;right:0;top:-3px;bottom:-3px;width:2px;background:#fff;box-shadow:0 0 6px #fff,0 0 12px var(--hazard);}

#gameContainer{position:relative;width:100vw;height:100vh;}
#gameCanvas{display:block;width:100%;height:100%;}
#uiOverlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;}

#topBar{background:linear-gradient(180deg,rgba(0,0,0,0.93) 0%,rgba(0,0,0,0.7) 100%);border-bottom:1px solid rgba(224,230,42,0.12);color:var(--text-primary);padding:8px 16px;display:flex;justify-content:space-between;font-size:13px;pointer-events:auto;align-items:center;font-family:var(--font-mono);letter-spacing:1px;backdrop-filter:blur(4px);}
#resourceReadout{color:var(--hazard);font-weight:bold;text-shadow:0 0 8px rgba(224,230,42,0.5);font-size:14px;}

#rosterPanel{position:absolute;top:100px;left:10px;display:flex;flex-direction:column;gap:4px;pointer-events:auto;z-index:50;}
.roster-btn{background:linear-gradient(135deg,rgba(12,12,15,0.96) 0%,rgba(22,22,26,0.96) 100%);color:var(--text-primary);border:1px solid var(--panel-border);border-left:3px solid var(--steel);padding:7px 12px;border-radius:2px;font-family:var(--font-mono);font-size:12px;font-weight:600;text-align:left;min-width:128px;transition:all 0.15s;box-shadow:2px 2px 8px rgba(0,0,0,0.6);}
.roster-btn.active{border-left-color:var(--hazard);background:linear-gradient(135deg,rgba(28,28,18,0.98) 0%,rgba(38,38,22,0.98) 100%);box-shadow:0 0 10px rgba(224,230,42,0.12),2px 2px 8px rgba(0,0,0,0.8);}
.roster-btn .sub-text{font-size:10px;color:var(--text-dim);display:block;margin-top:2px;letter-spacing:0;}

#safehouseMenu,#survivorMenu,#buildMenu{background:var(--panel-bg);color:var(--text-primary);padding:20px;border:1px solid var(--panel-border);border-top:2px solid var(--blood);pointer-events:auto;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:360px;border-radius:3px;display:flex;flex-direction:column;gap:10px;z-index:80;box-shadow:0 0 40px rgba(0,0,0,0.9);}
#exitPromptPanel,#loopPromptPanel,#walkiePromptPanel{background:var(--panel-bg);color:var(--text-primary);padding:20px;border:1px solid var(--panel-border);border-top:2px solid var(--hazard);pointer-events:auto;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:360px;border-radius:3px;display:flex;flex-direction:column;gap:10px;z-index:2000 !important;box-shadow:0 0 40px rgba(0,0,0,0.9),0 0 20px rgba(224,230,42,0.05);}

.hidden{display:none !important;}
h3{margin-bottom:8px;text-align:center;font-size:13px;color:var(--hazard);text-transform:uppercase;letter-spacing:4px;font-family:var(--font-main);font-weight:700;}

button{background:linear-gradient(180deg,rgba(50,50,55,1) 0%,rgba(30,30,35,1) 100%);color:var(--text-primary);border:1px solid rgba(255,255,255,0.1);padding:10px 14px;font-size:12px;border-radius:2px;font-weight:700;text-transform:uppercase;letter-spacing:2px;font-family:var(--font-main);cursor:pointer;transition:all 0.1s;}
button:hover{background:linear-gradient(180deg,rgba(68,68,73,1) 0%,rgba(48,48,53,1) 100%);}
button:active{background:linear-gradient(180deg,#3a3d20 0%,#2a2e14 100%);border-color:var(--hazard);box-shadow:0 0 8px rgba(224,230,42,0.3);}

#shSurvivorList div{background:rgba(18,18,22,0.9);padding:9px 12px;margin-bottom:4px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--panel-border);border-left:3px solid var(--bile);font-family:var(--font-mono);font-size:12px;}
#shSurvivorList button{padding:6px 10px;font-size:10px;}

#wpUI{position:absolute;bottom:20px;right:20px;pointer-events:auto;display:flex;flex-direction:column;align-items:flex-end;}
#wpEta{display:none;background:rgba(0,0,0,0.88);color:var(--hazard);padding:8px 14px;margin-top:8px;border:1px solid rgba(224,230,42,0.25);font-weight:bold;font-family:var(--font-mono);font-size:12px;letter-spacing:2px;}
#wpInfoScreen{display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--panel-bg);padding:20px;border:1px solid var(--panel-border);border-top:2px solid var(--steel-light);pointer-events:auto;flex-direction:column;gap:10px;color:var(--text-primary);width:90%;max-width:360px;border-radius:3px;z-index:90;box-shadow:0 0 40px rgba(0,0,0,0.9);}
#wpInfoScreen label{display:flex;align-items:center;gap:10px;font-size:13px;font-family:var(--font-mono);color:var(--text-dim);}
#wpInfoScreen input[type="range"]{width:100%;margin-top:5px;accent-color:var(--hazard);}

#zoomControls{position:absolute;left:12px;bottom:20px;display:flex;flex-direction:column;gap:6px;pointer-events:auto;z-index:95;}
#zoomControls button{background:rgba(10,10,12,0.9);color:var(--text-primary);border:1px solid rgba(255,255,255,0.12);width:40px;height:40px;font-size:22px;border-radius:2px;font-weight:bold;display:flex;justify-content:center;align-items:center;letter-spacing:0;padding:0;backdrop-filter:blur(4px);}
#zoomControls button:active{background:rgba(28,28,18,0.98);border-color:var(--hazard);}

#survivorStatusPanel{position:absolute;top:45px;left:10px;background:linear-gradient(135deg,rgba(8,8,10,0.97) 0%,rgba(15,15,18,0.97) 100%);padding:7px 14px;border:1px solid var(--panel-border);border-left:3px solid var(--bile);border-radius:2px;display:flex;align-items:center;gap:10px;pointer-events:auto;color:var(--text-primary);white-space:nowrap;z-index:100;font-family:var(--font-mono);font-size:12px;box-shadow:2px 2px 12px rgba(0,0,0,0.7);}
#survivorStatusPanel button{background:rgba(160,0,0,0.85);border-color:rgba(200,0,0,0.3);padding:6px 10px;font-size:10px;}
#btnCharSurv{background:rgba(45,95,28,0.88) !important;border-color:rgba(74,124,47,0.35) !important;}
#btnAggSurv{background:rgba(135,78,18,0.88) !important;color:var(--bone) !important;font-weight:bold;border-color:rgba(180,100,30,0.35) !important;}

#masterPanel{background:var(--panel-bg);color:var(--text-primary);padding:12px;border:1px solid var(--panel-border);border-top:2px solid var(--blood);pointer-events:auto;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:98%;max-width:440px;max-height:95vh;overflow-y:auto;border-radius:3px;display:flex;flex-direction:column;gap:5px;z-index:110;box-shadow:0 0 60px rgba(0,0,0,0.95);}
#masterPanel::-webkit-scrollbar{width:4px;}
#masterPanel::-webkit-scrollbar-track{background:rgba(0,0,0,0.3);}
#masterPanel::-webkit-scrollbar-thumb{background:var(--panel-border);}

.inv-grid{display:grid;gap:2px;background:rgba(5,5,6,0.8);padding:4px;border:1px solid rgba(255,255,255,0.05);overflow-y:auto;}
.inv-slot{background:linear-gradient(135deg,rgba(20,20,24,1) 0%,rgba(14,14,18,1) 100%);border:1px solid rgba(255,255,255,0.07);aspect-ratio:1;position:relative;display:flex;justify-content:center;align-items:center;font-size:9px;text-align:center;word-break:break-word;padding:3px;cursor:pointer;color:var(--text-dim);min-height:36px;transition:all 0.08s;font-family:var(--font-mono);}
.inv-slot:hover{background:linear-gradient(135deg,rgba(32,32,24,1) 0%,rgba(22,22,16,1) 100%);border-color:rgba(224,230,42,0.25);color:var(--text-primary);}
.inv-slot:active{background:rgba(48,48,28,0.9);border-color:var(--hazard);}
.inv-qty{position:absolute;bottom:2px;right:3px;font-size:10px;font-weight:bold;color:var(--hazard);text-shadow:1px 1px 2px #000;font-family:var(--font-mono);}

#paperdoll{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr 1fr;gap:4px;position:relative;margin-bottom:6px;text-align:center;background:rgba(5,5,6,0.5);padding:5px;border:1px solid rgba(255,255,255,0.05);}
#body-silhouette{grid-column:2;grid-row:1 / span 3;font-size:56px;display:flex;align-items:center;justify-content:center;color:rgba(90,90,100,0.45);z-index:1;}
.equip-slot{background:rgba(14,14,18,0.9);border:1px dashed rgba(255,255,255,0.1);border-radius:2px;padding:2px;z-index:2;display:flex;align-items:center;justify-content:center;font-size:8px;color:rgba(107,114,128,0.8);cursor:pointer;min-height:40px;letter-spacing:1px;font-family:var(--font-mono);transition:all 0.1s;}
.equip-slot:hover{border-color:rgba(224,230,42,0.3);}
.equip-slot.filled{border:1px solid rgba(224,230,42,0.4);background:rgba(28,28,18,0.9);color:var(--text-primary);}
#slot-head{grid-column:2;grid-row:1;margin-bottom:auto;}
#slot-chest{grid-column:2;grid-row:2;}
#slot-legs{grid-column:2;grid-row:3;}
#slot-hands{grid-column:1;grid-row:2;}
#slot-feet{grid-column:1;grid-row:3;}
#slot-tool{grid-column:3;grid-row:2;}

#mobileControls{position:absolute;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:999;}
#leftStickBase{position:absolute;bottom:30px;left:30px;width:110px;height:110px;background:rgba(255,255,255,0.05);border:2px solid rgba(255,255,255,0.15);border-radius:50%;pointer-events:auto;touch-action:none;z-index:1000;box-shadow:0 0 20px rgba(0,0,0,0.5);}
#rightStickBase{position:absolute;top:0;left:0;width:100%;height:100%;background:transparent;border:none;pointer-events:auto;touch-action:none;z-index:990;display:none;}
#leftStickKnob{position:absolute;top:50%;left:50%;width:44px;height:44px;background:radial-gradient(circle,rgba(255,255,255,0.5) 0%,rgba(255,255,255,0.2) 100%);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 2px 8px rgba(0,0,0,0.5);}
#rightStickKnob{position:absolute;width:44px;height:44px;background:rgba(255,255,255,0.25);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;display:none;}
#btnShoot,#btnMelee{position:absolute;bottom:170px;right:30px;pointer-events:auto;background:radial-gradient(circle,rgba(210,30,30,0.85) 0%,rgba(140,0,0,0.65) 100%);border:2px solid rgba(255,80,80,0.35);border-radius:50%;width:65px;height:65px;color:#fff;font-size:10px;font-weight:bold;display:flex;justify-content:center;align-items:center;touch-action:none;text-align:center;padding:5px;box-shadow:0 4px 12px rgba(0,0,0,0.7),0 0 18px rgba(210,0,0,0.3);z-index:1000;font-family:var(--font-main);letter-spacing:1px;}
#btnMelee{right:110px;bottom:110px;background:radial-gradient(circle,rgba(170,85,20,0.85) 0%,rgba(110,55,10,0.65) 100%);border-color:rgba(210,125,45,0.35);box-shadow:0 4px 12px rgba(0,0,0,0.7),0 0 18px rgba(170,85,20,0.3);}

#errorConsole{background:rgba(18,0,0,0.98);padding:20px;border:1px solid rgba(255,85,85,0.4);border-top:2px solid #ff5555;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:420px;border-radius:3px;display:flex;flex-direction:column;gap:10px;z-index:9999;pointer-events:auto;}
#errorLog{height:150px;overflow-y:auto;background:rgba(0,0,0,0.8);padding:10px;font-family:var(--font-mono);font-size:11px;color:#ff8888;border:1px solid rgba(255,85,85,0.25);word-wrap:break-word;}

hr{border:none;border-top:1px solid rgba(255,255,255,0.07);margin:4px 0;}
#btnTakeAll{background:linear-gradient(180deg,rgba(58,88,38,0.9) 0%,rgba(38,68,23,0.9) 100%);border-color:rgba(74,124,47,0.45);color:var(--bone);}
#btnCloseMaster{background:linear-gradient(180deg,rgba(95,18,18,0.9) 0%,rgba(65,8,8,0.9) 100%);border-color:rgba(170,28,28,0.35);}
