/* ============================================================
   AEGIS — Couche PREMIUM (art direction + motion)
   Chargée APRÈS style.css : elle élève, ne casse rien.
   ============================================================ */
:root {
  --ink-2: #c4d2ee;
  --glass: rgba(20, 28, 50, 0.55);
  --glass-brd: rgba(140, 200, 255, 0.18);
  --glow-cyan: 0 0 50px -8px rgba(94, 200, 255, 0.55);
  --glow-gold: 0 0 50px -8px rgba(232, 177, 90, 0.5);
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* Fond : aurore animée + grain subtil (signature, pas le radial générique) */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(60% 50% at 78% 12%, rgba(43,155,255,0.16), transparent 70%),
    radial-gradient(50% 45% at 12% 78%, rgba(232,177,90,0.10), transparent 70%),
    radial-gradient(45% 40% at 50% 50%, rgba(120,90,255,0.06), transparent 70%);
  filter: saturate(1.1);
  animation: aurora 22s var(--ease) infinite alternate;
}
@keyframes aurora {
  0%   { transform: translate3d(0,0,0) scale(1); }
  100% { transform: translate3d(-2%, 1.5%, 0) scale(1.08); }
}
body::after {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: 0.4;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
}

/* ---- Reveal au scroll (piloté par GSAP/IO) ---- */
.reveal { opacity: 0; transform: translateY(26px); }
.reveal.is-in { opacity: 1; transform: none; transition: opacity 0.8s var(--ease), transform 0.8s var(--ease); }
.reveal-stagger > * { opacity: 0; transform: translateY(22px); }

/* ============================================================
   HERO éditorial asymétrique
   ============================================================ */
.hero { padding: 78px 0 44px; position: relative; }
.hero .wrap { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 40px; align-items: center; }
@media (max-width: 940px) { .hero .wrap { grid-template-columns: 1fr; gap: 12px; } .hero-visual { order: -1; } }

.hero h1 {
  font-size: clamp(40px, 5.4vw, 68px); line-height: 0.98; letter-spacing: -1.8px;
  margin: 14px 0 20px; font-weight: 700;
}
.hero h1 .grad {
  background: linear-gradient(108deg, var(--cyan) 10%, var(--gold) 90%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  position: relative;
}
.hero p.lead { font-size: 18.5px; color: var(--ink-2); max-width: 540px; }

/* Bandeau de confiance sous le hero */
.trust-strip { display: flex; gap: 22px; flex-wrap: wrap; margin-top: 26px; padding-top: 22px; border-top: 1px solid var(--border); }
.trust-strip .ts { display: flex; align-items: center; gap: 9px; color: var(--muted); font-size: 13px; }
.trust-strip .ts .ic { color: var(--cyan); }
.trust-strip .ts b { color: var(--ink); font-family: var(--display); }

/* ---- Visuel animé du hero ---- */
.hero-visual { position: relative; display: grid; place-items: center; min-height: 420px; }
.hero-art { width: min(460px, 92%); height: auto; overflow: visible; }
.hero-art .ring { fill: none; stroke: var(--cyan); stroke-width: 1; opacity: 0; transform-origin: 240px 240px; }
.hero-art .grid-circle { fill: none; stroke: rgba(140,200,255,0.10); stroke-width: 1; }
.hero-art .scan { stroke: url(#scanGrad); stroke-width: 2.5; opacity: 0.9; }
.hero-art .shield-fill { fill: url(#heroShield); opacity: 0.16; }
.hero-art .shield-stroke { fill: none; stroke: url(#heroShield); stroke-width: 2; }
.hero-art .chev { fill: none; stroke: url(#heroShield); stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; }
.hero-shield-wrap { filter: drop-shadow(0 0 26px rgba(94,200,255,0.45)); }
.orbit-chip { }
.orbit-chip rect { fill: var(--glass); stroke: var(--glass-brd); stroke-width: 1; }
.orbit-chip .ic { color: var(--cyan); }
.orbit-chip.gold .ic { color: var(--gold); }
.orbit-chip text { fill: var(--ink-2); font-family: var(--display); font-size: 11px; font-weight: 500; }
.verified-pop { transform-origin: 240px 372px; }
.verified-pop circle { fill: rgba(47,224,166,0.16); stroke: var(--green); stroke-width: 1.5; }
.verified-pop path { fill: none; stroke: var(--green); stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; }

/* ============================================================
   Composants élevés (glass, glow, depth)
   ============================================================ */
.card {
  background: var(--glass); backdrop-filter: blur(16px) saturate(1.2);
  border: 1px solid var(--glass-brd); transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease), border-color 0.4s var(--ease);
}
.card:hover { transform: translateY(-4px); border-color: var(--border-strong); box-shadow: var(--glow-cyan); }

/* Boutons : brillance + profondeur */
.btn { position: relative; overflow: hidden; transition: transform 0.25s var(--ease), box-shadow 0.25s var(--ease); }
.btn.primary { box-shadow: 0 14px 34px -12px rgba(43,184,255,0.6), inset 0 1px 0 rgba(255,255,255,0.25); }
.btn.primary::after {
  content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.35) 50%, transparent 70%);
  transform: translateX(-120%); transition: transform 0.7s var(--ease);
}
.btn.primary:hover::after { transform: translateX(120%); }
.btn:hover { transform: translateY(-2px); }

/* Piliers : bordure dégradée animée + glow par couleur */
.pillar { transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease); }
.pillar::before { height: 100%; width: 3px; inset: 0 auto 0 0; opacity: 0.8; }
.pillar:hover { transform: translateY(-6px); }
.p-ia:hover { box-shadow: 0 22px 50px -22px rgba(94,200,255,0.6); }
.p-cyber:hover { box-shadow: 0 22px 50px -22px rgba(232,177,90,0.55); }
.p-block:hover { box-shadow: 0 22px 50px -22px rgba(255,182,72,0.5); }
.p-data:hover { box-shadow: 0 22px 50px -22px rgba(47,224,166,0.5); }
.pillar .pico { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center;
  background: rgba(94,200,255,0.08); border: 1px solid var(--glass-brd); margin-bottom: 14px; }
.p-cyber .pico { background: rgba(232,177,90,0.08); }
.p-block .pico { background: rgba(255,182,72,0.08); }
.p-data .pico { background: rgba(47,224,166,0.08); }

/* Stats : chiffres animés + glow */
.stat { position: relative; overflow: hidden; }
.stat .n { font-size: 38px; letter-spacing: -1px; }
.stat::after { content: ""; position: absolute; right: -30px; top: -30px; width: 90px; height: 90px; border-radius: 50%;
  background: radial-gradient(circle, rgba(94,200,255,0.12), transparent 70%); }

/* Flow : connecteurs lumineux + hover */
.flow-step { transition: transform 0.35s var(--ease), border-color 0.35s var(--ease); }
.flow-step:hover { transform: translateY(-4px); border-color: var(--border-strong); }
.flow-arrow { color: var(--cyan); opacity: 0.5; }

/* Score ring (SVG) pour les passeports */
.score-ring-svg { transform: rotate(-90deg); }
.score-ring-svg .track { fill: none; stroke: var(--panel-solid); stroke-width: 9; }
.score-ring-svg .prog { fill: none; stroke-width: 9; stroke-linecap: round; transition: stroke-dashoffset 1.1s var(--ease); }

/* Titres de section : compteur + filet */
.section > .wrap > h2 { font-size: clamp(24px, 3vw, 32px); }

/* En-tête sticky : verre + bord lumineux au scroll */
.topbar { transition: background 0.3s, box-shadow 0.3s, border-color 0.3s; }
.topbar.scrolled { box-shadow: 0 10px 40px -20px rgba(0,0,0,0.8); border-bottom-color: var(--border-strong); }
.logo-mark { transition: transform 0.5s var(--ease); }
.brand:hover .logo-mark { transform: rotate(-8deg) scale(1.06); }

/* Badge live (pour la démo) */
.live-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--green);
  box-shadow: 0 0 0 0 rgba(47,224,166,0.7); animation: pulse 2s infinite; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(47,224,166,0.6)} 70%{box-shadow:0 0 0 9px rgba(47,224,166,0)} 100%{box-shadow:0 0 0 0 rgba(47,224,166,0)} }

@media (prefers-reduced-motion: reduce) {
  *, body::before { animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
}

/* ====================================================================== */
/*  Console d'intégration (/integrations)                                  */
/* ====================================================================== */
.block-title { font-size: 19px; font-weight: 700; letter-spacing: -0.3px; color: var(--ink); }

.btn-sm { padding: 8px 13px; font-size: 13px; border-radius: 9px; }
.btn.ghost.danger { color: #ffb4b4; border-color: rgba(255,120,120,.32); }
.btn.ghost.danger:hover { border-color: #ff8e8e; color: #fff; box-shadow: 0 10px 26px -12px rgba(255,90,90,.7); }

/* Clé API */
.key-row { display: flex; flex-wrap: wrap; align-items: center; gap: 9px; }
.key-mono {
  flex: 1 1 320px; min-width: 0; font-family: var(--mono); font-size: 13.5px;
  background: var(--bg); border: 1px solid var(--border); border-radius: 10px;
  padding: 11px 14px; color: var(--cyan); letter-spacing: .3px; overflow-x: auto; white-space: nowrap;
}

/* Onglets quickstart */
.tabbar { display: flex; gap: 4px; border-bottom: 1px solid var(--border); margin-bottom: 0; flex-wrap: wrap; }
.tab {
  background: transparent; border: 0; color: var(--muted); cursor: pointer;
  padding: 10px 16px; font-size: 13.5px; font-weight: 600; border-radius: 9px 9px 0 0;
  border-bottom: 2px solid transparent; transition: .18s;
}
.tab:hover { color: var(--ink); }
.tab.is-active { color: var(--cyan); border-bottom-color: var(--cyan); background: rgba(94,200,255,.06); }
.tabpane { display: none; }
.tabpane.is-active { display: block; }

/* Blocs de code */
.code { position: relative; margin-top: 12px; }
.code pre {
  margin: 0; background: var(--panel-solid); border: 1px solid var(--border);
  border-radius: 12px; padding: 16px 18px; overflow-x: auto;
}
.code code, .mini code { font-family: var(--mono); font-size: 12.8px; line-height: 1.65; color: #cfe1ff; }
.copy-btn {
  position: absolute; top: 9px; right: 9px; z-index: 2;
  background: rgba(94,200,255,.1); color: var(--cyan); border: 1px solid var(--border-strong);
  border-radius: 7px; padding: 4px 10px; font-size: 11px; cursor: pointer; transition: .18s;
}
.copy-btn:hover { background: rgba(94,200,255,.2); color: #fff; }
.copy-btn.ok { color: #6ee7a8; border-color: rgba(110,231,168,.5); }
code { font-family: var(--mono); color: #bcd7ff; background: rgba(94,200,255,.08); padding: 1px 6px; border-radius: 5px; font-size: .92em; }
pre code { background: none; padding: 0; }

/* Table des endpoints */
.api-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.api-table th { text-align: left; padding: 12px 16px; color: var(--muted); font-weight: 600;
  font-size: 11.5px; letter-spacing: .08em; text-transform: uppercase; border-bottom: 1px solid var(--border); }
.api-table td { padding: 11px 16px; border-bottom: 1px solid var(--border); color: var(--ink); }
.api-table tr:last-child td { border-bottom: 0; }
.api-table tr:hover td { background: rgba(94,200,255,.04); }
.api-table code { background: none; padding: 0; color: var(--cyan); }
.m { font-family: var(--mono); font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 6px; }
.m.get { color: #6ee7a8; background: rgba(110,231,168,.12); }
.m.post { color: var(--gold); background: rgba(232,177,90,.14); }

/* Cartes outils */
.tool-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 16px; }
.tool { display: flex; flex-direction: column; gap: 8px; }
.tool h3 { margin: 4px 0 0; font-size: 16px; }
.tool .mini { margin: 4px 0 10px; background: var(--bg); border: 1px solid var(--border);
  border-radius: 9px; padding: 11px 13px; overflow-x: auto; }
.tool .btn { align-self: flex-start; margin-top: 2px; }

/* ====================================================================== */
/*  Sécurité : SSO, MFA, codes de secours (/login, /security)             */
/* ====================================================================== */
.sso-sep { display:flex; align-items:center; gap:12px; margin:20px 0 14px; color:var(--muted); font-size:12px; }
.sso-sep::before, .sso-sep::after { content:""; flex:1; height:1px; background:var(--border); }
.sso-row { display:flex; gap:10px; }
.sso-btn { flex:1; justify-content:center; gap:9px; padding:10px 12px; font-size:13.5px; }
.sso-ic { width:18px; height:18px; flex:none; }

.pill-on { margin-left:auto; color:#6ee7a8; background:rgba(110,231,168,.12); border:1px solid rgba(110,231,168,.35);
  padding:3px 11px; border-radius:999px; font-size:12px; font-weight:600; }
.pill-off { margin-left:auto; color:var(--muted); background:rgba(138,155,189,.1); border:1px solid var(--border);
  padding:3px 11px; border-radius:999px; font-size:12px; font-weight:600; }

.enroll-row { display:flex; gap:22px; flex-wrap:wrap; align-items:flex-start; margin-top:6px; }
.enroll-qr { border-radius:12px; border:1px solid var(--border); background:#0b1020; flex:none; }

.backup-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(130px,1fr)); gap:9px; }
.backup-code { font-family:var(--mono); font-size:14px; letter-spacing:.06em; text-align:center;
  background:var(--bg); border:1px solid var(--border-strong); border-radius:9px; padding:9px 6px; color:var(--cyan); }

.sec-actions { display:flex; flex-direction:column; gap:12px; }
.sec-form { display:flex; align-items:center; gap:10px; flex-wrap:wrap; padding:12px 14px;
  background:var(--panel-solid); border:1px solid var(--border); border-radius:11px; }
.sec-form .muted { flex:1 1 220px; }
.sec-form input { width:150px; font-family:var(--mono); font-size:13px; color:var(--ink);
  background:var(--bg); border:1px solid var(--border); border-radius:8px; padding:8px 10px; text-align:center; }
.sec-form .btn { flex:none; }

.sec-list { margin:0; padding-left:20px; color:var(--muted); font-size:13.5px; line-height:1.85; }
.sec-list b { color:var(--ink); }
