/* ============================================================
   PARQO — Landing page
   Direction AXLE : navy profond + bleu électrique, grotesque
   technique, fond ivoire froid, angles peu arrondis.
   S'appuie sur les tokens du design system (styles.css).
   ============================================================ */

html { scroll-behavior: smooth; }
body { overflow-x: hidden; }

.wrap { width: min(1180px, 100% - 48px); margin-inline: auto; }
.wrap-narrow { width: min(820px, 100% - 48px); margin-inline: auto; }

section { position: relative; }

/* Kicker mono label */
.kicker {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--accent-text);
}
.kicker::before {
  content: ""; width: 18px; height: 2px; border-radius: var(--radius-pill);
  background: var(--accent); display: inline-block;
}
.kicker.on-dark { color: var(--blue-200); }
.kicker.on-dark::before { background: var(--blue-500); }

/* ---- Boutons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  height: var(--control-h-lg); padding-inline: var(--space-5);
  border-radius: var(--radius-md); border: 1px solid transparent;
  font: var(--weight-semibold) var(--text-base)/1 var(--font-sans);
  cursor: pointer; white-space: nowrap; text-decoration: none;
  transition: var(--transition-base);
}
.btn:hover { text-decoration: none; }
.btn svg { width: 18px; height: 18px; }
.btn-primary { background: var(--accent); color: var(--text-on-accent); box-shadow: var(--shadow-sm); }
.btn-primary:hover { background: var(--accent-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-primary:active { background: var(--accent-active); transform: translateY(0); }
.btn-ghost-dark { background: rgba(255,255,255,.06); color: #fff; border-color: rgba(255,255,255,.18); }
.btn-ghost-dark:hover { background: rgba(255,255,255,.12); }
.btn-secondary { background: var(--surface-card); color: var(--text-strong); border-color: var(--border-default); }
.btn-secondary:hover { background: var(--surface-hover); }
.btn-sm { height: var(--control-h-md); padding-inline: var(--space-4); font-size: var(--text-sm); }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: var(--z-sticky);
  background: rgba(10, 20, 34, .72);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  transition: background var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out);
}
.nav.scrolled { background: rgba(10, 20, 34, .92); }
.nav-inner { display: flex; align-items: center; gap: var(--space-6); height: 64px; }
.brand { display: inline-flex; align-items: center; gap: var(--space-3); text-decoration: none; }
.brand:hover { text-decoration: none; }
.brand .mark { width: 30px; height: 30px; border-radius: 8px; flex: none; box-shadow: 0 2px 8px rgba(46,107,255,.4); }
.brand .word {
  font: var(--weight-bold) 21px/1 var(--font-display);
  letter-spacing: var(--tracking-tight); color: #fff;
}
.nav-links { display: flex; align-items: center; gap: var(--space-1); margin-left: var(--space-4); }
.nav-links a {
  color: rgba(233,238,246,.82); font: var(--weight-medium) var(--text-sm)/1 var(--font-sans);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm);
  transition: var(--transition-base);
}
.nav-links a:hover { color: #fff; background: rgba(255,255,255,.06); text-decoration: none; }
.nav-cta { margin-left: auto; display: flex; align-items: center; gap: var(--space-3); }
.nav-toggle { display: none; }

/* ============================================================
   HERO (sombre)
   ============================================================ */
.hero {
  position: relative; overflow: hidden;
  background:
    radial-gradient(120% 90% at 85% -10%, rgba(46,107,255,.30), transparent 55%),
    radial-gradient(80% 70% at 0% 100%, rgba(22,73,141,.45), transparent 60%),
    linear-gradient(180deg, #0A1422 0%, #0B2440 55%, #0B2E5C 100%);
  color: #fff;
}
.hero-grid-bg {
  position: absolute; inset: 0; pointer-events: none; opacity: .5;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(120% 80% at 70% 10%, #000 30%, transparent 75%);
          mask-image: radial-gradient(120% 80% at 70% 10%, #000 30%, transparent 75%);
}
.hero-inner {
  position: relative; display: grid; grid-template-columns: 1.05fr .95fr;
  gap: var(--space-16); align-items: center;
  padding: clamp(56px, 9vw, 110px) 0 clamp(64px, 9vw, 116px);
}
.hero h1 {
  color: #fff; font-size: clamp(38px, 5.4vw, 64px); line-height: 1.04;
  letter-spacing: -0.03em; margin-top: var(--space-5); text-wrap: balance;
}
.hero h1 .accent { color: var(--blue-200); }
.hero .lede {
  margin-top: var(--space-5); max-width: 30em;
  font-size: clamp(16px, 1.6vw, 19px); line-height: 1.6;
  color: rgba(214,221,232,.92);
}
.hero-form { margin-top: var(--space-8); max-width: 480px; }
.field-row {
  display: flex; gap: var(--space-2); background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.16); border-radius: var(--radius-md);
  padding: 6px; transition: var(--transition-base);
}
.field-row:focus-within { border-color: var(--blue-500); box-shadow: var(--focus-ring); background: rgba(255,255,255,.1); }
.field-row input {
  flex: 1; min-width: 0; background: transparent; border: 0; outline: 0;
  color: #fff; font: var(--weight-regular) var(--text-base)/1 var(--font-sans);
  padding-inline: var(--space-3);
}
.field-row input::placeholder { color: rgba(174,187,208,.8); }
.form-note {
  margin-top: var(--space-3); display: flex; align-items: center; gap: var(--space-2);
  font: var(--weight-regular) var(--text-xs)/1.4 var(--font-sans); color: rgba(174,187,208,.85);
}
.form-note svg { width: 14px; height: 14px; color: var(--green-500); flex: none; }
.form-success {
  display: none; align-items: center; gap: var(--space-3);
  padding: var(--space-4); border-radius: var(--radius-md);
  background: rgba(19,138,94,.16); border: 1px solid rgba(19,138,94,.4);
  color: #d9f2e6; font: var(--weight-medium) var(--text-sm)/1.4 var(--font-sans);
}
.form-success svg { width: 20px; height: 20px; color: #4ad9a0; flex: none; }
.hero-form.done .field-row, .hero-form.done .form-note, .hero-form.done .form-error { display: none; }
.hero-form.done .form-success { display: flex; }
.form-error {
  display: none; align-items: center; gap: var(--space-2);
  margin-top: var(--space-3);
  color: #e5534b;
  font: var(--weight-medium) var(--text-sm)/1.4 var(--font-sans);
}
.form-error svg { width: 14px; height: 14px; flex: none; }
.hero-form.invalid .form-error { display: flex; }
.hero-form.invalid .field-row { border-color: rgba(229,83,75,.6); box-shadow: 0 0 0 3px rgba(229,83,75,.18); }

.hero-trust {
  margin-top: var(--space-8); display: flex; flex-wrap: wrap; gap: var(--space-5) var(--space-6);
  align-items: center;
}
.hero-trust .stat { display: flex; flex-direction: column; gap: 2px; }
.hero-trust .stat b {
  font: var(--weight-semibold) var(--text-xl)/1 var(--font-display); color: #fff; letter-spacing: -0.02em;
}
.hero-trust .stat span { font: var(--weight-regular) var(--text-xs)/1 var(--font-sans); color: rgba(174,187,208,.85); }
.hero-trust .divider { width: 1px; height: 30px; background: rgba(255,255,255,.14); }

/* ---- Carte VIN flottante (visuel hero) ---- */
.vin-card {
  position: relative; background: var(--surface-card); color: var(--text-default);
  border-radius: var(--radius-lg); border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-lg); overflow: hidden;
  animation: floatUp .7s var(--ease-out) both;
}
.vin-card__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--border-subtle);
  background: var(--surface-sunken);
}
.vin-card__head .mono-label { color: var(--text-muted); }
.vin-card__head .dot-row { display: flex; gap: 6px; }
.vin-card__head .dot-row i { width: 9px; height: 9px; border-radius: 50%; background: var(--slate-200); }
.vin-card__body { padding: var(--space-5); }
.vin-input {
  display: flex; align-items: center; gap: var(--space-3);
  height: var(--control-h-lg); padding-inline: var(--space-4);
  border: 1.5px solid var(--accent); border-radius: var(--radius-md);
  background: var(--blue-50); box-shadow: var(--focus-ring);
}
.vin-input svg { width: 18px; height: 18px; color: var(--accent); flex: none; }
.vin-input .vin {
  font: var(--weight-medium) var(--text-md)/1 var(--font-mono);
  color: var(--navy-800); letter-spacing: .04em;
}
.vin-input .caret { width: 2px; height: 20px; background: var(--accent); margin-left: -2px; animation: blink 1.1s step-end infinite; }
.decode-row {
  margin-top: var(--space-4); display: flex; align-items: center; gap: var(--space-2);
  font: var(--weight-medium) var(--text-xs)/1 var(--font-sans); color: var(--green-600);
}
.decode-row svg { width: 14px; height: 14px; }
.decoded {
  margin-top: var(--space-3); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md); overflow: hidden;
}
.decoded__top { display: flex; gap: var(--space-4); padding: var(--space-4); }
.decoded__photo {
  width: 96px; height: 70px; border-radius: var(--radius-sm); flex: none;
  background-color: var(--slate-75);
  background-image: repeating-linear-gradient(135deg, var(--slate-100) 0 8px, var(--slate-75) 8px 16px);
  border: 1px solid var(--border-subtle);
  display: grid; place-items: center;
}
.decoded__photo span { font: var(--weight-medium) 8px/1.3 var(--font-mono); letter-spacing: .1em; color: var(--slate-400); text-transform: uppercase; text-align: center; }
.decoded__info { display: flex; flex-direction: column; justify-content: center; gap: 3px; min-width: 0; }
.decoded__info .model { font: var(--weight-semibold) var(--text-lg)/1.1 var(--font-display); color: var(--text-strong); letter-spacing: -0.02em; }
.decoded__info .trim { font: var(--weight-regular) var(--text-sm)/1.2 var(--font-sans); color: var(--text-muted); }
.decoded__info .meta { margin-top: 4px; display: flex; gap: var(--space-3); }
.decoded__info .meta span { font: var(--weight-medium) var(--text-xs)/1 var(--font-mono); color: var(--text-default); }
.decoded__prices { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--border-subtle); }
.decoded__prices .cell { padding: var(--space-3) var(--space-4); }
.decoded__prices .cell + .cell { border-left: 1px solid var(--border-subtle); }
.decoded__prices .cell .lbl { font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono); letter-spacing: .12em; text-transform: uppercase; color: var(--text-subtle); }
.decoded__prices .cell .val { margin-top: 5px; font: var(--weight-semibold) var(--text-xl)/1 var(--font-display); color: var(--navy-800); letter-spacing: -0.02em; }
.decoded__prices .cell .val.accent { color: var(--accent); }

.float-badge {
  position: absolute; z-index: 2; display: inline-flex; align-items: center; gap: var(--space-2);
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-pill); padding: 7px var(--space-3); box-shadow: var(--shadow-md);
  font: var(--weight-medium) var(--text-xs)/1 var(--font-sans); color: var(--text-default);
  animation: floatUp .7s var(--ease-out) both;
}
.float-badge svg { width: 14px; height: 14px; }
.float-badge.b1 { top: -16px; right: 24px; animation-delay: .12s; }
.float-badge.b1 svg { color: var(--accent); }
.float-badge.b2 { bottom: -16px; left: -18px; animation-delay: .24s; }
.float-badge.b2 svg { color: var(--green-500); }
.vin-stage { position: relative; }

/* ============================================================
   BANDE INTÉGRATIONS
   ============================================================ */
.logos {
  padding: var(--space-8) 0; border-bottom: 1px solid var(--border-subtle);
  background: var(--surface-card);
}
.logos-inner { display: flex; align-items: center; gap: var(--space-8); flex-wrap: wrap; justify-content: center; }
.logos .lead { font: var(--weight-medium) var(--text-2xs)/1.4 var(--font-mono); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-subtle); }
.logos .src {
  font: var(--weight-semibold) var(--text-md)/1 var(--font-display);
  letter-spacing: -0.01em; color: var(--slate-500); transition: color var(--duration-base) var(--ease-out);
}
.logos .src:hover { color: var(--navy-800); }

/* ============================================================
   SECTIONS CLAIRES — entêtes
   ============================================================ */
.section { padding: clamp(64px, 9vw, 112px) 0; }
.section.sunken { background: var(--surface-sunken); border-block: 1px solid var(--border-subtle); }
.section-head { max-width: 640px; }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head h2 {
  margin-top: var(--space-4); font-size: clamp(28px, 3.6vw, 42px); line-height: 1.08;
  letter-spacing: -0.025em; color: var(--text-strong); text-wrap: balance;
}
.section-head p {
  margin-top: var(--space-4); font-size: var(--text-lg); line-height: 1.6; color: var(--text-muted);
  text-wrap: pretty;
}

/* ---- Features grid ---- */
.features-grid {
  margin-top: var(--space-12);
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4);
}
.feature {
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-6);
  box-shadow: var(--shadow-xs); transition: var(--transition-base);
}
.feature:hover { box-shadow: var(--shadow-md); border-color: var(--border-default); transform: translateY(-2px); }
.feature .ico {
  width: 42px; height: 42px; border-radius: var(--radius-md);
  display: grid; place-items: center; background: var(--accent-tint); color: var(--accent);
  margin-bottom: var(--space-5);
}
.feature .ico svg { width: 21px; height: 21px; }
.feature h3 { font: var(--weight-semibold) var(--text-lg)/1.2 var(--font-display); letter-spacing: -0.01em; color: var(--text-strong); }
.feature p { margin-top: var(--space-2); font: var(--weight-regular) var(--text-sm)/1.55 var(--font-sans); color: var(--text-muted); }

/* ============================================================
   COMMENT ÇA MARCHE
   ============================================================ */
.steps { margin-top: var(--space-12); display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); position: relative; }
.step { position: relative; }
.step .num {
  width: 38px; height: 38px; border-radius: var(--radius-md);
  display: grid; place-items: center;
  background: var(--navy-800); color: #fff;
  font: var(--weight-semibold) var(--text-md)/1 var(--font-mono);
  box-shadow: var(--shadow-sm);
}
.step h3 { margin-top: var(--space-4); font: var(--weight-semibold) var(--text-lg)/1.2 var(--font-display); letter-spacing: -0.01em; color: var(--text-strong); }
.step p { margin-top: var(--space-2); font: var(--weight-regular) var(--text-sm)/1.55 var(--font-sans); color: var(--text-muted); }
.step:not(:last-child)::after {
  content: ""; position: absolute; top: 19px; left: 50px; right: -10px; height: 1px;
  background: linear-gradient(90deg, var(--border-default), transparent);
}

/* ============================================================
   APERÇU APP (mock)
   ============================================================ */
.appwin {
  margin-top: var(--space-12); border-radius: var(--radius-xl); overflow: hidden;
  border: 1px solid var(--border-default); box-shadow: var(--shadow-lg);
  background: var(--surface-card);
}
.appwin__bar {
  display: flex; align-items: center; gap: var(--space-3);
  height: 44px; padding-inline: var(--space-4);
  background: var(--navy-900); border-bottom: 1px solid rgba(255,255,255,.06);
}
.appwin__bar .tl { display: flex; gap: 7px; }
.appwin__bar .tl i { width: 11px; height: 11px; border-radius: 50%; background: rgba(255,255,255,.2); }
.appwin__bar .addr {
  margin-left: var(--space-2); display: inline-flex; align-items: center; gap: var(--space-2);
  font: var(--weight-medium) var(--text-xs)/1 var(--font-mono); color: rgba(214,221,232,.7);
}
.appwin__bar .addr svg { width: 13px; height: 13px; color: var(--green-500); }
.appwin__body { display: grid; grid-template-columns: 196px 1fr; min-height: 460px; }

.appside { background: var(--navy-900); padding: var(--space-4); display: flex; flex-direction: column; gap: 3px; }
.appside .grp { font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono); letter-spacing: .14em; text-transform: uppercase; color: rgba(132,147,173,.7); padding: var(--space-3) var(--space-3) var(--space-2); }
.appside .item {
  display: flex; align-items: center; gap: var(--space-3);
  padding: 9px var(--space-3); border-radius: var(--radius-sm);
  font: var(--weight-medium) var(--text-sm)/1 var(--font-sans); color: rgba(214,221,232,.82);
}
.appside .item svg { width: 17px; height: 17px; opacity: .85; }
.appside .item.active { background: rgba(46,107,255,.18); color: #fff; box-shadow: inset 2px 0 0 var(--blue-500); }
.appside .item.active svg { color: var(--blue-200); opacity: 1; }

.appmain { padding: var(--space-6); background: var(--surface-page); overflow: hidden; }
.appmain__head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; }
.appmain__head h4 { font: var(--weight-semibold) var(--text-2xl)/1 var(--font-display); letter-spacing: -0.02em; color: var(--text-strong); }
.appmain__head .sub { margin-top: 4px; font: var(--weight-regular) var(--text-xs)/1 var(--font-sans); color: var(--text-muted); }
.app-cta { display: inline-flex; align-items: center; gap: var(--space-2); height: 34px; padding-inline: var(--space-3); border-radius: var(--radius-md); background: var(--accent); color: #fff; font: var(--weight-semibold) var(--text-sm)/1 var(--font-sans); }
.app-cta svg { width: 15px; height: 15px; }

.kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); margin-top: var(--space-5); }
.kpi { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); padding: var(--space-4); }
.kpi .lbl { font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono); letter-spacing: .1em; text-transform: uppercase; color: var(--text-subtle); }
.kpi .v { margin-top: 6px; font: var(--weight-semibold) var(--text-2xl)/1 var(--font-display); letter-spacing: -0.02em; color: var(--navy-800); }
.kpi .v small { font-size: var(--text-sm); color: var(--text-muted); font-weight: var(--weight-medium); }
.kpi .chg { font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono); margin-top: 6px; display: inline-flex; gap: 3px; align-items: center; }
.kpi .chg.up { color: var(--green-600); }

.app-table { margin-top: var(--space-5); background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); overflow: hidden; }
.app-table table { width: 100%; border-collapse: collapse; }
.app-table thead th {
  text-align: left; padding: var(--space-3) var(--space-4);
  font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono); letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-subtle); background: var(--surface-sunken); border-bottom: 1px solid var(--border-subtle);
  white-space: nowrap;
}
.app-table tbody td { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--border-subtle); font: var(--weight-regular) var(--text-sm)/1.2 var(--font-sans); color: var(--text-default); }
.app-table tbody tr:last-child td { border-bottom: 0; }
.app-table tbody tr:hover td { background: var(--surface-hover); }
.app-table .veh { display: flex; align-items: center; gap: var(--space-3); }
.app-table .veh .thumb {
  width: 42px; height: 32px; border-radius: 5px; flex: none;
  background-color: var(--slate-75);
  background-image: repeating-linear-gradient(135deg, var(--slate-100) 0 6px, var(--slate-75) 6px 12px);
  border: 1px solid var(--border-subtle);
}
.app-table .veh b { font: var(--weight-semibold) var(--text-sm)/1.15 var(--font-sans); color: var(--text-strong); display: block; }
.app-table .veh span { font: var(--weight-regular) var(--text-xs)/1.15 var(--font-sans); color: var(--text-muted); }
.app-table .vincell { font: var(--weight-medium) var(--text-xs)/1 var(--font-mono); color: var(--text-muted); letter-spacing: .02em; }
.app-table .price { font: var(--weight-semibold) var(--text-md)/1 var(--font-display); color: var(--navy-800); letter-spacing: -0.01em; text-align: right; }

.sbadge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 9px; border-radius: var(--radius-pill); font: var(--weight-medium) var(--text-2xs)/1 var(--font-sans); white-space: nowrap; }
.sbadge i { width: 6px; height: 6px; border-radius: 50%; }
.sbadge.available { background: var(--status-available-bg); color: var(--status-available-fg); }
.sbadge.available i { background: var(--green-500); }
.sbadge.reserved { background: var(--status-reserved-bg); color: var(--status-reserved-fg); }
.sbadge.reserved i { background: var(--amber-500); }
.sbadge.sold { background: var(--status-sold-bg); color: var(--status-sold-fg); }
.sbadge.sold i { background: var(--sold-500); }

/* ============================================================
   ORG (multi-sites / vendeurs / objectifs)
   ============================================================ */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-16); align-items: center; }
.org-list { margin-top: var(--space-7); display: flex; flex-direction: column; gap: var(--space-5); }
.org-item { display: flex; gap: var(--space-4); }
.org-item .ico { width: 40px; height: 40px; border-radius: var(--radius-md); flex: none; display: grid; place-items: center; background: var(--surface-card); border: 1px solid var(--border-default); color: var(--navy-800); }
.org-item .ico svg { width: 19px; height: 19px; }
.org-item h4 { font: var(--weight-semibold) var(--text-md)/1.3 var(--font-display); color: var(--text-strong); letter-spacing: -0.01em; }
.org-item p { margin-top: 3px; font: var(--weight-regular) var(--text-sm)/1.55 var(--font-sans); color: var(--text-muted); }

/* Carte vendeur (visuel) */
.seller-card { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); overflow: hidden; }
.seller-card__head { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-5); border-bottom: 1px solid var(--border-subtle); }
.seller-card__head .ava { width: 44px; height: 44px; border-radius: var(--radius-pill); background: linear-gradient(135deg, var(--blue-500), var(--navy-700)); color: #fff; display: grid; place-items: center; font: var(--weight-semibold) var(--text-md)/1 var(--font-display); flex: none; }
.seller-card__head .who b { font: var(--weight-semibold) var(--text-md)/1.2 var(--font-display); color: var(--text-strong); display: block; }
.seller-card__head .who span { font: var(--weight-regular) var(--text-xs)/1 var(--font-sans); color: var(--text-muted); }
.seller-card__head .month { margin-left: auto; font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono); letter-spacing: .1em; text-transform: uppercase; color: var(--text-subtle); }
.seller-card__body { padding: var(--space-5); display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); }
.goal .goal-top { display: flex; align-items: baseline; justify-content: space-between; }
.goal .goal-top .lbl { font: var(--weight-medium) var(--text-xs)/1 var(--font-sans); color: var(--text-muted); }
.goal .goal-top .pct { font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono); color: var(--accent-text); }
.goal .bignum { margin-top: var(--space-2); font: var(--weight-semibold) var(--text-3xl)/1 var(--font-display); letter-spacing: -0.02em; color: var(--navy-800); }
.goal .bignum small { font-size: var(--text-sm); color: var(--text-muted); font-weight: var(--weight-medium); }
.goal .bar { margin-top: var(--space-3); height: 7px; border-radius: var(--radius-pill); background: var(--slate-100); overflow: hidden; }
.goal .bar > i { display: block; height: 100%; border-radius: var(--radius-pill); background: var(--accent); }
.goal .bar.green > i { background: var(--green-500); }
.goal .sub { margin-top: var(--space-2); font: var(--weight-regular) var(--text-2xs)/1.3 var(--font-sans); color: var(--text-subtle); }
.seller-card__foot { padding: var(--space-4) var(--space-5); background: var(--surface-sunken); border-top: 1px solid var(--border-subtle); display: flex; justify-content: space-between; align-items: center; }
.seller-card__foot .lbl { font: var(--weight-regular) var(--text-xs)/1 var(--font-sans); color: var(--text-muted); }
.seller-card__foot .val { font: var(--weight-semibold) var(--text-md)/1 var(--font-display); color: var(--green-600); }

/* ============================================================
   OUTILS VENDEUR (bande de chips)
   ============================================================ */
.tools { margin-top: var(--space-10); display: flex; flex-wrap: wrap; gap: var(--space-3); }
.tool-chip {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: 10px var(--space-4); border-radius: var(--radius-pill);
  background: var(--surface-card); border: 1px solid var(--border-default);
  font: var(--weight-medium) var(--text-sm)/1 var(--font-sans); color: var(--text-default);
  box-shadow: var(--shadow-xs); transition: var(--transition-base);
}
.tool-chip:hover { border-color: var(--accent); color: var(--navy-800); }
.tool-chip svg { width: 16px; height: 16px; color: var(--accent); }

/* ============================================================
   PLATEFORMES
   ============================================================ */
.platforms { display: flex; flex-wrap: wrap; gap: var(--space-4); margin-top: var(--space-10); justify-content: center; }
.plat {
  display: flex; flex-direction: column; align-items: center; gap: var(--space-3);
  width: 156px; padding: var(--space-6) var(--space-4); border-radius: var(--radius-lg);
  background: var(--surface-card); border: 1px solid var(--border-subtle); box-shadow: var(--shadow-xs);
  transition: var(--transition-base);
}
.plat:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.plat .pico { width: 40px; height: 40px; color: var(--navy-800); display: grid; place-items: center; }
.plat .pico svg { width: 30px; height: 30px; }
.plat b { font: var(--weight-semibold) var(--text-md)/1 var(--font-display); color: var(--text-strong); }
.plat span { font: var(--weight-regular) var(--text-2xs)/1 var(--font-mono); letter-spacing: .08em; text-transform: uppercase; color: var(--text-subtle); }

/* ============================================================
   CTA finale (sombre)
   ============================================================ */
.cta {
  position: relative; overflow: hidden; color: #fff;
  background:
    radial-gradient(90% 120% at 100% 0%, rgba(46,107,255,.32), transparent 55%),
    linear-gradient(180deg, #0B2E5C 0%, #0A1422 100%);
}
.cta-inner { padding: clamp(64px, 9vw, 104px) 0; text-align: center; position: relative; }
.cta h2 { color: #fff; font-size: clamp(30px, 4.4vw, 50px); line-height: 1.06; letter-spacing: -0.03em; text-wrap: balance; }
.cta p { margin: var(--space-4) auto 0; max-width: 40em; font-size: var(--text-lg); line-height: 1.6; color: rgba(214,221,232,.9); }
.cta .hero-form { margin-inline: auto; margin-top: var(--space-8); }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list { margin-top: var(--space-10); border-top: 1px solid var(--border-subtle); }
.faq-item { border-bottom: 1px solid var(--border-subtle); }
.faq-q {
  width: 100%; background: none; border: 0; cursor: pointer; text-align: left;
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  padding: var(--space-5) 0; color: var(--text-strong);
  font: var(--weight-semibold) var(--text-lg)/1.3 var(--font-display); letter-spacing: -0.01em;
}
.faq-q .chev { flex: none; width: 22px; height: 22px; color: var(--accent); transition: transform var(--duration-base) var(--ease-out); }
.faq-item.open .faq-q .chev { transform: rotate(180deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height var(--duration-slow) var(--ease-out); }
.faq-a p { padding: 0 0 var(--space-5); margin: 0; max-width: 60ch; font: var(--weight-regular) var(--text-base)/1.65 var(--font-sans); color: var(--text-muted); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--navy-900); color: rgba(214,221,232,.7); padding: var(--space-16) 0 var(--space-8); }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--space-8); }
.footer .brand .word { color: #fff; }
.footer-blurb { margin-top: var(--space-4); max-width: 28em; font: var(--weight-regular) var(--text-sm)/1.6 var(--font-sans); color: rgba(174,187,208,.85); }
.footer-col h5 { font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono); letter-spacing: .14em; text-transform: uppercase; color: rgba(132,147,173,.9); margin-bottom: var(--space-4); }
.footer-col a { display: block; color: rgba(214,221,232,.78); font: var(--weight-regular) var(--text-sm)/1 var(--font-sans); padding: var(--space-2) 0; }
.footer-col a:hover { color: #fff; text-decoration: none; }
.footer-bottom {
  margin-top: var(--space-12); padding-top: var(--space-6); border-top: 1px solid rgba(255,255,255,.08);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap;
}
.footer-bottom .legal { font: var(--weight-regular) var(--text-xs)/1.5 var(--font-sans); color: rgba(132,147,173,.85); }
.footer-bottom .pro { display: inline-flex; align-items: center; gap: var(--space-2); font: var(--weight-medium) var(--text-2xs)/1 var(--font-mono); letter-spacing: .08em; text-transform: uppercase; color: rgba(174,187,208,.8); }
.footer-bottom .pro svg { width: 14px; height: 14px; color: var(--blue-400, var(--blue-500)); }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes floatUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
@keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: 0; } }

@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s var(--ease-out), transform .6s var(--ease-out); }
  .reveal.in { opacity: 1; transform: none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1000px) {
  .hero-inner { grid-template-columns: 1fr; gap: var(--space-12); }
  .vin-stage { max-width: 480px; }
  .features-grid { grid-template-columns: repeat(2, 1fr); }
  .steps { grid-template-columns: repeat(2, 1fr); gap: var(--space-8); }
  .step:not(:last-child)::after { display: none; }
  .split { grid-template-columns: 1fr; gap: var(--space-10); }
  .appwin__body { grid-template-columns: 1fr; }
  .appside { flex-direction: row; overflow-x: auto; gap: var(--space-1); }
  .appside .grp { display: none; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
}
@media (max-width: 680px) {
  .wrap, .wrap-narrow { width: 100% - 32px; width: calc(100% - 32px); }
  .nav-links { display: none; }
  .nav-links.open {
    display: flex; flex-direction: column; position: absolute; top: 64px; left: 0; right: 0;
    background: rgba(10,20,34,.97); padding: var(--space-4); gap: var(--space-1);
    border-bottom: 1px solid rgba(255,255,255,.08); margin: 0;
  }
  .nav-links.open a { padding: var(--space-3); }
  .nav-toggle { display: inline-grid; place-items: center; width: 40px; height: 40px; border-radius: var(--radius-sm); background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16); color: #fff; cursor: pointer; }
  .nav-toggle svg { width: 20px; height: 20px; }
  .nav-cta .btn:not(.nav-toggle) { display: none; }
  .features-grid { grid-template-columns: 1fr; }
  .steps { grid-template-columns: 1fr; }
  .kpis { grid-template-columns: 1fr 1fr; }
  .seller-card__body { grid-template-columns: 1fr; }
  .field-row { flex-direction: column; }
  .field-row .btn { width: 100%; }
  .hero-trust .divider { display: none; }
  .footer-top { grid-template-columns: 1fr; }
  .app-table { overflow-x: auto; }
  .app-table table { min-width: 540px; }
}
