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

:root {
  --bg: #04030c;
  --txt: #eaf3ff;
  --gris: #7e84b8;
  --rose: #ff2e7e;
  --cyan: #25f4ff;
  --violet: #9b5cff;
  --vert2: #2bffb0;
  --jaune: #ffd23f;
  --bord: rgba(110,150,255,.18);
  --verre: rgba(16,18,40,.5);
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg); color: var(--txt);
  font-family: "Rajdhani","Segoe UI",system-ui,sans-serif; font-size: 16px; line-height: 1.5;
  min-height: 100vh; position: relative; overflow-x: hidden;
}

/* ====== DECOR DE FOND (sci-fi) ====== */
.bg { position: fixed; inset: 0; z-index: -1; overflow: hidden; background:
  radial-gradient(120% 80% at 50% -10%, #0a0a22 0%, #04030c 55%); }
.bg-glow { position: absolute; inset: -25%; filter: blur(40px); opacity: .9; background:
  radial-gradient(28% 36% at 16% 20%, rgba(37,244,255,.28), transparent 60%),
  radial-gradient(30% 40% at 86% 14%, rgba(255,46,126,.26), transparent 60%),
  radial-gradient(36% 44% at 60% 80%, rgba(155,92,255,.22), transparent 60%);
  animation: flot 16s ease-in-out infinite alternate; }
@keyframes flot { 0%{transform:translate(0,0) scale(1)} 100%{transform:translate(-2%,-3%) scale(1.1)} }

/* grille perspective (sol synthwave) */
.bg-grid { position: absolute; left: -50%; right: -50%; bottom: -8%; height: 82vh;
  background-image:
    linear-gradient(rgba(37,244,255,.85) 2px, transparent 2px),
    linear-gradient(90deg, rgba(37,244,255,.6) 2px, transparent 2px);
  background-size: 66px 66px;
  transform: perspective(360px) rotateX(72deg); transform-origin: bottom;
  mask-image: linear-gradient(to top, #000 22%, transparent 92%);
  -webkit-mask-image: linear-gradient(to top, #000 22%, transparent 92%);
  animation: defile 3.2s linear infinite; opacity: .9;
  filter: drop-shadow(0 0 7px rgba(37,244,255,.55)); }
@keyframes defile { from{background-position-y:0} to{background-position-y:66px} }
/* ligne d'horizon qui brille au-dessus de la grille */
.bg::after { content:""; position: absolute; left: 0; right: 0; bottom: 30vh; height: 2px;
  background: linear-gradient(90deg, transparent, var(--cyan) 30%, #fff 50%, var(--rose) 70%, transparent);
  box-shadow: 0 0 24px 4px rgba(37,244,255,.55); opacity: .9; }

/* scanlines + vignette */
body::after { content:""; position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  background: repeating-linear-gradient(to bottom, rgba(0,0,0,0) 0 2px, rgba(0,0,0,.13) 2px 3px);
  mix-blend-mode: overlay; opacity: .35; }

a { color: var(--cyan); text-decoration: none; }
.conteneur { max-width: 1140px; margin: 0 auto; padding: 30px 18px 80px; position: relative; }

/* ====== EN-TETE ====== */
.logo { font-family: "Orbitron",sans-serif; font-weight: 900; font-size: 32px; letter-spacing: 4px;
  background: linear-gradient(92deg, var(--cyan), #fff 45%, var(--rose));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 18px rgba(37,244,255,.5)); }
.logo span { -webkit-text-fill-color: transparent;
  background: linear-gradient(92deg, var(--rose), var(--violet));
  -webkit-background-clip: text; background-clip: text;
  filter: drop-shadow(0 0 18px rgba(255,46,126,.5)); }
.sstitre { color: var(--cyan); font-size: 13px; margin-top: 4px; letter-spacing: 3px;
  text-transform: uppercase; opacity: .85; }

/* ====== CARTES VERRE + coins HUD ====== */
.carte { position: relative; background: var(--verre); border: 1px solid var(--bord);
  border-radius: 18px; padding: 24px; backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 10px 50px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.06),
              inset 0 0 40px rgba(37,244,255,.04); }
.carte::before, .carte::after { content:""; position: absolute; width: 16px; height: 16px; pointer-events: none; }
.carte::before { top: 9px; left: 9px; border-top: 2px solid var(--cyan); border-left: 2px solid var(--cyan);
  border-top-left-radius: 6px; filter: drop-shadow(0 0 6px var(--cyan)); }
.carte::after { bottom: 9px; right: 9px; border-bottom: 2px solid var(--rose); border-right: 2px solid var(--rose);
  border-bottom-right-radius: 6px; filter: drop-shadow(0 0 6px var(--rose)); }

label { display: block; font-size: 11px; color: var(--cyan); margin: 16px 0 6px;
  font-weight: 700; text-transform: uppercase; letter-spacing: 1.4px; }
input, select, textarea { width: 100%; background: rgba(6,8,22,.72); border: 1px solid var(--bord);
  color: var(--txt); border-radius: 12px; padding: 13px 15px; font-size: 16px; font-family: inherit;
  font-weight: 600; outline: none; transition: .18s; }
input::placeholder, textarea::placeholder { color: #54577f; font-weight: 500; }
input:focus, select:focus, textarea:focus { border-color: var(--cyan);
  box-shadow: 0 0 0 3px rgba(37,244,255,.14), 0 0 22px rgba(37,244,255,.25); background: rgba(6,8,28,.92); }
textarea { resize: vertical; min-height: 72px; }
.aide { font-size: 12.5px; color: var(--gris); margin-top: 5px; }
option { background: #0a0c1e; }

/* ====== BOUTONS NEON ====== */
button, .btn { position: relative; background: linear-gradient(92deg, var(--rose), var(--violet));
  color: #fff; border: none; border-radius: 12px; padding: 12px 20px; font-size: 15px; font-weight: 700;
  cursor: pointer; font-family: inherit; letter-spacing: .5px; transition: .18s;
  display: inline-flex; align-items: center; gap: 8px; box-shadow: 0 4px 24px rgba(255,46,126,.4); }
button:hover, .btn:hover { transform: translateY(-2px); box-shadow: 0 8px 34px rgba(255,46,126,.6); }
button:active { transform: translateY(0); }
button.ghost,.btn.ghost { background: rgba(110,150,255,.08); border: 1px solid var(--bord); color: var(--txt); box-shadow: none; }
button.ghost:hover { border-color: var(--cyan); box-shadow: 0 0 18px rgba(37,244,255,.3); }
button.vert { background: linear-gradient(92deg, var(--vert2), #14c98e); box-shadow: 0 4px 24px rgba(43,255,176,.35); color:#022; }
button.gris { background: rgba(110,150,255,.1); border: 1px solid var(--bord); box-shadow: none; }
button.petit { padding: 7px 13px; font-size: 13px; border-radius: 9px; }
button.danger { background: transparent; border: 1px solid rgba(255,46,126,.45); color: #ff6b9d; box-shadow: none; }
button.danger:hover { background: rgba(255,46,126,.14); box-shadow: 0 0 16px rgba(255,46,126,.3); }
button:disabled { opacity: .5; cursor: not-allowed; transform: none; box-shadow: none; }

/* ====== BADGES ====== */
.badge { display: inline-block; padding: 3px 12px; border-radius: 20px; font-size: 12px; font-weight: 700;
  border: 1px solid transparent; letter-spacing: .5px; }
.g-A { background: rgba(255,46,126,.14); color: #ff6b9d; border-color: rgba(255,46,126,.4); box-shadow: 0 0 12px rgba(255,46,126,.2); }
.g-B { background: rgba(37,244,255,.12); color: var(--cyan); border-color: rgba(37,244,255,.4); box-shadow: 0 0 12px rgba(37,244,255,.2); }
.g-C { background: rgba(255,210,63,.14); color: var(--jaune); border-color: rgba(255,210,63,.38); box-shadow: 0 0 12px rgba(255,210,63,.18); }
.g-D { background: rgba(155,92,255,.18); color: #bd9bff; border-color: rgba(155,92,255,.42); box-shadow: 0 0 12px rgba(155,92,255,.2); }
.st-nouveau { color: var(--jaune); } .st-confirme { color: var(--vert2); } .st-inactif { color: var(--gris); }

/* ====== TABLES ====== */
table { width: 100%; border-collapse: collapse; font-size: 14.5px; }
th, td { text-align: left; padding: 12px 9px; border-bottom: 1px solid rgba(110,150,255,.1); }
th { color: var(--cyan); font-size: 11px; text-transform: uppercase; letter-spacing: 1.2px; font-weight: 700; }
tr:hover td { background: rgba(37,244,255,.05); }

/* ====== ONGLETS ====== */
.onglets { display: flex; gap: 9px; margin: 24px 0; flex-wrap: wrap; }
.onglet { background: var(--verre); border: 1px solid var(--bord); color: var(--gris); padding: 11px 22px;
  border-radius: 12px; cursor: pointer; font-weight: 700; font-size: 14.5px; letter-spacing: .4px;
  backdrop-filter: blur(10px); transition: .18s; }
.onglet:hover { color: var(--txt); border-color: var(--cyan); box-shadow: 0 0 16px rgba(37,244,255,.15); }
.onglet.actif { background: linear-gradient(92deg, var(--rose), var(--violet)); color: #fff;
  border-color: transparent; box-shadow: 0 6px 26px rgba(255,46,126,.5); }

/* ====== STATS ====== */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap: 16px; margin: 20px 0; }
.stat { position: relative; background: var(--verre); border: 1px solid var(--bord); border-radius: 16px;
  padding: 20px; backdrop-filter: blur(12px); overflow: hidden;
  box-shadow: inset 0 0 30px rgba(37,244,255,.05); }
.stat::before { content:""; position: absolute; top: -40%; right: -20%; width: 130px; height: 130px;
  background: radial-gradient(circle, rgba(37,244,255,.22), transparent 70%); }
.stat .nb { font-family: "Orbitron",sans-serif; font-size: 32px; font-weight: 900;
  text-shadow: 0 0 22px rgba(37,244,255,.35); }
.stat .lib { color: var(--gris); font-size: 13px; margin-top: 3px; text-transform: uppercase; letter-spacing: .5px; }

.cache { display: none !important; }
.message { padding: 13px 17px; border-radius: 12px; margin: 12px 0; font-weight: 600; }
.message.ok { background: rgba(43,255,176,.12); color: var(--vert2); border: 1px solid rgba(43,255,176,.4); }
.message.err { background: rgba(255,46,126,.12); color: #ff6b9d; border: 1px solid rgba(255,46,126,.4); }
.ligne { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.ligne > * { flex: 1; } .ligne > .auto { flex: 0 0 auto; }
.titre-sec { font-family: "Orbitron",sans-serif; font-size: 16px; font-weight: 700; margin: 8px 0 14px; letter-spacing: .6px; color: #dfe9ff; }
small.muted { color: var(--gris); }

/* scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: rgba(10,12,26,.6); }
::-webkit-scrollbar-thumb { background: linear-gradient(var(--cyan), var(--violet)); border-radius: 10px; }
