*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:          oklch(97.5% 0.005 145);
  --bg-alt:      oklch(94%   0.010 145);
  --bg-dark:     oklch(18%   0.028 145);
  --bg-darkest:  oklch(12%   0.018 145);
  --text-1:      oklch(14%   0.022 145);
  --text-2:      oklch(42%   0.028 145);
  --text-3:      oklch(62%   0.018 145);
  --text-inv:    oklch(97%   0.004 145);
  --text-inv-2:  oklch(72%   0.018 145);
  --accent:      oklch(37%   0.090 145);
  --accent-lite: oklch(92%   0.030 145);
  --accent-mid:  oklch(55%   0.100 145);
  --cta:         oklch(50%   0.115 145);
  --cta-hover:   oklch(43%   0.095 145);
  --amber:       oklch(73%   0.170  52);
  --amber-dim:   oklch(58%   0.140  52);
  --amber-bg:    oklch(96%   0.040  70);
  --border:      oklch(88%   0.012 145);
  --border-mid:  oklch(80%   0.018 145);
  --r-sm: 6px; --r-md: 10px; --r-lg: 16px; --r-xl: 22px;
  --sh-sm: 0 1px 3px oklch(0% 0 0/.06),0 1px 2px oklch(0% 0 0/.04);
  --sh-md: 0 4px 14px oklch(0% 0 0/.08);
  --sh-lg: 0 12px 36px oklch(0% 0 0/.10);
}

html { scroll-behavior: smooth; }
body { font-family:'Inter',sans-serif; color:var(--text-1); background:var(--bg); line-height:1.6; -webkit-font-smoothing:antialiased; }

/* ── ANNOUNCE BANNER ── */
.announce-banner {
  position:fixed; top:0; left:0; right:0; z-index:200;
  background:var(--bg-darkest); height:38px;
  display:flex; align-items:center;
  transition:transform .3s ease, opacity .3s ease;
}
.announce-banner.dismissed { transform:translateY(-100%); opacity:0; pointer-events:none; }
.announce-inner {
  max-width:1200px; margin:0 auto; padding:0 24px;
  display:flex; align-items:center; gap:12px; width:100%;
}
.announce-badge {
  background:var(--amber); color:oklch(20% 0.06 52);
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; padding:2px 8px; border-radius:999px; flex-shrink:0;
}
.announce-text-wrap { flex:1; position:relative; height:38px; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.announce-text {
  position:absolute; width:100%; font-size:13px; text-align:center; color:var(--text-inv-2); line-height:1;
  opacity:0; transition:opacity .5s ease;
}
.announce-text--active { opacity:1; }
.announce-text strong { color:var(--text-inv); font-weight:600; }
.announce-link {
  color:var(--amber); text-decoration:none; font-weight:600;
  margin-left:8px; transition:opacity .2s;
}
.announce-link:hover { opacity:.8; }
.announce-close {
  background:none; border:none; color:var(--text-inv-2);
  font-size:20px; line-height:1; cursor:pointer; padding:0 4px;
  flex-shrink:0; transition:color .2s;
}
.announce-close:hover { color:var(--text-inv); }
.has-banner nav { top:38px; }
@media(max-width:600px) { .announce-link { display:none; } }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:var(--bg); border-bottom:1px solid var(--border);
  transition:box-shadow .3s;
}
nav.scrolled { box-shadow:var(--sh-md); }
.nav-inner {
  max-width:1200px; margin:0 auto; padding:0 24px;
  height:64px; display:flex; align-items:center; justify-content:space-between;
}
.nav-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.nav-logo-mark { width:34px; height:34px; border-radius:8px; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.nav-logo-mark img { width:100%; height:100%; object-fit:contain; }
.nav-logo-text { font-family:'Sora',sans-serif; font-weight:700; font-size:18px; color:var(--text-1); }
.nav-logo-text span { color:var(--accent); }
.nav-links { display:flex; align-items:center; gap:28px; list-style:none; }
.nav-links a { color:var(--text-2); text-decoration:none; font-size:14px; font-weight:500; transition:color .2s; }
.nav-links a:hover { color:var(--text-1); }
.nav-cta {
  background:var(--cta) !important; color:var(--text-inv) !important;
  padding:8px 18px; border-radius:var(--r-md); font-weight:600 !important;
  transition:background .2s !important;
}
.nav-cta:hover { background:var(--cta-hover) !important; color:var(--text-inv) !important; }

/* ── HERO ── */
.hero { min-height:100vh; padding:120px 24px 96px; background:transparent; position:relative; overflow:hidden; }
#particles-js {
  position:absolute; inset:0; z-index:0;
  background:linear-gradient(135deg, oklch(97.5% 0.005 145) 0%, oklch(93% 0.018 145) 60%, oklch(96% 0.010 155) 100%);
}
#particles-js canvas { display:block; }
.hero-inner {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;
  position:relative; z-index:1;
}
.hero-tag {
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  color:var(--accent); margin-bottom:24px;
}
.hero-tag::before {
  content:''; width:6px; height:6px; background:var(--amber); border-radius:50%;
  animation:tagPulse 2.5s ease-in-out infinite;
}
@keyframes tagPulse {
  0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.5)}
}
.hero h1 {
  font-family:'Sora',sans-serif; font-size:clamp(38px,4.5vw,60px);
  font-weight:800; line-height:1.08; color:var(--text-1); margin-bottom:20px;
}
.hero-sub { font-size:18px; color:var(--text-2); line-height:1.7; margin-bottom:36px; max-width:520px; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:28px; }
.hero-proof {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
  font-size:14px; color:var(--text-2); margin-bottom:18px;
}
.hero-proof strong { color:var(--text-1); font-weight:700; }
.proof-sep { color:var(--border-mid); }
.hero-trust { display:flex; gap:20px; flex-wrap:wrap; font-size:12px; color:var(--text-3); }

/* Hero visual */
.hero-visual { display:flex; flex-direction:column; gap:12px; }
.hero-app-card {
  background:var(--bg); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:24px; box-shadow:var(--sh-lg);
}
.hero-app-header {
  display:flex; align-items:center; gap:8px;
  margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid var(--border);
}
.hero-live-dot {
  width:7px; height:7px; background:var(--amber); border-radius:50%;
  animation:livePulse 2.5s ease-in-out infinite;
}
@keyframes livePulse {
  0%,100%{box-shadow:0 0 0 0 oklch(73% 0.17 52/.5)}
  50%    {box-shadow:0 0 0 5px oklch(73% 0.17 52/0)}
}
.hero-app-name { font-size:12px; font-weight:600; color:var(--text-2); flex:1; }
.hero-app-status { font-size:11px; color:var(--text-3); }
.hero-score-row { display:flex; align-items:flex-end; gap:16px; margin-bottom:12px; }
.hero-score-num { font-family:'Sora',sans-serif; font-size:44px; font-weight:800; line-height:1; color:var(--text-1); }
.hero-score-slash { font-size:18px; color:var(--text-3); }
.hero-score-meta { padding-bottom:4px; }
.hero-score-pill {
  display:inline-block; background:var(--accent-lite); color:var(--accent);
  font-size:10px; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
  padding:3px 10px; border-radius:100px; margin-bottom:4px;
}
.hero-score-trend { font-size:12px; color:var(--accent-mid); }
.hero-score-bar { height:5px; background:var(--border); border-radius:100px; overflow:hidden; margin-bottom:16px; }
.hero-score-fill {
  height:100%; width:82%; background:var(--accent-mid); border-radius:100px;
  animation:barGrow 1.4s cubic-bezier(.16,1,.3,1) both;
}
@keyframes barGrow { from{width:0} to{width:82%} }
.hero-card-row {
  display:flex; align-items:center; gap:12px;
  padding:9px 0; border-bottom:1px solid var(--border);
}
.hero-card-row:last-child { border-bottom:none; }
.hero-card-icon { width:30px; height:30px; border-radius:7px; display:flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; }
.icon-sage  { background:var(--accent-lite); }
.icon-amber { background:var(--amber-bg); }
.hero-card-label { color:var(--text-1); font-size:13.5px; }
.hero-card-badge { margin-left:auto; font-size:11px; font-weight:600; padding:3px 8px; border-radius:100px; }
.badge-sage  { background:var(--accent-lite); color:var(--accent); }
.badge-amber { background:var(--amber-bg); color:var(--amber-dim); }
.hero-ai-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--accent-lite); border:1px solid var(--border);
  border-radius:100px; padding:8px 16px; font-size:13px; color:var(--text-2);
  align-self:flex-start;
}
.hero-ai-badge strong { color:var(--accent); }

/* ── BOUTONS ── */
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--cta); color:var(--text-inv);
  padding:13px 26px; border-radius:var(--r-md);
  font-size:15px; font-weight:600; text-decoration:none;
  transition:background .2s,transform .2s;
  position:relative; overflow:hidden;
}
.btn-primary::after {
  content:''; position:absolute; top:0; left:-120%; width:55%; height:100%;
  background:linear-gradient(90deg,transparent,oklch(100% 0 0/.22),transparent);
  transform:skewX(-20deg); pointer-events:none;
  transition:left .55s cubic-bezier(.16,1,.3,1);
}
.btn-primary:hover::after { left:170%; }
.btn-primary:hover { background:var(--cta-hover); transform:translateY(-1px); }
.btn-secondary {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; border:1.5px solid var(--border-mid); color:var(--text-1);
  padding:12px 24px; border-radius:var(--r-md);
  font-size:15px; font-weight:600; text-decoration:none;
  transition:border-color .2s,background .2s;
}
.btn-secondary:hover { border-color:var(--accent); background:var(--accent-lite); }

/* ── BASE SECTIONS ── */
section { padding:100px 24px; }
.container { max-width:1200px; margin:0 auto; }
.section-eyebrow {
  display:inline-block; font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em; color:var(--accent-mid); margin-bottom:14px;
}
.section-title {
  font-family:'Sora',sans-serif; font-size:clamp(28px,3vw,42px);
  font-weight:800; color:var(--text-1); line-height:1.12; margin-bottom:16px;
}
.section-sub { font-size:17px; color:var(--text-2); line-height:1.7; max-width:600px; }
.section-header { margin-bottom:64px; }
.section-header.center { text-align:center; }
.section-header.center .section-sub { margin:0 auto; }

/* ── DARK SECTIONS ── */
.dark-section { background:var(--bg-dark); }
.dark-section .section-eyebrow { color:var(--amber); }
.dark-section .section-title { color:var(--text-inv); }
.dark-section .section-sub { color:var(--text-inv-2); }

/* ── CONSTAT ── */
.constat-inner { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
.problem-list { list-style:none; display:flex; flex-direction:column; gap:24px; margin-top:8px; }
.problem-item { display:flex; gap:20px; align-items:flex-start; }
.problem-num { font-family:'Sora',sans-serif; font-size:11px; font-weight:800; color:var(--amber); letter-spacing:.06em; min-width:22px; padding-top:3px; }
.problem-text { font-size:15px; color:var(--text-inv-2); line-height:1.55; }
.solution-head { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--amber); margin-bottom:20px; }
.solution-title { font-family:'Sora',sans-serif; font-size:24px; font-weight:800; color:var(--text-inv); margin-bottom:28px; line-height:1.2; }
.solution-list { list-style:none; display:flex; flex-direction:column; gap:16px; }
.solution-item { display:flex; gap:14px; align-items:flex-start; font-size:15px; color:var(--text-inv-2); line-height:1.55; }
.check-mark {
  width:20px; height:20px; background:var(--accent-mid); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; margin-top:1px; font-size:11px; color:var(--text-inv); font-weight:700;
}

/* ── FEATURES ── */
.features { background:var(--bg); }
.features-table-wrap {
  border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden;
}
.features-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--border);
}
.feature-item { background:var(--bg); padding:28px 24px; transition:background .2s; }
.feature-item:hover { background:var(--accent-lite); transform:translateY(-3px); }
.feature-item.feature-new { background:var(--amber-bg); position:relative; }
.feature-item.feature-new:hover { background:oklch(94% 0.05 70); }
.feature-icon { font-size:24px; margin-bottom:14px; display:block; }
.feature-name { font-family:'Sora',sans-serif; font-size:15px; font-weight:700; color:var(--text-1); margin-bottom:8px; }
.feature-desc { font-size:13.5px; color:var(--text-2); line-height:1.6; }
.feature-new-badge {
  position:absolute; top:14px; right:14px;
  font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.07em;
  background:var(--amber); color:var(--bg-dark); padding:3px 10px; border-radius:100px;
}

/* ── CONFORMITÉ ── */
.conformite { background:var(--bg-alt); }
.conform-list { display:flex; flex-direction:column; margin-top:56px; border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; }
.conform-item {
  display:grid; grid-template-columns:52px 1fr; gap:24px; align-items:start;
  padding:28px 32px; background:var(--bg); border-bottom:1px solid var(--border);
  transition:background .2s, transform .22s cubic-bezier(.16,1,.3,1);
}
.conform-item:last-child { border-bottom:none; }
.conform-item:hover { background:var(--accent-lite); transform:translateX(5px); }
.conform-num { font-family:'Sora',sans-serif; font-size:22px; font-weight:800; color:var(--amber); line-height:1; padding-top:3px; }
.conform-title { font-size:15px; font-weight:700; color:var(--text-1); margin-bottom:6px; }
.conform-desc { font-size:14px; color:var(--text-2); line-height:1.6; }

/* ── ARIA ── */
.ia-section { background:var(--bg-dark); }
.ia-inner { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.ia-visual-card { background:var(--bg-alt); border-radius:var(--r-xl); padding:32px; box-shadow:var(--sh-lg); }
.ia-chat { display:flex; flex-direction:column; gap:12px; }
.ia-msg { border-radius:12px; padding:12px 16px; font-size:13.5px; line-height:1.5; max-width:85%; }
.ia-msg-user { background:var(--border); color:var(--text-1); align-self:flex-end; }
.ia-msg-ai { background:var(--bg); border:1px solid var(--border); color:var(--text-1); align-self:flex-start; }
.ia-msg-ai-label { font-size:10px; font-weight:700; color:var(--accent-mid); text-transform:uppercase; letter-spacing:.06em; margin-bottom:6px; }
.ia-points { list-style:none; margin-top:32px; display:flex; flex-direction:column; gap:24px; }
.ia-point { display:flex; gap:16px; align-items:flex-start; }
.ia-point-icon {
  width:36px; height:36px; background:oklch(25% 0.04 145);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  font-size:16px; flex-shrink:0;
}
.ia-point-title { font-weight:600; color:var(--text-inv); margin-bottom:4px; font-size:14.5px; }
.ia-point-desc { font-size:13.5px; color:var(--text-inv-2); line-height:1.55; }
.ia-native-badge {
  display:inline-flex; align-items:center; gap:8px; margin-top:28px;
  background:oklch(24% 0.04 145); border:1px solid oklch(30% 0.05 145);
  border-radius:100px; padding:8px 16px; font-size:13px; color:var(--text-inv-2);
}
.ia-native-badge strong { color:var(--text-inv); }
.ia-native-dot { width:7px; height:7px; background:var(--amber); border-radius:50%; flex-shrink:0; }

/* ── TRAJECTOIRE ── */
.trajectoire { background:var(--bg); }
.trajectoire-inner { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.score-widget { background:var(--bg-alt); border:1px solid var(--border); border-radius:var(--r-xl); padding:36px; }
.score-main { display:flex; align-items:flex-end; gap:16px; margin-bottom:16px; }
.score-number { font-family:'Sora',sans-serif; font-size:72px; font-weight:800; line-height:1; color:var(--text-1); }
.score-number span { font-size:28px; color:var(--text-3); font-weight:400; }
.score-meta { padding-bottom:8px; }
.score-level { display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border-radius:100px; font-size:11px; font-weight:800; letter-spacing:.07em; text-transform:uppercase; margin-bottom:6px; }
.level-solide { background:var(--accent-lite); color:var(--accent); }
.score-trend { font-size:13px; color:var(--text-2); }
.score-trend strong { color:var(--accent); }
.score-bar-wrap { margin-bottom:20px; }
.score-bar-track { height:7px; background:var(--border); border-radius:100px; overflow:hidden; }
.score-bar-fill { height:100%; width:0%; background:var(--accent-mid); border-radius:100px; transition:width 1.5s cubic-bezier(.16,1,.3,1); }
.score-sparkline { margin-bottom:20px; }
.score-sparkline svg { width:100%; display:block; }
.score-insight {
  background:var(--bg); border:1px solid var(--border); border-radius:var(--r-sm);
  padding:12px 14px; font-size:13px; color:var(--text-2);
  display:flex; align-items:center; gap:10px; margin-bottom:16px;
}
.score-details { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.score-detail-item { background:var(--bg); border:1px solid var(--border); border-radius:var(--r-sm); padding:10px 8px; text-align:center; }
.score-detail-num { font-family:'Sora',sans-serif; font-size:18px; font-weight:800; }
.score-detail-label { font-size:10px; color:var(--text-3); margin-top:2px; line-height:1.3; }
.traj-ia-points { list-style:none; margin-top:32px; display:flex; flex-direction:column; gap:24px; }
.traj-ia-point { display:flex; gap:16px; align-items:flex-start; }
.traj-ia-point-icon { width:38px; height:38px; background:var(--accent-lite); border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.traj-ia-point-title { font-weight:600; color:var(--text-1); margin-bottom:4px; font-size:14.5px; }
.traj-ia-point-desc { font-size:13.5px; color:var(--text-2); line-height:1.55; }

/* ── SECTEURS ── */
.secteurs { background:var(--bg-alt); }
.secteurs-table-wrap { border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; margin-top:48px; }
.secteurs-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border); }
.secteur-item { background:var(--bg-alt); padding:32px 20px; text-align:center; transition:background .2s, transform .22s cubic-bezier(.16,1,.3,1), box-shadow .22s; }
.secteur-item:hover { background:var(--bg); transform:translateY(-5px); box-shadow:var(--sh-md); }
.secteur-icon { font-size:30px; margin-bottom:12px; display:block; }
.secteur-title { font-family:'Sora',sans-serif; font-size:15px; font-weight:700; color:var(--text-1); margin-bottom:6px; }
.secteur-desc { font-size:13px; color:var(--text-2); line-height:1.5; }

/* ── CHIFFRES ── */
.chiffres { background:var(--bg-dark); }
.chiffres-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:48px; margin-bottom:72px; }
.chiffre-item { text-align:center; }
.chiffre-num { font-family:'Sora',sans-serif; font-size:clamp(40px,5vw,60px); font-weight:800; color:var(--amber); line-height:1; margin-bottom:10px; }
.chiffre-label { font-size:14px; color:var(--text-inv-2); line-height:1.4; }
.bdd-block {
  border:1px solid oklch(30% 0.04 145); border-radius:var(--r-xl); padding:48px;
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center;
  background:oklch(21% 0.032 145);
}
.bdd-eyebrow { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--amber); margin-bottom:12px; }
.bdd-title { font-family:'Sora',sans-serif; font-size:22px; font-weight:800; color:var(--text-inv); margin-bottom:14px; }
.bdd-desc { font-size:14.5px; color:var(--text-inv-2); line-height:1.7; margin-bottom:24px; }
.bdd-tags { display:flex; flex-wrap:wrap; gap:8px; }
.bdd-tag { background:oklch(25% 0.04 145); color:var(--text-inv-2); font-size:12px; font-weight:500; padding:5px 12px; border-radius:100px; border:1px solid oklch(30% 0.04 145); }
.bdd-stats { display:flex; flex-direction:column; }
.bdd-stat-row { display:flex; align-items:center; justify-content:space-between; padding:16px 0; border-bottom:1px solid oklch(26% 0.04 145); }
.bdd-stat-row:last-child { border-bottom:none; }
.bdd-stat-label { font-size:14px; color:var(--text-inv-2); }
.bdd-stat-value { font-family:'Sora',sans-serif; font-size:24px; font-weight:800; color:var(--amber); }

/* ── FONCTIONS ── */
.fonctions { background:var(--bg); }
.fonctions-list { display:flex; flex-direction:column; gap:12px; }
.fonction-block {
  display:grid; grid-template-columns:60px 1fr; gap:28px; align-items:start;
  padding:36px 32px; background:var(--bg); border:1px solid var(--border);
  border-radius:var(--r-lg); transition:border-color .2s,background .2s;
}
.fonction-block:hover { border-color:var(--accent-mid); background:var(--accent-lite); }
.fonction-icon-wrap { width:52px; height:52px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:26px; flex-shrink:0; }
.bg-sage   { background:var(--accent-lite); }
.bg-amber  { background:var(--amber-bg); }
.bg-mid    { background:oklch(90% 0.015 145); }
.fonction-title { font-family:'Sora',sans-serif; font-size:20px; font-weight:800; color:var(--text-1); margin-bottom:10px; }
.fonction-desc { font-size:14.5px; color:var(--text-2); line-height:1.7; margin-bottom:18px; }
.fonction-chips { display:flex; flex-wrap:wrap; gap:7px; }
.fonction-chip { font-size:12.5px; color:var(--accent); background:var(--accent-lite); border:1px solid oklch(87% 0.025 145); padding:4px 12px; border-radius:100px; font-weight:500; }

/* ── RÉFÉRENCES ── */
.references { background:var(--bg-alt); }
.ref-flow { display:flex; flex-wrap:wrap; gap:12px 24px; justify-content:center; margin-top:48px; }
.ref-org { font-size:15px; font-weight:600; color:var(--text-2); padding:6px 16px; background:var(--bg); border:1px solid var(--border); border-radius:var(--r-sm); transition:color .2s,border-color .2s; }
.ref-org:hover { color:var(--text-1); border-color:var(--border-mid); }
.ref-org-more { color:var(--accent); border-color:var(--accent-lite); background:var(--accent-lite); }

/* ── CONTACT ── */
.contact-section { background:var(--bg); }
.contact-inner { display:grid; grid-template-columns:1fr 1.4fr; gap:64px; align-items:start; }
.contact-detail { display:flex; align-items:center; gap:16px; padding:16px 0; border-bottom:1px solid var(--border); }
.contact-detail:last-child { border-bottom:none; }
.contact-detail-icon { width:40px; height:40px; background:var(--accent-lite); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.contact-detail-label { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.06em; color:var(--text-3); margin-bottom:2px; }
.contact-detail-value { font-size:15px; font-weight:600; color:var(--text-1); text-decoration:none; }
.contact-detail-value:hover { color:var(--accent); }
.contact-form-wrap { background:var(--bg-alt); border:1px solid var(--border); border-radius:var(--r-xl); padding:40px; }
.form-title { font-family:'Sora',sans-serif; font-size:20px; font-weight:700; color:var(--text-1); margin-bottom:28px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group.full { grid-column:1/-1; }
.form-label { font-size:13px; font-weight:600; color:var(--text-2); }
.form-label .req { color:var(--cta); margin-left:2px; }
.form-input,.form-select,.form-textarea {
  width:100%; padding:11px 14px; border:1.5px solid var(--border-mid);
  border-radius:var(--r-sm); font-family:'Inter',sans-serif; font-size:14px;
  color:var(--text-1); background:var(--bg); transition:border-color .2s,box-shadow .2s; outline:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus {
  border-color:var(--cta); box-shadow:0 0 0 3px oklch(50% 0.115 145/.12);
}
.form-textarea { resize:vertical; min-height:110px; }
.form-select { cursor:pointer; }
.form-submit {
  width:100%; padding:13px; background:var(--cta); color:var(--text-inv);
  border:none; border-radius:var(--r-sm); font-family:'Inter',sans-serif;
  font-size:15px; font-weight:600; cursor:pointer; transition:background .2s,transform .2s; margin-top:8px;
}
.form-submit:hover { background:var(--cta-hover); transform:translateY(-1px); }
.form-submit:active { transform:translateY(0); }
.form-submit:disabled { opacity:.6; cursor:not-allowed; transform:none; }
.form-notice { font-size:12px; color:var(--text-3); text-align:center; margin-top:12px; }
.form-alert { display:none; padding:12px 16px; border-radius:var(--r-sm); font-size:14px; font-weight:500; margin-bottom:16px; }
.form-alert.success { background:var(--accent-lite); color:var(--accent); border:1px solid oklch(87% 0.025 145); }
.form-alert.error { background:oklch(96% 0.03 25); color:oklch(40% 0.14 25); border:1px solid oklch(90% 0.05 25); }

/* ── FAQ ── */
.faq-section { background:var(--bg-alt); }
.faq-list { max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:8px; }
.faq-item { border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; transition:border-color .2s; }
.faq-item[open] { border-color:var(--accent-mid); }
.faq-question {
  list-style:none; display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:18px 22px; font-size:15.5px; font-weight:600; color:var(--text-1);
  cursor:pointer; user-select:none; background:var(--bg); transition:background .15s;
}
.faq-question::-webkit-details-marker { display:none; }
.faq-question::after { content:'+'; font-size:22px; font-weight:300; color:var(--accent-mid); flex-shrink:0; transition:transform .25s ease; line-height:1; }
.faq-item[open] .faq-question { background:var(--accent-lite); }
.faq-item[open] .faq-question::after { transform:rotate(45deg); }
.faq-question:hover { background:var(--accent-lite); }
.faq-answer { padding:18px 22px 22px; border-top:1px solid var(--border); background:var(--bg); }
.faq-answer p { font-size:14.5px; color:var(--text-2); line-height:1.75; margin:0; }
.faq-answer strong { color:var(--text-1); }
.faq-cta { text-align:center; margin-top:48px; }
.faq-cta p { font-size:15px; color:var(--text-3); margin-bottom:20px; }

/* ── CTA ── */
.cta-section { background:var(--bg-dark); padding:120px 24px; text-align:center; }
.cta-section h2 { font-family:'Sora',sans-serif; font-size:clamp(32px,4vw,52px); font-weight:800; color:var(--text-inv); margin-bottom:16px; }
.cta-section > p { font-size:18px; color:var(--text-inv-2); margin-bottom:48px; max-width:520px; margin-left:auto; margin-right:auto; }
.cta-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.cta-section .btn-primary { background:var(--amber); color:var(--bg-dark); }
.cta-section .btn-primary:hover { background:var(--amber-dim); transform:translateY(-1px); }
.cta-section .btn-secondary { border-color:oklch(35% 0.05 145); color:var(--text-inv-2); background:transparent; }
.cta-section .btn-secondary:hover { border-color:oklch(50% 0.07 145); background:oklch(25% 0.04 145); }
.cta-contact { margin-top:40px; display:flex; gap:32px; justify-content:center; flex-wrap:wrap; }
.cta-contact a { display:flex; align-items:center; gap:8px; color:var(--text-inv-2); text-decoration:none; font-size:14px; transition:color .2s; }
.cta-contact a:hover { color:var(--text-inv); }

/* ── COOKIE BANNER ── */
#cookie-banner {
  position:fixed; bottom:24px; left:50%;
  transform:translateX(-50%) translateY(120px);
  z-index:9999; width:calc(100% - 48px); max-width:780px;
  background:var(--bg-dark); border:1px solid oklch(30% 0.04 145);
  border-radius:var(--r-xl); box-shadow:0 20px 60px oklch(0% 0 0/.35);
  padding:20px 24px; display:flex; align-items:center; gap:20px;
  transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .35s ease;
  opacity:0; pointer-events:none;
}
#cookie-banner.visible { transform:translateX(-50%) translateY(0); opacity:1; pointer-events:all; }
.cookie-icon { font-size:26px; flex-shrink:0; }
.cookie-text { flex:1; min-width:0; }
.cookie-text strong { display:block; font-size:14px; font-weight:700; color:var(--text-inv); margin-bottom:4px; }
.cookie-text p { font-size:13px; color:var(--text-inv-2); line-height:1.55; margin:0; }
.cookie-text a { color:var(--amber); text-decoration:underline; text-underline-offset:3px; }
.cookie-actions { display:flex; gap:10px; flex-shrink:0; }
.cookie-btn-refuse {
  padding:9px 16px; border-radius:var(--r-sm); font-size:13px; font-weight:600; cursor:pointer;
  border:1.5px solid oklch(35% 0.05 145); background:transparent; color:var(--text-inv-2);
  font-family:'Inter',sans-serif; transition:background .18s,color .18s; white-space:nowrap;
}
.cookie-btn-refuse:hover { background:oklch(25% 0.04 145); color:var(--text-inv); }
.cookie-btn-accept {
  padding:9px 18px; border-radius:var(--r-sm); font-size:13px; font-weight:700; cursor:pointer;
  border:none; background:var(--amber); color:var(--bg-dark);
  font-family:'Inter',sans-serif; transition:opacity .18s,transform .18s; white-space:nowrap;
}
.cookie-btn-accept:hover { opacity:.88; transform:translateY(-1px); }

/* ── FOOTER ── */
footer { background:var(--bg-darkest); border-top:1px solid oklch(20% 0.025 145); padding:36px 24px; }
.footer-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.footer-copy { font-size:13px; color:oklch(50% 0.020 145); }
.footer-links { display:flex; gap:24px; }
.footer-links a { font-size:13px; color:oklch(50% 0.020 145); text-decoration:none; transition:color .2s; }
.footer-links a:hover { color:var(--text-inv-2); }

/* ── BURGER ── */
.nav-burger { display:none; flex-direction:column; justify-content:center; gap:5px; width:40px; height:40px; background:none; border:none; cursor:pointer; padding:6px; border-radius:8px; transition:background .2s; }
.nav-burger:hover { background:var(--accent-lite); }
.nav-burger span { display:block; width:22px; height:2px; background:var(--text-1); border-radius:2px; transition:transform .3s ease,opacity .3s ease,width .3s ease; transform-origin:center; }
nav.open .nav-burger span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
nav.open .nav-burger span:nth-child(2) { opacity:0; width:0; }
nav.open .nav-burger span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ── MENU MOBILE ── */
.nav-mobile { display:none; position:absolute; top:64px; left:0; right:0; height:100dvh; z-index:10; background:var(--bg); border-top:1px solid var(--border); box-shadow:var(--sh-lg); flex-direction:column; overflow-y:auto; padding:8px 0 32px; opacity:0; visibility:hidden; transition:opacity .25s ease,visibility .25s ease; }
nav.open .nav-mobile { opacity:1; visibility:visible; }
.nav-mobile-links { list-style:none; display:flex; flex-direction:column; }
.nav-mobile-links li a { display:flex; align-items:center; justify-content:space-between; padding:14px 24px; font-size:16px; font-weight:600; color:var(--text-1); text-decoration:none; border-bottom:1px solid var(--border); transition:background .15s; }
.nav-mobile-links li a::after { content:'›'; font-size:18px; color:var(--text-3); font-weight:300; }
.nav-mobile-links li a:active { background:var(--accent-lite); }
.nav-mobile-links li:last-child a { border-bottom:none; }
.nav-mobile-cta { margin:14px 20px 0; }
.nav-mobile-cta a { display:flex; align-items:center; justify-content:center; gap:8px; background:var(--cta); color:var(--text-inv); padding:13px 20px; border-radius:10px; font-size:15px; font-weight:700; text-decoration:none; }
.nav-mobile-contact { margin:10px 20px 0; display:flex; gap:8px; }
.nav-mobile-contact a { flex:1; display:flex; align-items:center; justify-content:center; gap:6px; padding:10px 12px; color:var(--text-2); text-decoration:none; font-size:13px; font-weight:500; background:var(--bg-alt); border:1px solid var(--border); border-radius:8px; }

/* ── FADE-UP ── */
.fade-up { opacity:0; transform:translateY(22px); transition:opacity .65s cubic-bezier(.16,1,.3,1),transform .65s cubic-bezier(.16,1,.3,1); }
.fade-up.visible { opacity:1; transform:translateY(0); }

/* ── HERO CARD FLOAT ── */
/* ── CURSOR GLOW ── */
.cursor-glow {
  position:fixed; pointer-events:none; z-index:0;
  width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle, oklch(55% 0.10 145 / .07) 0%, transparent 68%);
  top:0; left:0; margin-top:-300px; margin-left:-300px;
  will-change:transform;
}

/* ── HERO TITLE WORD REVEAL ── */
.word-reveal {
  display:inline-block;
  animation:wordIn .75s cubic-bezier(.16,1,.3,1) var(--wd-delay, 0s) both;
}
@keyframes wordIn {
  from { opacity:0; transform:translateY(32px); }
  to   { opacity:1; transform:none; }
}

/* ── HERO CARD FLOAT ── */
@keyframes cardFloat {
  0%,100% { transform:translateY(0); }
  40%     { transform:translateY(-14px) rotate(.4deg); }
  70%     { transform:translateY(-7px) rotate(-.25deg); }
}
.hero-app-card { animation:cardFloat 5s ease-in-out infinite; }

/* ── ARIA CHAT ANIMATION ── */
.ia-typing {
  display:none; align-items:center; gap:5px;
  padding:10px 14px; margin-bottom:8px;
  background:var(--bg-darkest); border-radius:10px 10px 10px 2px;
  width:fit-content;
}
.ia-typing.show { display:flex; }
.ia-typing span {
  width:6px; height:6px; border-radius:50%;
  background:oklch(62% 0.018 145);
  animation:typDot 1.1s ease-in-out infinite;
}
.ia-typing span:nth-child(2) { animation-delay:.18s; }
.ia-typing span:nth-child(3) { animation-delay:.36s; }
@keyframes typDot {
  0%,70%,100% { transform:translateY(0); opacity:.35; }
  35% { transform:translateY(-5px); opacity:1; }
}
.ia-chat .ia-msg {
  opacity:0; transform:translateY(8px);
  transition:opacity .38s ease, transform .4s cubic-bezier(.16,1,.3,1);
}
.ia-chat .ia-msg.revealed { opacity:1; transform:none; }

/* ── SPARKLINE DRAW ── */
.sparkline-path {
  transition:stroke-dashoffset 2.2s cubic-bezier(.16,1,.3,1) .15s;
}

/* ── RESPONSIVE ── */
@media (max-width:1024px) {
  .features-grid { grid-template-columns:repeat(2,1fr); }
  .secteurs-grid { grid-template-columns:repeat(2,1fr); }
  .chiffres-grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:768px) {
  .nav-links { display:none; }
  .nav-burger { display:flex; }
  .nav-mobile { display:flex; }

  .hero { min-height:auto; padding:96px 20px 56px; }
  .hero-inner { grid-template-columns:1fr; gap:0; }
  .hero-visual { display:none; }
  .hero h1 { font-size:clamp(32px,8vw,44px); }
  .hero-sub { font-size:16px; }
  .hero-actions { flex-direction:column; }
  .hero-actions a { justify-content:center; }

  section { padding:64px 20px; }
  .section-title { font-size:clamp(24px,6vw,34px); }

  .constat-inner { grid-template-columns:1fr; gap:48px; }
  .features-grid { grid-template-columns:1fr; }
  .conform-item { grid-template-columns:40px 1fr; gap:16px; padding:20px; }
  .ia-inner { grid-template-columns:1fr; gap:40px; }
  .trajectoire-inner { grid-template-columns:1fr; gap:40px; }
  .secteurs-grid { grid-template-columns:repeat(2,1fr); }
  .chiffres-grid { grid-template-columns:repeat(2,1fr); }
  .bdd-block { grid-template-columns:1fr; gap:32px; padding:28px 24px; }
  .fonction-block { grid-template-columns:1fr; gap:16px; padding:24px 20px; }
  .contact-inner { grid-template-columns:1fr; gap:40px; }
  .contact-form-wrap { padding:24px 20px; }
  .form-grid { grid-template-columns:1fr; }
  .cta-section { padding:72px 20px; }
  .cta-actions { flex-direction:column; align-items:center; }
  .cta-contact { gap:16px; flex-direction:column; align-items:center; }
  .footer-inner { flex-direction:column; text-align:center; gap:12px; }
}

@media (max-width:480px) {
  .secteurs-grid { grid-template-columns:1fr; }
  .chiffres-grid { grid-template-columns:1fr; }
  .hero-proof { flex-direction:column; gap:6px; align-items:flex-start; }
  .proof-sep { display:none; }
  #cookie-banner { flex-direction:column; align-items:flex-start; gap:16px; bottom:16px; width:calc(100% - 32px); padding:18px; }
  .cookie-actions { width:100%; }
  .cookie-btn-refuse,.cookie-btn-accept { flex:1; text-align:center; }
}
