/* ─────────────────── tokens ─────────────────── */
:root{
  /* Backgrounds — harmonisé avec le produit (cream/blanc) */
  --bg:#F5F2EC;
  --bg-soft:#ECE7DD;
  --surface:#FBF8F2;
  --card:#FFFFFF;
  --card-hi:#FAF6EE;

  /* Edges — sombres translucides sur fond clair */
  --edge:rgba(10,10,15,0.08);
  --edge-mid:rgba(10,10,15,0.14);
  --edge-strong:rgba(10,10,15,0.22);

  /* Brand — légèrement assombris pour contraste AAA sur fond clair */
  --brand:#2563EB;
  --brand-soft:#3B82F6;
  --sovereign:#6D28D9;
  --sovereign-soft:#7C3AED;
  --high:#DC2626;
  --high-soft:#EF4444;
  --warn:#EA580C;
  --ok:#16A34A;

  /* Text — du noir vers les gris muets */
  --text:#0A0A0F;
  --text-soft:#2D2D33;
  --text-mid:#4A4D55;
  --text-muted:#7A7D85;
  --text-faint:#B0B3BB;

  --display:Georgia,"Times New Roman",serif;
  --body:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mono:ui-monospace,"SF Mono",SFMono-Regular,Menlo,Consolas,monospace;

  --container:1240px;
  --container-wide:1340px;
  --gutter:clamp(20px,4vw,32px);
  --ease:cubic-bezier(.2,.8,.2,1);

  --r-sm:6px; --r:10px; --r-lg:14px; --r-xl:20px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--body);font-size:15px;line-height:1.55;font-weight:400;
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
::selection{background:var(--brand);color:#fff}

/* ─────────────────── primitives ─────────────────── */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.container-wide{max-width:var(--container-wide);margin:0 auto;padding:0 var(--gutter)}

h1,h2,h3,h4{font-family:var(--display);font-weight:400;letter-spacing:-0.02em;margin:0;color:var(--text)}
h1{font-size:clamp(28px,3.4vw,48px);line-height:1.12;letter-spacing:-0.018em}
h2{font-size:clamp(28px,3.4vw,48px);line-height:1.12;letter-spacing:-0.018em}
h3{font-size:clamp(22px,2.4vw,32px);line-height:1.2;letter-spacing:-0.015em}
h4{font-size:clamp(17px,1.4vw,20px);line-height:1.3;letter-spacing:-0.01em}
p{margin:0}

/* ─────────────────── section-title — classe unifiée pour tous les titres de section ─────────────────── */
.section-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(36px,5.4vw,72px);line-height:1.02;letter-spacing:-0.025em;
  color:var(--text);margin:0 0 24px;
}
.section-title em{font-style:italic;color:var(--brand)}

.section-subtitle{
  font-family:var(--display);font-style:italic;
  font-size:clamp(16px,1.5vw,22px);line-height:1.4;
  color:#6B7280;margin:0 0 24px;
}
.section-subtitle em{font-style:italic}

.section-paragraph{
  font-family:var(--body);font-size:clamp(15px,1.1vw,17px);
  line-height:1.6;color:var(--text-soft);margin:0 0 24px;max-width:48ch;
}
.section-caption{
  font-family:var(--display);font-style:italic;font-size:13px;
  color:var(--text-muted);margin:0;
}

.eyebrow{
  font-family:var(--mono);font-size:11px;font-weight:500;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted);
}

/* buttons — cursor-style: pill */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:999px;font-weight:500;font-size:13.5px;
  letter-spacing:-0.005em;transition:all .18s var(--ease);
  white-space:nowrap;line-height:1.2;
}
.btn-primary{background:var(--text);color:#FFFFFF;border:1px solid var(--text)}
.btn-primary:hover{background:#000;border-color:#000}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--edge-strong)}
.btn-ghost:hover{border-color:var(--text);background:rgba(10,10,15,0.04)}
.btn-text{background:transparent;color:var(--text);border:0;padding:11px 16px}
.btn-text:hover{color:var(--text-soft)}
.btn .arrow{font-size:14px;transition:transform .18s var(--ease)}
.btn:hover .arrow{transform:translateX(2px)}
.btn .dl{font-size:14px;line-height:1;display:inline-block;transform:translateY(-1px)}

.txt-link{
  display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--text-soft);
  border-bottom:1px solid var(--edge-mid);padding-bottom:2px;
  transition:color .15s var(--ease),border-color .15s var(--ease);
}
.txt-link:hover{color:var(--text);border-bottom-color:var(--edge-strong)}
.txt-link .arrow{transition:transform .18s var(--ease)}
.txt-link:hover .arrow{transform:translateX(2px)}

/* logo wordmark */
.logo{font-family:var(--display);font-size:clamp(22px,2vw,28px);font-weight:700;letter-spacing:-0.015em;color:var(--text)}
.logo .in{color:var(--brand)}

/* ─────────────────── nav ─────────────────── */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);
  background:rgba(245,242,236,0.78);
  border-bottom:1px solid var(--edge);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:56px;gap:24px}
.nav-left{display:flex;align-items:center;gap:36px}
.nav-links{display:flex;gap:22px;align-items:center}
.nav-links a{
  font-size:13.5px;color:var(--text-soft);transition:color .15s var(--ease);
  display:inline-flex;align-items:center;gap:4px;
}
.nav-links a:hover{color:var(--text)}
.nav-links .caret{font-size:9px;color:var(--text-muted);margin-top:2px}
.nav-right{display:flex;gap:10px;align-items:center}
.nav-right .signin{font-size:13.5px;color:var(--text-soft);padding:8px 4px}
.nav-right .signin:hover{color:var(--text)}
@media (max-width:880px){
  .nav-links{display:none}
  .nav-right .signin{display:none}
}

/* ─────────────────── hero ─────────────────── */
.hero{
  position:relative;overflow:hidden;
  padding:clamp(56px,8vw,112px) 0 clamp(48px,6vw,80px);
}
.hero-bg{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 70% 50% at 50% 20%,rgba(59,130,246,0.07),transparent 60%),
    radial-gradient(ellipse 50% 40% at 70% 60%,rgba(124,58,237,0.05),transparent 70%);
}
.hero-inner{position:relative;z-index:1}

/* huge hero headline — cursor-style: long single sentence */
.hero h1{
  max-width:24ch;margin:0 0 clamp(28px,3vw,40px);
}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* product mockup card right after hero */
.hero-mockup{
  margin-top:clamp(56px,7vw,96px);
  border-radius:var(--r-xl);
  background:var(--card);
  border:1px solid var(--edge-mid);
  padding:0;
  position:relative;overflow:hidden;
  box-shadow:
    0 30px 80px -32px rgba(10,10,15,0.20),
    0 0 0 1px rgba(10,10,15,0.04),
    0 0 100px -30px rgba(59,130,246,0.20);
}
.hero-mockup::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(37,99,235,0.4),transparent);
  z-index:2;
}
.hero-mockup img{display:block;width:100%;background:#fff}

/* macOS-style window chrome — wraps any product mockup */
.chrome{
  display:flex;align-items:center;
  padding:12px 16px;
  border-bottom:1px solid var(--edge);
  background:var(--bg-soft);
  position:relative;z-index:1;
}
.chrome .lights{display:flex;gap:7px}
.chrome .lights span{width:11px;height:11px;border-radius:50%;display:inline-block}
.chrome .lights span:nth-child(1){background:#FF5F57}
.chrome .lights span:nth-child(2){background:#FEBC2E}
.chrome .lights span:nth-child(3){background:#28C840}
.chrome .ttl{
  flex:1;text-align:center;
  font-family:var(--mono);font-size:11.5px;
  letter-spacing:0.04em;color:var(--text-mid);
}
.chrome .ttl::before{content:""}

/* ─────────────────── manifesto / constat (slide 2) ─────────────────── */
.manifesto{
  padding:clamp(96px,12vw,160px) 0;
  border-top:1px solid var(--edge);
}
/* Layout 2 colonnes : texte à gauche, cartes à droite */
.manifesto-grid{
  display:grid;
  grid-template-columns:minmax(0,40fr) minmax(0,60fr);
  gap:clamp(48px,6vw,96px);
  align-items:start;
}
@media (max-width:1100px){.manifesto-grid{grid-template-columns:1fr;gap:48px}}
.manifesto-head{max-width:480px}
.manifesto-head .eyebrow{margin-bottom:18px;display:block}

/* ─────────────────── Layout pyramide 2+1 (réutilisable) ─────────────────── */
.pyramid-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.pyramid-grid > :nth-child(3){
  grid-column:1 / -1;
  max-width:calc(50% - 12px);
  margin-inline:auto;
}
@media (max-width:780px){
  .pyramid-grid{grid-template-columns:1fr}
  .pyramid-grid > :nth-child(3){max-width:100%}
}

/* ─────────────────── .card-dark — Design unifié pour toutes les cartes ─────────────────── */
.card-dark{
  background:#0F172A;
  border:none;
  border-radius:0;
  overflow:hidden;
  position:relative;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.card-dark::before{
  content:"";position:absolute;top:0;left:0;right:0;height:5px;
  background:var(--card-accent, #3B82F6);
}
.card-dark:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 50px -15px rgba(0,0,0,0.5);
}
.card-dark__header{
  padding:24px 28px 0;
}
.card-dark__label{
  font-family:var(--mono);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;
  font-weight:600;color:var(--card-accent, #3B82F6);
}
.card-dark__body{
  padding:20px 28px 32px;
}
.card-dark__title{
  font-family:var(--display);font-style:italic;color:#FFFFFF;
  font-size:clamp(18px,1.6vw,22px);line-height:1.35;letter-spacing:-0.01em;
  margin-bottom:16px;
}
.card-dark__divider{
  height:1px;background:rgba(255,255,255,0.1);margin:20px 0;
}
.card-dark__tag{
  font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
  font-weight:500;margin-bottom:8px;
}
.card-dark__tag--muted{color:#9CA3AF}
.card-dark__tag--accent{color:var(--card-accent, #3B82F6)}
.card-dark__text{
  font-size:15px;line-height:1.6;color:#D1D5DB;
}
.card-dark__quote{
  font-family:var(--display);font-style:italic;color:#FFFFFF;
  font-size:clamp(17px,1.5vw,21px);line-height:1.4;letter-spacing:-0.01em;
}

/* Variantes de couleur d'accent */
.card-dark--red{--card-accent:#E63946}
.card-dark--orange{--card-accent:#F77F00}
.card-dark--yellow{--card-accent:#FFB703}
.card-dark--blue{--card-accent:#3B82F6}
.card-dark--cyan{--card-accent:#06B6D4}
.card-dark--green{--card-accent:#10B981}
.card-dark--violet{--card-accent:#8B5CF6}
.card-dark--brand{--card-accent:#2563EB}
.card-dark--success{--card-accent:#16A34A}
.card-dark--navy{--card-accent:#1E40AF}

/* Grille scénarios — pyramide 2+1 */
.scenarios{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.scenarios > :nth-child(3){
  grid-column:1 / -1;
  max-width:calc(50% - 12px);
  margin-inline:auto;
}
@media (max-width:780px){
  .scenarios{grid-template-columns:1fr}
  .scenarios > :nth-child(3){max-width:100%}
}

/* ─────────────────── écart chiffré (slide 3) ─────────────────── */
.gap-section{
  padding:clamp(96px,12vw,160px) 0;
  border-top:1px solid var(--edge);
  background:var(--bg-soft);
}
.gap-grid{
  display:grid;grid-template-columns:minmax(0,40fr) minmax(0,60fr);
  gap:clamp(48px,6vw,96px);align-items:center;
}
@media (max-width:980px){.gap-grid{grid-template-columns:1fr;gap:56px}}
.gap-text .eyebrow{margin-bottom:18px;display:block}
.gap-text h2{
  font-family:var(--display);font-weight:400;
  font-size:clamp(36px,5.4vw,72px);line-height:1.02;letter-spacing:-0.025em;
  color:var(--text);margin:0 0 28px;
}

.gap-viz{display:flex;flex-direction:column;gap:32px}
.gap-bar{
  background:var(--card);border:1px solid var(--edge-mid);border-radius:var(--r-lg);
  padding:24px 28px;
}
.gap-bar-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.gap-bar-name{
  font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--text-mid);font-weight:500;
}
.gap-bar-val{
  font-family:var(--display);font-weight:400;
  font-size:clamp(28px,3vw,40px);line-height:1;letter-spacing:-0.02em;
}
.gap-declared .gap-bar-val{color:var(--high)}
.gap-verified .gap-bar-val{color:var(--text-mid)}
.gap-bar-fill{
  height:8px;background:rgba(10,10,15,0.06);border-radius:4px;overflow:hidden;
  margin-bottom:14px;
}
.gap-bar-fill i{
  display:block;height:100%;border-radius:4px;
}
.gap-declared .gap-bar-fill i{background:var(--high)}
.gap-verified .gap-bar-fill i{background:var(--text-mid);min-width:0}
.gap-bar-desc{
  font-size:13.5px;color:var(--text-mid);line-height:1.5;
}

/* ─────────────────── 4 angles morts (slide 4) ─────────────────── */
.blindspots{
  padding:clamp(96px,12vw,160px) 0;
  border-top:1px solid var(--edge);
}
/* Layout 2 colonnes : titre à gauche, grille 2×2 à droite */
.bs-wrapper{
  display:grid;
  grid-template-columns:minmax(0,40fr) minmax(0,60fr);
  gap:clamp(48px,6vw,96px);
  align-items:start;
}
@media (max-width:1100px){.bs-wrapper{grid-template-columns:1fr;gap:48px}}
.bs-head{max-width:480px}
.bs-head .eyebrow{margin-bottom:18px;display:block}

.bs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;align-items:stretch}
@media (max-width:780px){.bs-grid{grid-template-columns:1fr}}
/* Les cartes .bs-card sont remplacées par .card-dark */

/* ─────────────────── paradigm / Claude Mythos ─────────────────── */
.paradigm{
  padding:clamp(96px,12vw,160px) 0;
  border-top:1px solid var(--edge);
  background:var(--bg-soft);
}
.paradigm-closing{
  font-family:var(--display);font-style:italic;color:var(--text-mid);
  font-size:clamp(17px,1.5vw,22px);line-height:1.4;
  margin:48px 0 0;text-align:center;max-width:56ch;margin-left:auto;margin-right:auto;
}

/* ─────────────────── trust logos ─────────────────── */
.trust{padding:clamp(72px,8vw,112px) 0;border-top:1px solid var(--edge)}
.trust h2{font-size:clamp(18px,1.6vw,22px);text-align:center;color:var(--text-mid);font-weight:400;letter-spacing:-0.01em;margin-bottom:48px;max-width:48ch;margin-left:auto;margin-right:auto}
.trust-grid{
  display:grid;grid-template-columns:repeat(8,1fr);gap:0;
  border-top:1px solid var(--edge);border-left:1px solid var(--edge);
}
@media (max-width:1100px){.trust-grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:560px){.trust-grid{grid-template-columns:repeat(2,1fr)}}
.sector{
  border-right:1px solid var(--edge);border-bottom:1px solid var(--edge);
  padding:32px 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  min-height:140px;color:var(--text-mid);transition:color .2s var(--ease),background .2s var(--ease);
}
.sector:hover{color:var(--text);background:rgba(240,238,233,0.02)}
.sector svg{width:30px;height:30px;opacity:0.85}
.sector-label{font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase}

/* ─────────────────── feature sections ─────────────────── */
.feature{padding:clamp(96px,12vw,180px) 0;border-top:1px solid var(--edge)}

/* 2-column grid: image dominant, alternating sides — images agrandies */
.feature-grid{
  display:grid;
  grid-template-columns:minmax(0,32fr) minmax(0,68fr);
  gap:clamp(48px,6vw,96px);
  align-items:center;
}
.feature-grid.reverse{grid-template-columns:minmax(0,68fr) minmax(0,32fr)}
.feature-grid.reverse .feature-head{order:2}
.feature-grid.reverse .feature-mockup{order:1}

@media (max-width:880px){
  .feature-grid,.feature-grid.reverse{grid-template-columns:1fr;gap:48px}
  .feature-grid.reverse .feature-head{order:1}
  .feature-grid.reverse .feature-mockup{order:2}
}

.feature-head{margin-bottom:0;max-width:480px}
.feature-head h3{margin-bottom:24px;font-family:var(--display);font-weight:400;font-size:clamp(28px,3.4vw,48px);line-height:1.05;letter-spacing:-0.025em;color:var(--text)}
.feature-head p{font-size:clamp(15px,1.25vw,18px);color:var(--text-soft);line-height:1.6;max-width:44ch;margin-bottom:28px}

.feature-mockup{
  position:relative;border-radius:var(--r-xl);
  background:var(--card);
  border:1px solid var(--edge-mid);padding:0;
  box-shadow:0 30px 80px -32px rgba(10,10,15,0.22), 0 0 0 1px rgba(10,10,15,0.03);
  overflow:hidden;
  width:100%;
}
.feature-mockup::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(37,99,235,0.3),transparent);
  z-index:2;
}
.feature-mockup img{display:block;width:100%;background:#fff}

/* ─────────────────── différenciateur cards (slide 4) — design .card-dark ─────────────────── */
.diff-flow{display:flex;align-items:stretch;gap:16px;flex-wrap:nowrap;justify-content:center}
@media (max-width:880px){.diff-flow{flex-direction:column;gap:16px}}
.diff-flow .card-dark{
  flex:1;min-width:200px;
}
.diff-flow .card-dark__body{
  min-height:120px;
  display:flex;flex-direction:column;justify-content:center;
  text-align:center;
}
.diff-num{
  width:28px;height:28px;border-radius:50%;
  background:var(--brand);color:#fff;
  font-family:var(--mono);font-size:12px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.diff-title{
  font-family:var(--mono);font-size:11px;letter-spacing:0.14em;
  text-transform:uppercase;color:#fff;font-weight:600;
}
.diff-body{padding:20px;text-align:center}
.diff-body p{
  font-family:var(--display);font-style:italic;
  font-size:15px;color:var(--text-soft);line-height:1.45;
}
.diff-arrow{
  display:flex;align-items:center;justify-content:center;
  padding:0 12px;
  font-family:var(--display);font-size:28px;color:var(--brand);
}
@media (max-width:880px){.diff-arrow{transform:rotate(90deg);padding:8px 0}}

/* ─────────────────── cycle 4 étapes (slide 7) ─────────────────── */
.cycle-container{
  background:var(--card);border:1px solid var(--edge-mid);border-radius:var(--r-xl);
  padding:clamp(32px,4vw,48px);overflow:hidden;
}
.cycle-flow{display:flex;align-items:stretch;justify-content:center;gap:0;flex-wrap:wrap;margin-bottom:36px}
@media (max-width:980px){.cycle-flow{flex-direction:column;align-items:center;gap:16px}}
.cycle-step{
  flex:1;min-width:160px;max-width:220px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
}
.cycle-icon{
  width:56px;height:56px;border-radius:14px;
  background:linear-gradient(135deg,#0F172A 0%,#1E293B 100%);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;position:relative;
}
.cycle-icon::before{
  content:attr(data-num);position:absolute;top:-8px;right:-8px;
  width:24px;height:24px;border-radius:50%;
  background:var(--brand);color:#fff;
  font-family:var(--mono);font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.cycle-icon svg{width:26px;height:26px;stroke:#fff;stroke-width:1.5;fill:none}
.cycle-label{
  font-family:var(--display);font-size:18px;font-weight:400;
  color:var(--text);margin-bottom:8px;letter-spacing:-0.01em;
}
.cycle-desc{
  font-family:var(--mono);font-size:11px;letter-spacing:0.04em;
  color:var(--text-mid);line-height:1.5;
}
.cycle-arrow{
  display:flex;align-items:center;justify-content:center;
  padding:0 8px;color:var(--brand);font-size:24px;font-family:var(--display);
  align-self:center;
}
@media (max-width:980px){.cycle-arrow{transform:rotate(90deg);padding:12px 0}}
.cycle-stats{
  display:flex;justify-content:center;gap:clamp(24px,4vw,48px);flex-wrap:wrap;
  padding-top:28px;border-top:1px solid var(--edge);
}
.cycle-stat{text-align:center}
.cycle-stat-num{
  font-family:var(--display);font-size:clamp(36px,4vw,52px);
  font-weight:400;color:var(--brand);line-height:1;letter-spacing:-0.02em;
}
.cycle-stat-label{
  font-family:var(--mono);font-size:10px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--text-mid);margin-top:8px;
}

/* custom mockups (HTML-based) */
.mock-canvas{
  border-radius:12px;background:var(--card);padding:clamp(28px,3vw,44px);
  min-height:520px;position:relative;overflow:hidden;
}
.mock-canvas.light{background:#F0EEE9;color:#0A0A0F}
.mock-canvas .mock-bg{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 40% at 50% 30%,rgba(59,130,246,0.10),transparent 70%);
}

/* compliance mockup (feature 2) */
.comp-mock{position:relative;z-index:1;display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center;height:100%}
@media (max-width:780px){.comp-mock{grid-template-columns:1fr}}
.comp-question{
  background:var(--card);border:1px solid var(--edge-mid);border-radius:12px;padding:24px;
}
.comp-question .qlabel{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;color:var(--brand);text-transform:uppercase;margin-bottom:14px}
.comp-question .qtitle{font-family:var(--display);font-size:20px;line-height:1.3;color:var(--text);margin-bottom:18px}
.comp-question .qopts{display:grid;gap:8px}
.comp-question .qopt{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--edge);border-radius:8px;font-size:13px;color:var(--text-soft)}
.comp-question .qopt.sel{border-color:rgba(59,130,246,0.4);background:rgba(59,130,246,0.06);color:var(--text)}
.comp-question .qopt .dot{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--text-faint);flex-shrink:0;position:relative}
.comp-question .qopt.sel .dot{border-color:var(--brand)}
.comp-question .qopt.sel .dot::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--brand)}

.comp-arrow{align-self:center;justify-self:center;color:var(--text-mid);font-size:24px;font-family:var(--display)}
@media (max-width:780px){.comp-arrow{display:none}}

.comp-refs{display:grid;gap:10px}
.comp-ref{
  background:var(--card);border:1px solid var(--edge);border-radius:10px;
  padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:14px;
  transition:all .25s var(--ease);
}
.comp-ref.hit{border-color:rgba(34,197,94,0.3);background:linear-gradient(90deg,rgba(34,197,94,0.06),transparent)}
.comp-ref-name{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11px;letter-spacing:0.12em;color:var(--text);text-transform:uppercase;font-weight:600}
.comp-ref-art{font-family:var(--mono);font-size:10.5px;color:var(--text-mid);letter-spacing:0.04em}
.comp-ref-status{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:#22C55E;display:flex;align-items:center;gap:6px}
.comp-ref-status .ok{display:inline-block;width:14px;height:14px;border-radius:50%;background:rgba(34,197,94,0.15);color:#22C55E;font-size:11px;text-align:center;line-height:14px}

/* connectors mockup (feature 3) */
.conn-mock{position:relative;z-index:1;height:100%;display:grid;grid-template-rows:auto 1fr auto;gap:24px}
.conn-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--edge)}
.conn-head .ctitle{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-mid)}
.conn-head .ctime{font-family:var(--mono);font-size:11px;color:var(--text-faint)}
.conn-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media (max-width:780px){.conn-grid{grid-template-columns:repeat(2,1fr)}}
.conn-card{
  background:var(--card);border:1px solid var(--edge);border-radius:10px;
  padding:18px;display:flex;flex-direction:column;gap:10px;
}
.conn-card .cn-name{display:flex;align-items:center;gap:10px}
.conn-card .cn-icon{width:24px;height:24px;border-radius:6px;background:rgba(59,130,246,0.12);display:flex;align-items:center;justify-content:center;color:var(--brand);font-size:12px;font-weight:700}
.conn-card .cn-label{font-family:var(--mono);font-size:11px;letter-spacing:0.06em;color:var(--text);font-weight:600}
.conn-card .cn-status{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;letter-spacing:0.10em;text-transform:uppercase;color:var(--text-mid)}
.conn-card .cn-status .pulse{width:6px;height:6px;border-radius:50%;background:#22C55E;box-shadow:0 0 0 0 rgba(34,197,94,0.6);animation:pulse 2s infinite}
.conn-card .cn-meta{font-size:11.5px;color:var(--text-muted);font-family:var(--mono)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,0.4)}50%{box-shadow:0 0 0 6px rgba(34,197,94,0)}}

.conn-log{font-family:var(--mono);font-size:11.5px;color:var(--text-mid);line-height:1.7;max-height:120px;overflow:hidden}
.conn-log .ln{padding:2px 0}
.conn-log .ln .t{color:var(--text-faint);margin-right:10px}
.conn-log .ln .ok{color:#22C55E}
.conn-log .ln .warn{color:#EAB308}

/* verdict mockup (feature 4) */
.verd-mock{position:relative;z-index:1;height:100%;display:grid;grid-template-columns:1.2fr 1fr;gap:24px;align-items:start}
@media (max-width:780px){.verd-mock{grid-template-columns:1fr}}
.verd-card{
  background:var(--card);border:1px solid var(--edge);border-radius:14px;padding:24px;
}
.verd-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--edge)}
.verd-head h4{font-family:var(--display);font-size:18px;color:var(--text);margin:0 0 6px}
.verd-head .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:0.10em;color:var(--text-mid);text-transform:uppercase}
.verd-stamp{
  font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:#22C55E;border:1px solid rgba(34,197,94,0.4);padding:5px 10px;border-radius:6px;
  background:rgba(34,197,94,0.06);
}
.verd-rows{display:grid;gap:12px}
.verd-row{display:grid;grid-template-columns:1fr auto auto;gap:14px;align-items:center;padding:10px 0;border-bottom:1px solid var(--edge)}
.verd-row:last-child{border-bottom:0}
.verd-row .vrn{font-size:13px;color:var(--text-soft)}
.verd-row .vra{font-family:var(--mono);font-size:11px;color:var(--text-mid)}
.verd-row .vrv{font-family:var(--mono);font-size:11px;font-weight:600}
.verd-row .vrv.ok{color:#22C55E}
.verd-row .vrv.no{color:#DC2626}
.verd-row .vrv.warn{color:#EAB308}

.verd-side{display:grid;gap:14px}
.verd-stat{
  background:var(--card);border:1px solid var(--edge);border-radius:12px;padding:18px;
}
.verd-stat-label{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-mid);margin-bottom:10px}
.verd-stat-num{font-family:var(--display);font-size:36px;line-height:1;color:var(--text);letter-spacing:-0.02em}
.verd-stat-sub{font-size:12px;color:var(--text-muted);margin-top:8px}

/* ─────────────────── context (replaces testimonials) ─────────────────── */
.context{padding:clamp(96px,11vw,148px) 0;border-top:1px solid var(--edge);background:linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 100%)}
.context h2{max-width:24ch;text-align:center;margin:0 auto 64px}
.context-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:980px){.context-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.context-grid{grid-template-columns:1fr}}
.ctx-card{
  background:var(--card);border:1px solid var(--edge);border-radius:var(--r-lg);
  padding:clamp(28px,3vw,36px);transition:border-color .2s var(--ease),background .2s var(--ease);
  display:flex;flex-direction:column;
}
.ctx-card:hover{border-color:var(--edge-mid);background:var(--card-hi)}
.ctx-quote{font-family:var(--display);font-size:clamp(17px,1.4vw,20px);line-height:1.45;color:var(--text);letter-spacing:-0.01em;margin-bottom:24px;flex:1}
.ctx-quote::before{content:"« ";color:var(--text-muted);margin-right:2px}
.ctx-quote::after{content:" »";color:var(--text-muted);margin-left:2px}
.ctx-meta{display:flex;flex-direction:column;gap:6px;padding-top:18px;border-top:1px solid var(--edge);font-family:var(--mono);font-size:10.5px;letter-spacing:0.10em;text-transform:uppercase;color:var(--text-mid)}
.ctx-meta .src{color:var(--text);font-size:11px}

/* ─────────────────── platform grid (sub-features) ─────────────────── */
.platform{padding:clamp(80px,10vw,140px) 0;border-top:1px solid var(--edge)}
/* Layout 2 colonnes : titre à gauche, cartes pyramide à droite */
.platform-wrapper{
  display:grid;
  grid-template-columns:minmax(0,40fr) minmax(0,60fr);
  gap:clamp(48px,6vw,96px);
  align-items:start;
}
@media (max-width:1100px){.platform-wrapper{grid-template-columns:1fr;gap:48px}}
.platform-head{max-width:480px}
.platform-head .eyebrow{margin-bottom:18px;display:block}

/* Grille pyramide 2+1 pour les piliers */
.platform-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}
.platform-grid > :nth-child(3){
  grid-column:1 / -1;
  max-width:calc(50% - 10px);
  margin-inline:auto;
}
@media (max-width:780px){
  .platform-grid{grid-template-columns:1fr}
  .platform-grid > :nth-child(3){max-width:100%}
}
/* Les cartes .pf-card sont remplacées par .card-dark */

/* ─────────────────── market (slide 12 of deck) ─────────────────── */
.market{padding:clamp(80px,10vw,140px) 0;border-top:1px solid var(--edge);background:var(--bg-soft)}
.market-head{text-align:center;margin-bottom:64px;max-width:48ch;margin-left:auto;margin-right:auto}
.market-head .eyebrow{margin-bottom:18px;display:block}
.market-head h2{font-family:var(--display);font-weight:400;font-size:clamp(32px,4.4vw,56px);line-height:1.05;letter-spacing:-0.022em;color:var(--text)}
.market-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:780px){.market-stats{grid-template-columns:1fr}}
.mkt-stat{
  background:var(--card);border:1px solid var(--edge-mid);border-radius:var(--r-xl);
  padding:48px 36px;text-align:center;
  transition:border-color .25s var(--ease),transform .3s var(--ease);
}
.mkt-stat:hover{border-color:var(--edge-strong);transform:translateY(-3px)}
.mkt-num{
  font-family:var(--display);font-weight:400;
  font-size:clamp(56px,7vw,96px);line-height:1;letter-spacing:-0.035em;
  color:var(--brand);margin-bottom:18px;
}
.mkt-num .plus{font-size:0.55em;color:var(--text-mid);margin-left:4px}
.mkt-num.sov{color:var(--sovereign)}
.mkt-label{font-family:var(--mono);font-size:11.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-mid);line-height:1.5}

/* ─────────────────── changelog (card grid, cursor-style) ─────────────────── */
.changelog{padding:clamp(96px,12vw,160px) 0;border-top:1px solid var(--edge)}
.changelog-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;flex-wrap:wrap;gap:16px}
.changelog-head h2{font-family:var(--display);font-weight:400;font-size:clamp(32px,4vw,52px);line-height:1.05;letter-spacing:-0.02em;color:var(--text)}
.cl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media (max-width:1100px){.cl-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.cl-grid{grid-template-columns:1fr}}
.cl-card{
  border:1px solid var(--edge-mid);border-radius:var(--r-lg);background:var(--card);
  overflow:hidden;display:flex;flex-direction:column;
  transition:border-color .25s var(--ease),transform .3s var(--ease),box-shadow .3s var(--ease);
}
.cl-card:hover{
  border-color:var(--edge-strong);transform:translateY(-3px);
  box-shadow:0 18px 40px -22px rgba(10,10,15,0.18);
}

.cl-body{padding:24px 26px 28px;display:flex;flex-direction:column;gap:12px;flex:1}
.cl-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cl-meta .new{color:var(--brand);background:rgba(37,99,235,0.10);padding:3px 8px;border-radius:5px;font-size:9.5px}
.cl-card h4{font-family:var(--display);font-weight:400;font-size:clamp(17px,1.5vw,20px);color:var(--text);line-height:1.25;letter-spacing:-0.012em;margin:0}
.cl-card p{font-size:13.5px;color:var(--text-soft);line-height:1.55;margin:0}
.cl-card .cl-arr{margin-top:auto;color:var(--text-mid);font-size:13px;display:inline-flex;align-items:center;gap:6px;padding-top:6px}
.cl-card:hover .cl-arr{color:var(--text)}

/* ─────────────────── highlights — simple cards "Ressources récentes" ─────────────────── */
.highlights{padding:clamp(72px,9vw,120px) 0;border-top:1px solid var(--edge)}
.hl-head{margin-bottom:48px}
.hl-head h2{font-family:var(--display);font-weight:400;font-size:clamp(28px,3.4vw,44px);line-height:1.05;letter-spacing:-0.02em;color:var(--text)}
.hl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:880px){.hl-grid{grid-template-columns:1fr}}
.hl-card{
  border:1px solid var(--edge-mid);border-radius:var(--r-lg);background:var(--card);
  padding:32px;min-height:240px;display:flex;flex-direction:column;gap:14px;
  text-decoration:none;color:inherit;
  transition:border-color .25s var(--ease),background .25s var(--ease),transform .3s var(--ease);
}
.hl-card:hover{
  border-color:var(--edge-strong);background:var(--card-hi);transform:translateY(-3px);
}
.hl-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted)}
.hl-card h4{font-family:var(--display);font-weight:400;font-size:clamp(18px,1.7vw,22px);color:var(--text);line-height:1.25;letter-spacing:-0.012em;margin:0}
.hl-card p{font-size:13.5px;color:var(--text-soft);line-height:1.55;margin:0}
.hl-card .hl-arr{margin-top:auto;color:var(--text-mid);font-size:13px;display:inline-flex;align-items:center;gap:6px}
.hl-card:hover .hl-arr{color:var(--text)}

/* ─────────────────── sovereignty (slide 11 of deck) ─────────────────── */
.sovereignty{padding:clamp(96px,12vw,160px) 0;border-top:1px solid var(--edge);background:linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 100%)}
.sov-head{margin-bottom:64px;max-width:760px}
.sov-head .eyebrow{margin-bottom:18px;display:block}
.sov-head h2{
  font-family:var(--display);font-weight:400;
  font-size:clamp(36px,5vw,68px);line-height:1.02;letter-spacing:-0.025em;
  color:var(--text);margin-bottom:18px;
}
.sov-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
@media (max-width:1100px){.sov-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:780px){.sov-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.sov-grid{grid-template-columns:1fr}}
.sov-card{
  background:var(--card);border:1px solid var(--edge-mid);border-radius:var(--r-lg);
  padding:28px 24px;display:flex;flex-direction:column;gap:14px;
  transition:border-color .25s var(--ease),transform .3s var(--ease);
}
.sov-card:hover{border-color:var(--sovereign);transform:translateY(-3px)}
.sov-icon{
  width:44px;height:44px;border-radius:10px;
  background:rgba(109,40,217,0.08);color:var(--sovereign);
  display:flex;align-items:center;justify-content:center;
}
.sov-card h4{
  font-family:var(--display);font-weight:400;font-size:18px;
  color:var(--text);margin:0;letter-spacing:-0.01em;
}
.sov-card p{font-size:13px;color:var(--text-soft);line-height:1.5;margin:0}

.final{
  padding:clamp(120px,16vw,220px) 0 clamp(120px,16vw,220px);
  border-top:1px solid var(--edge);text-align:center;position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%,rgba(59,130,246,0.10),transparent 60%),
    var(--bg);
}
.final h2{
  font-family:var(--display);font-weight:400;
  font-size:clamp(36px,6vw,72px);line-height:1;letter-spacing:-0.03em;
  color:var(--text);margin:0 auto 16px;
}
.final .section-subtitle{
  font-size:clamp(16px,1.5vw,22px);
  margin:0 auto 48px;max-width:28ch;
}
.final-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;align-items:center}
.final-cta .btn-primary{padding:16px 32px;font-size:15px}

/* ─────────────────── compare (§09 Différenciation) ─────────────────── */
.compare{
  padding:clamp(96px,12vw,160px) 0;
  border-top:1px solid var(--edge);
  background:var(--bg);
}
.compare-grid{
  display:grid;
  grid-template-columns:minmax(0,40fr) minmax(0,60fr);
  gap:clamp(48px,6vw,96px);
  align-items:start;
}
@media (max-width:1100px){.compare-grid{grid-template-columns:1fr;gap:48px}}
.compare-head{max-width:480px}
.compare-head .eyebrow{margin-bottom:18px;display:block}
.compare-content .table-wrapper{max-width:960px}

/* Table wrapper avec scroll mobile */
.table-wrapper{position:relative;overflow:visible}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;position:relative}
.scroll-hint{
  display:none;
  text-align:center;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:12px;
}
@media (max-width:768px){.scroll-hint{display:block}}
.table-scroll::after{
  content:"";position:absolute;top:0;bottom:0;right:0;width:40px;
  background:linear-gradient(90deg,transparent,rgba(245,242,236,0.95));
  pointer-events:none;opacity:0;transition:opacity 0.3s;
}
@media (max-width:768px){
  .table-scroll::after{opacity:1}
  .table-scroll.scrolled-end::after{opacity:0}
}

/* Tableau comparatif */
.compare-table{
  width:100%;min-width:700px;border-collapse:collapse;
  background:var(--card);border:1px solid var(--edge-mid);
  border-radius:var(--r-lg);overflow:hidden;
}
.compare-table thead{background:#0F172A}
.compare-table th{
  padding:20px 24px;font-family:var(--body);font-size:14px;font-weight:600;
  letter-spacing:0.02em;color:#F5F2EC;text-align:center;
  border-bottom:1px solid rgba(255,255,255,0.1);
}
.compare-table th:first-child{
  text-align:left;font-family:var(--mono);font-size:11px;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted);
  background:#0F172A;position:sticky;left:0;z-index:2;
}
.compare-table th.col-krakin{color:var(--brand)}
.compare-table tbody tr{border-bottom:1px solid var(--edge)}
.compare-table tbody tr:last-child{border-bottom:none}
.compare-table tbody tr:hover{background:rgba(37,99,235,0.02)}
.compare-table td{
  padding:18px 24px;font-size:15px;color:var(--text-soft);
  text-align:center;vertical-align:middle;
}
.compare-table td:first-child{
  text-align:left;font-weight:500;color:var(--text);
  background:var(--card);position:sticky;left:0;z-index:1;
  border-right:1px solid var(--edge);
}
.compare-table td.col-krakin{background:rgba(37,99,235,0.08)}
.compare-table .check{color:var(--ok);font-size:20px;font-weight:700}
.compare-table .cross{color:var(--high);font-size:20px;font-weight:700}

.compare-closing{
  font-family:var(--display);font-style:italic;
  font-size:clamp(15px,1.3vw,18px);line-height:1.5;
  color:#6B7280;max-width:720px;margin:56px auto 0;text-align:center;
}

/* ─────────────────── faq (§12 Questions essentielles) ─────────────────── */
.faq{
  padding:clamp(96px,12vw,160px) 0;
  border-top:1px solid var(--edge);
  background:linear-gradient(180deg,var(--bg-soft) 0%,var(--bg) 100%);
}
.faq-head{max-width:600px;margin:0 0 64px}
.faq-head .eyebrow{margin-bottom:18px;display:block}
.faq-list{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:12px}

/* Accordéon item — cards claires */
.faq-item{
  background:var(--card);
  border:1px solid var(--edge-mid);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,0.04);
  transition:border-color 0.2s var(--ease),box-shadow 0.2s var(--ease);
}
.faq-item:hover{border-color:var(--edge-strong)}
.faq-item.open{border-color:var(--brand);box-shadow:0 2px 8px rgba(37,99,235,0.08)}
.faq-question{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 24px;cursor:pointer;
  transition:background 0.2s var(--ease);min-height:48px;
}
.faq-question:hover{background:rgba(37,99,235,0.02)}
.faq-question-text{
  font-family:var(--body);font-size:16px;font-weight:600;
  color:var(--text);line-height:1.4;
}
.faq-question-num{
  font-family:var(--mono);font-size:11px;letter-spacing:0.10em;
  color:var(--brand);margin-right:12px;
}
.faq-icon{
  width:24px;height:24px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);
  transition:transform 0.25s var(--ease),color 0.25s var(--ease);
}
.faq-item.open .faq-icon{transform:rotate(45deg);color:var(--brand)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.25s var(--ease)}
.faq-item.open .faq-answer{max-height:500px}
.faq-answer-inner{
  padding:0 24px 24px;font-size:15px;line-height:1.65;color:var(--text-soft);
}

.faq-closing{text-align:center;margin-top:48px}
.faq-closing-text{
  font-family:var(--display);font-style:italic;
  font-size:clamp(15px,1.3vw,18px);line-height:1.5;
  color:#6B7280;margin-bottom:24px;
}
.faq-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;background:var(--text);color:#FFFFFF;
  border-radius:999px;font-weight:500;font-size:14px;
  text-decoration:none;transition:background 0.18s var(--ease);
}
.faq-cta:hover{background:#000}

/* ─────────────────── footer ─────────────────── */
.footer{padding:64px 0 32px;border-top:1px solid var(--edge);background:var(--bg)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:32px;margin-bottom:48px}
@media (max-width:880px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){.footer-top{grid-template-columns:1fr}}
.footer-brand .logo{font-size:clamp(20px,1.6vw,24px);display:block;margin-bottom:10px}
.footer-tag{color:var(--text-muted);font-size:13px;line-height:1.5;max-width:32ch}
.footer-col h4{font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-mid);font-weight:600;margin-bottom:18px}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.footer-col a{font-size:13.5px;color:var(--text-soft);transition:color .15s var(--ease)}
.footer-col a:hover{color:var(--text)}
.footer-bot{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--edge);font-size:12px;color:var(--text-muted);flex-wrap:wrap;gap:12px}
.footer-bot .left{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.footer-bot .badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.10em;text-transform:uppercase;color:var(--text-mid);border:1px solid var(--edge);padding:5px 9px;border-radius:6px}
