:root{
  --navy:#0b1f3a; --navy2:#0f2749;
  --gold:#c8a04d; --muted:#64748b;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:#0b1f3a;
  background:
    radial-gradient(1200px 800px at 70% -10%, #163766 0%, transparent 50%),
    radial-gradient(800px 600px at -10% 60%, #142b51 0%, transparent 50%),
    var(--navy);
  overflow-x:hidden;
}

/* Canvas plein écran derrière */
#particles-bg{
  position:fixed; inset:0; z-index:-1;
  width:100vw; height:100vh; display:block;
  background:
    radial-gradient(1400px 900px at 50% -10%, rgba(232,196,106,.12), transparent 60%),
    linear-gradient(180deg, var(--navy), var(--navy2));
}

/* Layout */
.wrap{min-height:100vh; display:grid; place-items:center; padding:24px}
.card{
  width:min(820px, 92%);
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.18);
  border-radius:22px;
  padding:24px;
  color:#fff;
  box-shadow:0 24px 64px rgba(0,0,0,.45);
  backdrop-filter:saturate(130%) blur(6px);
}

/* Header propre et centré */
.header{
  display:grid;
  grid-template-columns:1fr;
  justify-items:center;
  text-align:center;
  gap:12px;
  margin-bottom:1.25rem;
}
.header .logo{
  /* Taille du logo : plus petit + fluide */
  width: clamp(140px, 22vw, 220px);
  height:auto;
  margin-bottom:.8rem;
  filter: drop-shadow(0 0 16px rgba(200,160,77,.35));
  animation: float 6s ease-in-out infinite;
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.header .name{
  font-size:clamp(1.25rem, 2.6vw, 1.6rem);
  font-weight:800;
  color:#fff;
  letter-spacing:.6px;
}
.header .badge{
  color:#c8a04d;
  font-weight:600;
  font-size:1rem;
  letter-spacing:1.2px;
}

/* Titre (typewriter) */
h1{margin:14px 0 6px; font-size:clamp(26px, 5vw, 42px); letter-spacing:.6px}
.type{
  display:inline-block; border-right:2px solid var(--gold); white-space:nowrap; overflow:hidden;
  animation: typing 2.2s steps(28,end) .2s both, caret .75s step-end infinite
}
@keyframes typing { from {width:0} to {width: 100%} }
@keyframes caret { 50% {border-color: transparent} }

.lead{color:#dbe3ef; opacity:.95; margin:0 0 14px}

/* Grilles optionnelles (si utilisées ailleurs) */
.domains{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:18px}
@media (max-width:900px){ .domains{grid-template-columns:1fr} }
.tile{
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px; padding:18px; min-height:150px;
  transform:translateY(10px); opacity:0;
  transition:transform .6s cubic-bezier(.2,.75,.2,1), opacity .6s ease, border-color .2s ease;
}
.tile.show{transform:none; opacity:1}
.tile h3{margin:0 0 6px; font-size:18px}
.tile p{margin:0; color:#d0d7e2}
.tile:hover{border-color:rgba(255,255,255,.35)}

.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:14px}
@media (max-width:900px){ .stats{grid-template-columns:repeat(2,1fr)} }
.stat{text-align:center; background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05)); border:1px solid rgba(255,255,255,.18); border-radius:14px; padding:14px}
.num{font-weight:800; font-size:28px; color:var(--gold)}

/* Progress */
.progress-wrap{margin-top:18px}
.progress-head{display:flex; justify-content:space-between; color:#e2e8f0; font-size:12px; margin-bottom:6px}
.progress{height:10px; background:rgba(255,255,255,.18); border-radius:999px; overflow:hidden}
.progress > span{display:block; height:100%; background:linear-gradient(90deg, var(--gold), #e8c46a); width:0; animation:grow 1.2s ease forwards}
@keyframes grow{ to { width: 56% } }

/* CTA — bouton pas pleine largeur, centré */
.cta{display:flex; justify-content:center; gap:10px; flex-wrap:wrap; margin-top:12px}
.btn{
  width:auto;                   /* ← corrige le plein écran */
  padding:10px 24px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:10px;
  color:#0b1f3a; background:#fff; font-weight:800; text-decoration:none;
  transition:.25s;
}
.btn:hover{transform:translateY(-2px)}
.btn.outline{background:transparent; color:#fff; border-color:rgba(255,255,255,.28)}

/* Mobile : bouton large mais pas 100% */
@media (max-width:600px){
  .cta .btn{ width: 80%; }
  .header .logo{ width: 160px; } /* logo plus discret sur mobile */
}

/* Footer optionnel */
.footer{display:flex; justify-content:space-between; gap:8px; flex-wrap:wrap; margin-top:18px; color:#cbd5e1}
.footer a{color:#e2e8f0; text-decoration:none}

/* Honeypot (anti-spam, si utilisé dans le HTML) */
.hp-label, .hp{ position:absolute!important; left:-9999px!important; width:1px; height:1px; overflow:hidden }
/* === FIX MOBILE / RESPONSIVE — SYNDRA === */

/* Carte bien centrée et souple */
.wrap{min-height:100vh; display:grid; place-items:center; padding:16px}
.card{margin:0 auto}

/* Logo : plus souple (moins grand sur mobile) */
.header .logo{
  width: clamp(110px, 28vw, 200px);  /* avant: 140–220 => trop grand sur petits écrans */
  height:auto;
}

/* Titre : évite la casse hors cadre */
h1{font-size: clamp(22px, 5.2vw, 36px); line-height: 1.15}

/* Typewriter : NE PAS forcer no-wrap sur mobile (sinon ça déborde) */
@media (max-width: 600px){
  .type{
    white-space: normal;    /* au lieu de nowrap */
    border-right: 0;        /* pas de curseur */
    animation: none;        /* on coupe l’animation en mobile */
  }
}

/* Bouton : ne pas prendre toute la ligne, mais assez large sur mobile */
.cta{display:flex; justify-content:center; gap:10px; margin-top:14px; flex-wrap:wrap}
.cta .btn{width:auto; padding:10px 22px}
@media (max-width: 600px){
  .cta .btn{width: 78%}    /* centré, mais pas plein écran */
}

/* Carte + paddings adaptés au petit écran */
@media (max-width: 600px){
  .card{width: 94%; padding: 18px}
  .progress-head{font-size: 13px}
}

/* Empêche tout débordement horizontal résiduel */
html, body{overflow-x: hidden}
.card, .header, .type{max-width:100%}
/* Fond animé derrière TOUT */
#particles-bg{
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  z-index: -1;             /* derrière la carte */
  pointer-events: none;    /* ne bloque pas les clics */
  background:
    radial-gradient(1400px 900px at 50% -10%, rgba(232,196,106,.12), transparent 60%),
    linear-gradient(180deg, #0b1f3a, #0f2749);  /* fallback si JS off */
}
