/* --- RESET & BASES --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:#0a0b0c; --bg-elev:#0f1012; --surface:#111214; --surface-2:#17191c; --surface-3:#1c1f23;
  --border:#1d2024; --border-2:#2a2f36; --text:#e3e6ea; --muted:#7a8190; --muted-2:#a1a8b6;
  --accent:#c8ff00;
  --red:#ff4a4a; --red-bg:#1a0909; --red-border:#582020;
  --orange:#ff9900; --orange-bg:#191100; --orange-border:#5a3600;
  --green:#00db6d; --green-bg:#04170d; --green-border:#0d5a2b;
  --gray:#9aa1ae; --gray-bg:#121417; --gray-border:#2d3138;
  --shadow:0 10px 30px rgba(0,0,0,.28);
  --mono:'Space Mono',monospace; --sans:'DM Sans',sans-serif;
  --nav-h:54px; --bar-h:54px; --section-gap:28px; --radius:8px;
}

html { scroll-behavior: smooth; }
body {
  background: var(--bg); color: var(--text); font-family: var(--sans); font-size: 15px; 
  line-height: 1.5; overflow-x: hidden; -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }

/* --- NAVBAR COMMUNE --- */
#nav {
  position: sticky; top: 0; z-index: 110; height: var(--nav-h); display: flex; 
  align-items: center; gap: 24px; padding: 0 24px; background: rgba(10,11,12,.94); 
  border-bottom: 1px solid var(--border); backdrop-filter: blur(10px);
}
.logo {
  flex-shrink: 0; display: flex; align-items: center; gap: 10px; font-family: var(--mono); 
  font-size: 12px; font-weight: 700; letter-spacing: .12em; color: var(--accent);
}
.logo-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--accent);
  box-shadow: 0 0 10px rgba(200,255,0,.35);
}
.nav-links { display: flex; align-items: center; gap: 4px; }
.nav-a {
  height: var(--nav-h); display: inline-flex; align-items: center; padding: 0 14px; 
  color: var(--muted); border-bottom: 2px solid transparent; font-family: var(--mono); 
  font-size: 10px; letter-spacing: .08em; text-transform: uppercase; transition: 0.14s;
}
.nav-a:hover { color: var(--text); }
.nav-a.active { color: var(--accent); border-bottom-color: var(--accent); }
.nav-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }

/* --- BOUTONS GÉNÉRIQUES --- */
.btn {
  min-height: 38px; padding: 0 14px; border-radius: var(--radius); border: 1px solid var(--border-2); 
  background: var(--surface); color: var(--text); cursor: pointer; font-family: var(--mono); 
  font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; transition: 0.14s;
}
.btn:hover { border-color: var(--accent); }
.btn-primary { background: var(--accent); color: #000; border-color: transparent; }
.btn-ghost { background: transparent; color: var(--muted-2); }

/* --- BADGES --- */
.badge {
  display: inline-flex; align-items: center; justify-content: center; min-height: 24px; 
  padding: 0 8px; border-radius: 999px; border: 1px solid; font-family: var(--mono); 
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
}
.badge-red { color: var(--red); background: var(--red-bg); border-color: var(--red-border); }
.badge-green { color: var(--green); background: var(--green-bg); border-color: var(--green-border); }
.badge-gray { color: var(--gray); background: var(--gray-bg); border-color: var(--gray-border); }
.badge-orange { color: var(--orange); background: var(--orange-bg); border-color: var(--orange-border); }
.badge-outline { background: transparent; }