:root{
  --blue:#3b82f6; --red:#ef4444; --bg:#0b0f17; --panel:#141b29;
  --accent:#f59e0b; --txt:#e6edf6; --muted:#8a98ad;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;width:100%;overflow:hidden;background:var(--bg);color:var(--txt);
  font-family:'Segoe UI',system-ui,-apple-system,Roboto,sans-serif;user-select:none}

.screen{position:fixed;inset:0;display:none;align-items:center;justify-content:center;flex-direction:column}
.screen.active{display:flex}

/* ---------- MENU ---------- */
#menu,#settings{
  background:radial-gradient(1200px 600px at 50% -10%, #1b2840 0%, var(--bg) 60%);
  overflow-y:auto;padding:24px;
}
.logo{font-size:64px;font-weight:900;letter-spacing:8px;
  background:linear-gradient(90deg,var(--blue),var(--accent),var(--red));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 40px rgba(245,158,11,.2);margin-bottom:6px}
.tagline{color:var(--muted);margin-bottom:24px;text-align:center}

.panel{background:rgba(20,27,41,.92);border:1px solid #243047;border-radius:16px;
  padding:24px;width:min(520px,94vw);box-shadow:0 20px 60px rgba(0,0,0,.5);
  backdrop-filter:blur(6px)}
.panel h2{margin-bottom:16px}

.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field>span{font-size:13px;color:var(--muted);font-weight:600}
.field.row{flex-direction:row;align-items:center;gap:10px}
.field b{color:var(--accent);font-weight:700}
input[type=text]{background:#0e1420;border:1px solid #2a3852;border-radius:10px;
  padding:12px 14px;color:var(--txt);font-size:15px;outline:none}
input[type=text]:focus{border-color:var(--blue)}
input[type=range]{width:100%;accent-color:var(--accent)}
input[type=checkbox]{width:18px;height:18px;accent-color:var(--blue)}

.mode-select{display:flex;gap:12px}
.mode-card{flex:1;background:#0e1420;border:2px solid #2a3852;border-radius:12px;
  padding:14px;cursor:pointer;color:var(--txt);transition:.15s;text-align:center}
.mode-card:hover{border-color:#3a4a68;transform:translateY(-2px)}
.mode-card.active{border-color:var(--accent);background:#1a2236}
.mode-ico{font-size:30px}
.mode-name{font-weight:800;margin-top:4px}
.mode-map{font-size:12px;color:var(--muted)}

.role-select{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.role-card{background:#0e1420;border:2px solid #2a3852;border-radius:10px;padding:10px;
  cursor:pointer;color:var(--txt);transition:.15s;text-align:left}
.role-card:hover{border-color:#3a4a68}
.role-card.active{border-color:var(--blue);background:#16203a}
.role-card .rn{font-weight:700}
.role-card .rs{font-size:11px;color:var(--muted)}
.role-desc{font-size:12px;color:var(--muted);min-height:16px;margin-top:4px}

.btn-primary,.btn-secondary{width:100%;padding:14px;border:none;border-radius:10px;
  font-size:16px;font-weight:800;cursor:pointer;margin-top:6px;transition:.15s}
.btn-primary{background:linear-gradient(90deg,var(--blue),var(--accent));color:#08111f}
.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px)}
.btn-secondary{background:#1a2236;color:var(--txt);border:1px solid #2a3852}
.btn-secondary:hover{background:#212c44}
.hint{margin-top:18px;color:var(--muted);font-size:12px;text-align:center;max-width:600px}

/* ---------- JEU / HUD ---------- */
#canvas{position:fixed;inset:0;width:100%;height:100%;display:block}
#hud{position:fixed;inset:0;pointer-events:none;font-weight:600}

#crosshair{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:22px;color:#fff;text-shadow:0 0 4px #000;opacity:.85}

#topbar{position:absolute;top:14px;left:50%;transform:translateX(-50%);
  display:flex;gap:24px;align-items:center;background:rgba(8,12,20,.6);
  padding:8px 18px;border-radius:30px;border:1px solid #243047}
.score{display:flex;align-items:center;gap:6px;font-size:18px}
.score b{font-size:22px}
.score .dot{width:12px;height:12px;border-radius:50%}
.score-A .dot{background:var(--blue)} .score-B .dot{background:var(--red)}
.mode-label{color:var(--accent);font-size:13px;letter-spacing:1px;text-transform:uppercase}

#killfeed{position:absolute;top:60px;right:14px;display:flex;flex-direction:column;
  gap:4px;align-items:flex-end;font-size:13px}
.kf{background:rgba(8,12,20,.65);padding:4px 10px;border-radius:6px;animation:fade 4s forwards}
.kf .a{font-weight:800}.kf .tA{color:var(--blue)}.kf .tB{color:var(--red)}
@keyframes fade{0%,80%{opacity:1}100%{opacity:0}}

#bottomleft{position:absolute;left:18px;bottom:18px}
#hpbar{position:relative;width:240px;height:26px;background:rgba(8,12,20,.7);
  border:1px solid #243047;border-radius:6px;overflow:hidden}
#hpfill{height:100%;width:100%;background:linear-gradient(90deg,#16a34a,#22c55e);transition:width .15s}
#hpText{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-weight:800;text-shadow:0 0 3px #000}
#roleTag{margin-top:8px;color:var(--accent);font-size:14px;text-transform:uppercase;letter-spacing:1px}

#weaponPanel{position:absolute;right:18px;bottom:18px;display:flex;flex-direction:column;gap:6px}
.weap{background:rgba(8,12,20,.7);border:1px solid #243047;border-radius:8px;
  padding:8px 14px;min-width:160px;text-align:right;font-size:14px;color:var(--muted)}
.weap.active{border-color:var(--accent);color:var(--txt);background:#1a2236}
.weap .wk{color:var(--accent);font-weight:800;margin-right:8px}

#fpsmeter{position:absolute;top:14px;left:14px;font-size:12px;color:var(--muted);
  background:rgba(8,12,20,.5);padding:3px 8px;border-radius:6px}

#minimap{position:absolute;top:14px;right:14px;background:rgba(8,12,20,.6);
  border:1px solid #243047;border-radius:10px}

.overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(5,8,14,.72);pointer-events:auto;z-index:5}
.overlay.hidden{display:none}
.dead-box,.round-box{text-align:center}
.dead-box h2{font-size:40px;color:var(--red);margin-bottom:8px}
.round-box h1{font-size:64px;margin-bottom:8px}
.round-box.win h1{color:#22c55e}.round-box.lose h1{color:var(--red)}

#scoreboard .sb-box{display:flex;gap:30px;background:var(--panel);
  padding:24px;border-radius:14px;border:1px solid #243047}
.sb-team{min-width:280px}
.sb-team h3{margin-bottom:10px}
.sb-A h3{color:var(--blue)}.sb-B h3{color:var(--red)}
.sb-team table{width:100%;border-collapse:collapse;font-size:14px}
.sb-team td{padding:5px 8px;border-bottom:1px solid #1d2738}
.sb-team td:nth-child(2),.sb-team td:nth-child(3){text-align:right;color:var(--muted)}

#pause{z-index:10}
#pause .panel{width:min(360px,90vw)}
