  /* ════════════════════════════════════════════════════════════════
     Direction A — Éditorial clair (façon 1x.tech)
     Palette : crème, noir, accent violet ponctuel
     Typo : Instrument Serif (titres) + Inter (texte)
     ════════════════════════════════════════════════════════════════ */
  :root {
    --cream:       #fbfbfc;
    --cream-soft:  #f1f1f3;
    --ink:         #1a1a1a;
    --ink-soft:    #4a4a4a;
    --ink-mute:    #6f6f6f;
    --accent:      #6b46c1;
    --line:        rgba(0,0,0,0.10);
    --display:     -apple-system, BlinkMacSystemFont, "SF Pro Display", "Geist", "Inter", system-ui, sans-serif;
    --text:        -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", system-ui, sans-serif;
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html, body { background: var(--cream); color: var(--ink); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; max-width: 100%; overflow-x: clip; }
  body {
    font-family: var(--text); font-size: 16px; line-height: 1.55;
    /* tabular-nums : chiffres alignés en colonne — détail de pro */
    font-feature-settings: "tnum", "ss01", "kern";
    font-variant-numeric: tabular-nums;
  }
  a { color: inherit; text-decoration: none; }

  /* Conteneur fluide façon thème pro (Shopify/WordPress) : largeur max élargie
     pour mieux remplir les grands écrans, et marges latérales FLUIDES (clamp)
     qui grandissent/rétrécissent en douceur selon l'écran → s'adapte à tous les PC. */
  .container { width: 100%; max-width: 1520px; margin: 0 auto; padding: 0 clamp(20px, 4vw, 56px); }

  /* ── NAV ──────────────────────────────────────────── */
  .nav { padding: 22px 0; border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 100; background: var(--cream, #fbfbfc); }
  .nav-inner {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 24px;
  }
  .nav-inner > .logo  { justify-self: start; }
  .nav-inner > .nav-links { justify-self: center; }
  .nav-inner > .nav-cta { justify-self: end; }
  .logo { font-family: var(--display); font-size: 22px; font-weight: 600;
          letter-spacing: -0.035em; }
  .logo .dot { color: var(--accent); }
  .nav-links { display: flex; gap: 42px; font-size: 12px; text-transform: uppercase;
               letter-spacing: 0.14em; color: var(--ink-mute); font-weight: 500; }
  .nav-links a:hover { color: var(--ink); }
  .nav-cta { display: flex; gap: 12px; align-items: center; }
  .btn-pill {
    display: inline-flex; align-items: center; gap: 10px;
    background: var(--ink); color: var(--cream); padding: 10px 22px;
    border-radius: 999px; font-size: 13.5px; font-weight: 500;
    transition: background .2s;
  }
  .btn-pill:hover { background: var(--accent); }
  .btn-pill-light {
    background: transparent; color: var(--ink); border: 1px solid var(--ink);
  }
  .btn-pill-light:hover { background: var(--ink); color: var(--cream); }

  /* ── MENU BURGER MOBILE (construit par mobile-nav.js) ─────────── */
  .nav-burger {
    display: none;
    flex-direction: column; justify-content: center; gap: 5px;
    width: 42px; height: 38px; padding: 0 10px;
    border: 1px solid var(--line); border-radius: 12px;
    background: #fff; cursor: pointer;
  }
  .nav-burger span {
    display: block; height: 2px; width: 100%;
    background: var(--ink); border-radius: 2px;
    transition: transform .22s ease, opacity .18s ease;
  }
  .nav-burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-burger.open span:nth-child(2) { opacity: 0; }
  .nav-burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  .mobile-menu {
    display: none; position: fixed; inset: 0; z-index: 200;
    background: rgba(250,250,247,0.97);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
  }
  .mobile-menu.open { display: block; animation: mm-fade .2s ease; }
  @keyframes mm-fade { from { opacity: 0; } to { opacity: 1; } }
  .mobile-menu-top {
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 20px;
    border-bottom: 1px solid var(--line);
  }
  .mobile-menu-close {
    display: inline-flex; align-items: center; justify-content: center;
    width: 42px; height: 38px;
    border: 1px solid var(--line); border-radius: 12px;
    background: #fff; color: var(--ink); cursor: pointer;
  }
  .mobile-menu-close svg { width: 22px; height: 22px; }
  .mobile-menu-inner {
    display: flex; flex-direction: column;
    padding: 28px 24px 32px;
    max-width: 480px; margin: 0 auto;
  }
  .mobile-menu-inner > a {
    font-family: var(--display);
    font-size: 22px; font-weight: 600; letter-spacing: -0.025em;
    color: var(--ink);
    padding: 16px 4px;
    border-bottom: 1px solid var(--line);
  }
  .mobile-menu-inner > a:active { color: var(--accent); }
  .mobile-menu-cta {
    display: flex; flex-direction: column; gap: 12px;
    margin-top: 28px;
  }
  .mobile-menu-cta .btn-pill, .mobile-menu-cta .btn-pill-light {
    width: 100%; justify-content: center;
    padding: 14px 24px; font-size: 15px;
  }

  /* ── HERO ASYMÉTRIQUE ──────────────────────────────── */
  .hero {
    /* ⚠️ padding HORIZONTAL = clamp comme .container : le raccourci ne doit PAS
       remettre la marge gauche/droite à 0 (sinon le hero est collé au bord et
       désaligné par rapport à la nav). */
    padding: 64px clamp(20px, 4vw, 56px) 96px;
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 80px;
    align-items: start;   /* haut aligné : l'eyebrow ne "flotte" plus au milieu */
  }
  .hero-text { padding-left: 0; padding-top: 8px; }   /* aligné sur le logo de la nav */
  .hero-eyebrow {
    font-size: 13px; text-transform: uppercase; letter-spacing: 0.16em;
    color: var(--ink-mute); margin-bottom: 16px; font-weight: 500;
    line-height: 1.5;
  }
  .hero-title {
    font-family: var(--display);
    /* Titre éditorial : plus grand, plus magazine */
    font-size: clamp(36px, 5.6vw, 76px);
    line-height: 1.05; font-weight: 700; letter-spacing: -0.038em;
    margin-bottom: 36px;
    text-wrap: balance;
    padding-bottom: 0.15em;
    overflow: visible;
  }
  .hero-title .accent {
    /* Couleur UNIE (plus de background-clip:text). Sur du texte italique, le
       clip du dégradé coupait le débord des lettres penchées (le « s » final).
       En couleur unie le glyphe italique est peint en entier → zéro clipping.
       L'italique vient du <em>. Pour la teinte profonde de marque : var(--accent). */
    color: #8b5cf6;
    font-weight: 500;
  }
  .hero-sub {
    /* Sous-titre éditorial : large, léger, contraste fort avec le titre lourd */
    font-size: 20px; font-weight: 400; color: var(--ink-soft);
    max-width: 480px;
    line-height: 1.6; margin-bottom: 44px;
  }
  .hero-cta { display: flex; gap: 14px; }

  /* ── Galerie "Trouvailles" (vraies photos Vinted) ───────────────── */
  .finds { padding: 56px 0 16px; }
  .finds-head { max-width: 640px; margin: 0 auto 34px; text-align: center; }
  .finds-eyebrow { font-size: 12px; text-transform: uppercase; letter-spacing: .16em; color: var(--ink-mute); font-weight: 600; }
  .finds-title { font-family: var(--display); font-size: clamp(26px, 3.4vw, 40px); font-weight: 700;
                 letter-spacing: -0.028em; margin: 10px 0 12px; line-height: 1.1; }
  .finds-sub { font-size: 16px; color: var(--ink-soft); line-height: 1.55; }
  .finds-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(206px, 1fr)); gap: 18px; }
  .find-card { background: #fff; border: 1px solid var(--line); border-radius: 16px; overflow: hidden;
               transition: transform .18s, box-shadow .18s; }
  .find-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(17,12,34,.14); }
  .find-ph { position: relative; aspect-ratio: 3 / 4; background: var(--cream-soft); overflow: hidden; }
  .find-ph img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .35s; }
  .find-card:hover .find-ph img { transform: scale(1.05); }
  .find-margin { position: absolute; top: 12px; right: 12px; background: rgba(22,163,74,.95); color: #fff;
                 font-family: var(--display); font-weight: 700; font-size: 15px; padding: 5px 11px; border-radius: 999px;
                 box-shadow: 0 4px 12px rgba(22,163,74,.35); }
  .find-body { padding: 12px 14px 14px; }
  .find-model { font-weight: 600; font-size: 14px; color: var(--ink); }
  .find-brand { font-size: 12px; color: var(--ink-mute); margin-top: 2px; }
  .find-meta { font-size: 12px; color: var(--ink-soft); margin-top: 8px; font-variant-numeric: tabular-nums; }
  .find-model.blur, .find-brand.blur { filter: blur(5px); -webkit-filter: blur(5px); user-select: none; pointer-events: none; }
  @media (max-width: 600px) { .finds { padding: 40px 0 8px; } .finds-grid { grid-template-columns: 1fr 1fr; gap: 12px; } }

  /* MOCKUP DASHBOARD — photo produit en perspective (brief : Stripe/Apple style) */
  .mockup-wrap {
    position: relative;
    perspective: 1500px;
  }
  .mockup {
    position: relative;
    background: #fff;
    border-radius: 20px;
    /* Inclinaison statique subtile pour évoquer une photo produit posée */
    transform: rotateY(-3deg) rotateX(2deg);
    transform-origin: center center;
    /* Ombre douce, longue, étalée — pas de cadre, frontière par l'ombre seule */
    box-shadow:
      0 1px 2px rgba(0, 0, 0, 0.03),
      0 8px 24px rgba(0, 0, 0, 0.05),
      0 60px 120px rgba(0, 0, 0, 0.08);
    padding: 24px;
    transition: transform .8s cubic-bezier(.22,.61,.36,1);
  }
  /* Au survol : le mockup se redresse doucement, comme si on l'examinait */
  .mockup-wrap:hover .mockup {
    transform: rotateY(0deg) rotateX(0deg);
  }
  @media (prefers-reduced-motion: reduce) {
    .mockup { transform: none; transition: none; }
  }
  .mockup-head {
    display: grid; grid-template-columns: auto 1fr auto;
    align-items: center; gap: 12px;
    padding-bottom: 16px; border-bottom: 1px solid var(--line);
    margin-bottom: 20px;
  }
  .mockup-head-brand {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--display); font-weight: 600;
    font-size: 13px; letter-spacing: -0.018em;
    color: var(--ink);
  }
  .mockup-head-brand::before {
    content: ''; width: 8px; height: 8px; border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 0 3px rgba(107,70,193,0.18);
  }
  .mockup-url {
    justify-self: center;
    font-size: 11.5px; color: var(--ink-mute);
    background: var(--cream-soft); padding: 4px 12px;
    border-radius: 999px;
    font-variant-numeric: tabular-nums;
    font-family: var(--text);
    max-width: 100%; min-width: 0;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  }
  .mockup-head-status {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 11px; color: var(--ink-mute);
    font-family: var(--display); font-weight: 500;
  }
  .mockup-head-status::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: #16a34a;
    box-shadow: 0 0 0 3px rgba(22,163,74,0.18);
    animation: la-pulse 2.4s ease-in-out infinite;
  }
  @keyframes la-pulse {
    0%, 100% { box-shadow: 0 0 0 3px rgba(22,163,74,0.18); }
    50%      { box-shadow: 0 0 0 6px rgba(22,163,74,0.08); }
  }
  /* legacy : dots conservés invisibles au cas où */
  .mockup-dot { display: none; }

  .mockup-cards {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
    margin-bottom: 20px;
  }
  .mockup-card {
    background: var(--cream); border-radius: 12px; padding: 14px 16px;
  }
  .mockup-card-label { font-size: 10px; color: var(--ink-mute); text-transform: uppercase;
                       letter-spacing: 0.08em; margin-bottom: 6px; }
  .mockup-card-value { font-family: var(--display); font-size: 28px;
                       font-weight: 600; line-height: 1; letter-spacing: -0.02em;
                       font-variant-numeric: tabular-nums; }
  .mockup-card-value.up { color: var(--accent); }
  .mockup-card-sub { font-size: 11px; color: var(--ink-mute); margin-top: 6px; }

  .mockup-row {
    display: grid; grid-template-columns: 1fr auto auto auto; gap: 16px;
    align-items: center; padding: 12px 16px;
    border: 1px solid var(--line); border-radius: 10px;
    margin-bottom: 8px; font-size: 13px;
  }
  .mockup-row-img { width: 44px; height: 44px; border-radius: 11px; margin-right: 11px;
                    display: inline-flex; align-items: center; justify-content: center;
                    vertical-align: middle; color: #fff; flex: none; position: relative;
                    overflow: hidden;
                    box-shadow: inset 0 1px 0 rgba(255,255,255,.40), 0 3px 8px rgba(17,12,34,.12);
                    background: linear-gradient(135deg, #a78bfa, var(--accent)); }
  /* reflet "photo" en haut de la vignette */
  .mockup-row-img::after { content:""; position:absolute; inset:0;
                    background: radial-gradient(120% 80% at 25% 0%, rgba(255,255,255,.34), transparent 60%); }
  .mockup-row-img svg { width: 22px; height: 22px; position: relative; z-index: 1; }
  .mockup-row-img.tint-game    { background: linear-gradient(135deg, #fb7185, #e11d48); }
  .mockup-row-img.tint-fashion { background: linear-gradient(135deg, #f0abfc, #c026d3); }
  .mockup-row-img.tint-bag     { background: linear-gradient(135deg, #fcd34d, #d97706); }
  .mockup-row-img.tint-beauty  { background: linear-gradient(135deg, #fda4af, #e11d48); }
  .mockup-row-img.tint-audio   { background: linear-gradient(135deg, #818cf8, #4f46e5); }
  .mockup-row-img.tint-watch   { background: linear-gradient(135deg, #94a3b8, #475569); }
  .mockup-row-img.tint-shoe    { background: linear-gradient(135deg, #5eead4, #0d9488); }
  /* "Mystère" : on FLOUTE le modèle / la marque / la marge à côté des photos
     (on montre qu'on a trouvé des pépites, mais il faut s'abonner pour les voir). */
  .mockup-row.mystery .mockup-row-title,
  .mockup-row.mystery .mockup-row-brand,
  .mockup-row.mystery .mockup-row-tag {
    filter: blur(5px);
    -webkit-filter: blur(5px);
    user-select: none; pointer-events: none;
  }
  /* vignette = vraie photo produit */
  .mockup-row-img.photo { background: var(--cream-soft); }
  .mockup-row-img.photo::after { display: none; }
  .mockup-row-img.photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .mockup-row-title { font-weight: 500; }
  .mockup-row-brand { font-size: 11px; color: var(--ink-mute); display: block; margin-top: 2px; }
  .mockup-row-price { font-family: var(--display); font-size: 17px; font-weight: 600;
                      letter-spacing: -0.01em; font-variant-numeric: tabular-nums; }
  .mockup-row-tag {
    background: var(--accent); color: #fff;
    padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 500;
  }
  .mockup-row-tag.muted { background: var(--cream-soft); color: var(--ink-soft); }
  .mockup-row-action {
    padding: 5px 12px; border: 1px solid var(--line); border-radius: 6px;
    font-size: 11px;
  }

  /* ── MOCKUP : SCÈNES + PAGINATION ─────────────────── */
  .mockup-stage { display: grid; min-height: 360px; }
  .mockup-scene {
    grid-area: 1 / 1;
    opacity: 0; pointer-events: none;
    transform: translateY(10px);
    transition: opacity .4s ease, transform .55s cubic-bezier(.22,.61,.36,1);
  }
  .mockup-scene.active { opacity: 1; pointer-events: auto; transform: translateY(0); }
  .mockup-scene.active .mockup-card {
    animation: cardIn .5s cubic-bezier(.22,.61,.36,1) backwards;
  }
  .mockup-scene.active .mockup-card:nth-child(1) { animation-delay: .00s; }
  .mockup-scene.active .mockup-card:nth-child(2) { animation-delay: .12s; }
  .mockup-scene.active .mockup-card:nth-child(3) { animation-delay: .24s; }
  @keyframes cardIn {
    from { opacity: 0; transform: translateY(8px) scale(0.96); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
  }

  .mockup-scene.active .mockup-row,
  .mockup-scene.active .scn-line {
    animation: rowIn .55s cubic-bezier(.22,.61,.36,1) backwards;
  }
  .mockup-scene[data-scene="0"].active .mockup-row:nth-of-type(1) { animation-delay: .85s; }
  .mockup-scene[data-scene="0"].active .mockup-row:nth-of-type(2) { animation-delay: 1.05s; }
  .mockup-scene[data-scene="0"].active .mockup-row:nth-of-type(3) { animation-delay: 1.25s; }
  .mockup-scene.active .scn-line:nth-of-type(1) { animation-delay: .10s; }
  .mockup-scene.active .scn-line:nth-of-type(2) { animation-delay: .20s; }
  .mockup-scene.active .scn-line:nth-of-type(3) { animation-delay: .30s; }
  .mockup-scene.active .scn-line:nth-of-type(4) { animation-delay: .40s; }
  /* Scènes hors scène 1 : rows en stagger plus serré (pour le cycle de pagination) */
  .mockup-scene:not([data-scene="0"]).active .mockup-row:nth-of-type(1) { animation-delay: .10s; }
  .mockup-scene:not([data-scene="0"]).active .mockup-row:nth-of-type(2) { animation-delay: .20s; }
  .mockup-scene:not([data-scene="0"]).active .mockup-row:nth-of-type(3) { animation-delay: .30s; }
  @keyframes rowIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

  /* — Scène 2 : Scan en cours — */
  .scn-scan-head { display: flex; align-items: center; gap: 12px; margin-bottom: 16px;
                   padding-bottom: 14px; border-bottom: 1px solid var(--line); }
  .scn-spinner { width: 14px; height: 14px; border: 2px solid var(--line);
                 border-top-color: var(--accent); border-radius: 50%;
                 animation: spin .8s linear infinite; }
  @keyframes spin { to { transform: rotate(360deg); } }
  .scn-scan-title { font-weight: 600; font-size: 14px; }
  .scn-scan-cat { font-size: 12px; color: var(--ink-mute); margin-left: auto; }
  .scn-progress { background: var(--cream-soft); border-radius: 999px; height: 8px;
                  overflow: hidden; margin: 18px 0 10px; }
  .scn-progress-fill {
    height: 100%; background: linear-gradient(90deg, var(--accent), #8b5cf6);
    width: 0; border-radius: 999px;
    animation: fillBar 3.6s ease-out forwards;
  }
  .mockup-scene.active .scn-progress-fill { animation: fillBar 3.6s ease-out forwards; }
  @keyframes fillBar { to { width: 62%; } }
  .scn-progress-meta { display: flex; justify-content: space-between;
                       font-size: 12px; color: var(--ink-mute); margin-bottom: 18px;
                       font-variant-numeric: tabular-nums; }
  .scn-progress-meta strong { color: var(--ink); font-family: var(--display);
                              font-weight: 600; }
  .scn-line {
    display: grid; grid-template-columns: auto 1fr auto; gap: 14px;
    align-items: center; padding: 10px 14px;
    border: 1px solid var(--line); border-radius: 10px;
    margin-bottom: 8px; font-size: 13px;
  }
  .scn-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
  .scn-line-title { font-weight: 500; }
  .scn-line-meta { font-size: 11px; color: var(--ink-mute); }
  .scn-line-price { font-family: var(--display); font-weight: 600; font-size: 14px;
                    color: #16a34a; font-variant-numeric: tabular-nums; }

  /* — Scène 3 : Tracker — */
  .scn-tracker-head { display: flex; justify-content: space-between; align-items: flex-end;
                       padding-bottom: 16px; border-bottom: 1px solid var(--line); margin-bottom: 18px; }
  .scn-tracker-id { display: flex; align-items: center; gap: 10px; min-width: 0; }
  .scn-tracker-thumb { width: 38px; height: 38px; border-radius: 9px; overflow: hidden; flex: none;
                       background: var(--cream-soft);
                       box-shadow: inset 0 0 0 1px rgba(0,0,0,.05), 0 2px 6px rgba(17,12,34,.12); }
  .scn-tracker-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .scn-tracker-title { font-family: var(--display); font-weight: 600;
                       letter-spacing: -0.022em; font-size: 17px; }
  .scn-tracker-sub { font-size: 12px; color: var(--ink-mute); margin-top: 4px; }
  .scn-tracker-badge { background: rgba(22,163,74,0.12); color: #16a34a;
                       padding: 4px 10px; border-radius: 999px; font-size: 11px;
                       font-weight: 600; font-variant-numeric: tabular-nums; }
  .scn-sparkline { width: 100%; height: 110px; display: block; margin-bottom: 18px; }
  .scn-tracker-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
  .scn-tracker-kpi { background: var(--cream); border-radius: 10px; padding: 12px 14px; }
  .scn-tracker-kpi-lbl { font-size: 10px; color: var(--ink-mute);
                         text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 4px; }
  .scn-tracker-kpi-val { font-family: var(--display); font-size: 20px; font-weight: 600;
                          letter-spacing: -0.018em; font-variant-numeric: tabular-nums; }

  /* — Scène 4 : Filtre v-tools — */
  .scn-vt-confirm {
    background: linear-gradient(135deg, rgba(107,70,193,0.08), rgba(139,92,246,0.04));
    border: 1px solid rgba(107,70,193,0.18);
    border-radius: 12px; padding: 16px 18px; margin-bottom: 16px;
    display: grid; grid-template-columns: 36px 1fr; gap: 14px; align-items: center;
  }
  .scn-vt-check {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--accent); color: #fff;
    display: grid; place-items: center;
    font-size: 18px; font-weight: 700;
  }
  .scn-vt-confirm-title { font-weight: 600; font-size: 14px; }
  .scn-vt-confirm-sub { font-size: 12px; color: var(--ink-mute); margin-top: 2px; }
  .scn-alert-h { font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em;
                 color: var(--ink-mute); margin-bottom: 10px; }

  /* — Paginator — */
  .mockup-paginator {
    display: grid; grid-template-columns: repeat(4, 1fr);
    background: #fff; border: 1px solid var(--line); border-radius: 14px;
    margin-top: 18px; overflow: hidden;
    box-shadow: 0 4px 14px rgba(0,0,0,0.04);
  }
  .mockup-paginator button {
    appearance: none; border: 0; background: transparent;
    border-right: 1px solid var(--line);
    padding: 13px 14px 14px; text-align: left;
    font: inherit; cursor: pointer; color: var(--ink-mute);
    transition: background .2s, color .2s;
    position: relative; overflow: hidden;
    display: flex; flex-direction: column; gap: 3px;
  }
  .mockup-paginator button:last-child { border-right: 0; }
  .mockup-paginator button:hover { color: var(--ink); background: var(--cream); }
  .mockup-paginator button.active { color: var(--ink); background: var(--cream); }
  .mockup-paginator button.active::after {
    content: ''; position: absolute; left: 0; bottom: 0; height: 2px;
    background: var(--accent); width: 100%;
    transform-origin: left center; transform: scaleX(0);
    animation: pagiBar 4.5s linear forwards;
  }
  @keyframes pagiBar { to { transform: scaleX(1); } }
  .mockup-paginator .num { font-size: 10px; letter-spacing: 0.14em; opacity: 0.55;
                            font-weight: 600; font-family: var(--display);
                            font-variant-numeric: tabular-nums; }
  .mockup-paginator .lbl { font-size: 13px; font-weight: 500; line-height: 1.2; }

  @media (max-width: 700px) {
    .mockup-paginator { grid-template-columns: 1fr 1fr; }
    .mockup-paginator button:nth-child(2) { border-right: 0; }
    .mockup-paginator button:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  }

  /* ── TICKER STATS ──────────────────────────────────── */
  .ticker {
    border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
    padding: 28px 0; margin-top: 40px;
  }
  .ticker-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px;
  }
  .ticker-stat { padding: 0 8px; }
  .ticker-num {
    font-family: var(--display); font-size: 48px;
    line-height: 1; font-weight: 600; letter-spacing: -0.035em;
    margin-bottom: 6px; font-variant-numeric: tabular-nums;
  }
  .ticker-lbl { font-size: 13px; color: var(--ink-mute); }

  /* ── SECTION FEATURE — magazine éditorial ──────────── */
  section.feature {
    /* Respirations gigantesques entre sections — brief: 120-160px */
    padding: 160px 0;
    /* Plus de border-bottom : la frontière se fait par l'espace et le ton */
    border-bottom: none;
  }
  /* Variante alternance ton magazine : fond gris très clair */
  section.feature.alt,
  section.section-alt {
    background: var(--cream-soft);
  }
  .feature-row {
    display: grid; grid-template-columns: 1fr 1.1fr; gap: 100px;
    align-items: center;
  }
  .feature-row.reverse { direction: rtl; }
  .feature-row.reverse > * { direction: ltr; }
  .feature-visual {
    position: relative;
    background: transparent;
    padding: 0;
    border-radius: 0;
    box-shadow: none;
  }

  /* — Visuel "Le moteur" : titre brut → fiche extraite — */
  .engine-stage { display: grid; gap: 16px; }

  /* Animation au scroll : tout est invisible avant in-view */
  .engine-stage .engine-card,
  .engine-stage .engine-arrow,
  .engine-stage .engine-fiche {
    opacity: 0; transform: translateY(14px);
    transition: opacity .55s cubic-bezier(.22,.61,.36,1),
                transform .65s cubic-bezier(.22,.61,.36,1);
  }
  .engine-stage .engine-fiche-row,
  .engine-stage .engine-verdict {
    opacity: 0; transform: translateY(6px);
    transition: opacity .35s cubic-bezier(.22,.61,.36,1),
                transform .4s cubic-bezier(.22,.61,.36,1);
  }
  /* Marks du titre brut : highlight s'allume un par un */
  .engine-stage .engine-title mark {
    box-shadow: inset 0 0 0 transparent !important;
    transition: box-shadow .5s cubic-bezier(.22,.61,.36,1);
  }
  /* Marge nette : grossit en final */
  .engine-stage .engine-fiche-row.hl strong.margin {
    font-size: 17px;
    transition: font-size .45s cubic-bezier(.22,.61,.36,1),
                color .45s ease;
  }

  /* État in-view : la séquence se déroule */
  .engine-stage.in-view .engine-card { opacity: 1; transform: none; }
  .engine-stage.in-view .engine-arrow { opacity: 1; transform: none; transition-delay: 1.15s; }
  .engine-stage.in-view .engine-fiche { opacity: 1; transform: none; transition-delay: 1.35s; }

  /* Marks allumés en cascade : .25s + 0.15s entre chacun */
  .engine-stage.in-view .engine-title mark {
    box-shadow: inset 0 -8px 0 rgba(107,70,193,0.18) !important;
  }
  .engine-stage.in-view .engine-title mark.brand {
    box-shadow: inset 0 -8px 0 rgba(22,163,74,0.20) !important;
  }
  .engine-stage.in-view .engine-title mark.price {
    box-shadow: inset 0 -8px 0 rgba(251,146,60,0.30) !important;
  }
  .engine-stage.in-view .engine-title mark:nth-of-type(1) { transition-delay: 0.40s; }
  .engine-stage.in-view .engine-title mark:nth-of-type(2) { transition-delay: 0.55s; }
  .engine-stage.in-view .engine-title mark:nth-of-type(3) { transition-delay: 0.70s; }
  .engine-stage.in-view .engine-title mark:nth-of-type(4) { transition-delay: 0.85s; }
  .engine-stage.in-view .engine-title mark:nth-of-type(5) { transition-delay: 1.00s; }

  /* Rows fiche en cascade après le fiche container (delay 1.35s) */
  .engine-stage.in-view .engine-fiche-row { opacity: 1; transform: none; }
  .engine-stage.in-view .engine-fiche-row:nth-of-type(2) { transition-delay: 1.55s; }
  .engine-stage.in-view .engine-fiche-row:nth-of-type(3) { transition-delay: 1.70s; }
  .engine-stage.in-view .engine-fiche-row:nth-of-type(4) { transition-delay: 1.85s; }
  .engine-stage.in-view .engine-fiche-row:nth-of-type(5) { transition-delay: 2.00s; }
  .engine-stage.in-view .engine-fiche-row:nth-of-type(6) { transition-delay: 2.15s; }
  .engine-stage.in-view .engine-fiche-row:nth-of-type(7) { transition-delay: 2.30s; }
  .engine-stage.in-view .engine-fiche-row:nth-of-type(8) { transition-delay: 2.45s; }
  .engine-stage.in-view .engine-fiche-row:nth-of-type(9) { transition-delay: 2.60s; }
  .engine-stage.in-view .engine-fiche-row:nth-of-type(10) { transition-delay: 2.75s; }

  /* La marge nette grossit en final, juste avant le verdict */
  .engine-stage.in-view .engine-fiche-row.hl strong.margin {
    font-size: 22px;
    transition-delay: 3.10s;
  }
  .engine-stage.in-view .engine-verdict {
    opacity: 1; transform: none;
    transition-delay: 3.25s;
  }

  @media (prefers-reduced-motion: reduce) {
    .engine-stage .engine-card,
    .engine-stage .engine-arrow,
    .engine-stage .engine-fiche,
    .engine-stage .engine-fiche-row,
    .engine-stage .engine-verdict {
      opacity: 1; transform: none; transition: none;
    }
  }
  .engine-card {
    background: #fff;
    border-radius: 12px;
    padding: 28px 30px;
    /* Ombre magazine : longue, douce, étalée — pas de border, pas de fond gris */
    box-shadow:
      0 1px 2px rgba(0, 0, 0, 0.03),
      0 8px 24px rgba(0, 0, 0, 0.04),
      0 50px 100px rgba(0, 0, 0, 0.06);
    position: relative;
  }
  .engine-card-head {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--ink-mute); margin-bottom: 10px;
  }
  .engine-badge { display: inline-flex; align-items: center; gap: 6px; }
  .engine-badge::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%; background: #fb923c;
  }
  .engine-title {
    font-size: 15px; line-height: 1.5; color: var(--ink-soft);
  }
  .engine-title mark {
    background: transparent; padding: 1px 3px; border-radius: 4px;
    color: var(--ink); font-weight: 500;
    box-shadow: inset 0 -8px 0 rgba(107,70,193,0.18);
  }
  .engine-title mark.brand   { box-shadow: inset 0 -8px 0 rgba(22,163,74,0.20); }
  .engine-title mark.price   { box-shadow: inset 0 -8px 0 rgba(251,146,60,0.30); }
  .engine-arrow {
    display: grid; place-items: center; font-size: 18px;
    color: var(--ink-mute); padding: 2px 0;
    position: relative;
  }
  .engine-arrow::before, .engine-arrow::after {
    content: ''; flex: 1; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(0,0,0,0.18), transparent);
    width: 60px;
  }
  .engine-arrow span {
    background: rgba(107,70,193,0.12); color: var(--accent);
    border-radius: 999px; padding: 4px 14px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.08em;
    text-transform: uppercase; font-family: var(--display);
  }
  .engine-fiche {
    background: #fff;
    border-radius: 12px;
    padding: 28px 30px;
    box-shadow:
      0 1px 2px rgba(0, 0, 0, 0.03),
      0 8px 24px rgba(0, 0, 0, 0.04),
      0 50px 100px rgba(0, 0, 0, 0.06);
  }
  .engine-fiche-head {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--ink-mute); margin-bottom: 14px;
    padding-bottom: 12px; border-bottom: 1px solid var(--line);
  }
  .engine-fiche-head::before {
    content: '✓'; display: inline-flex; align-items: center; gap: 6px;
    color: #16a34a; font-weight: 700; margin-right: 6px;
  }
  .engine-fiche-row {
    display: flex; justify-content: space-between;
    padding: 8px 0; font-size: 14px;
  }
  .engine-fiche-row > span { color: var(--ink-mute); }
  .engine-fiche-row > strong {
    font-weight: 500; color: var(--ink);
    font-variant-numeric: tabular-nums;
  }
  .engine-fiche-row.hl > strong {
    font-family: var(--display); font-weight: 600;
    letter-spacing: -0.015em;
  }
  .engine-fiche-row.hl > strong.margin {
    color: #16a34a; font-size: 17px;
  }
  .engine-fiche-row.total {
    margin: 6px 0;
    padding: 10px 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    font-size: 14px;
  }
  .engine-fiche-row.total > span { color: var(--ink); font-weight: 500; }
  .engine-fiche-row.total > strong {
    font-family: var(--display); font-weight: 600;
    letter-spacing: -0.015em; font-size: 16px;
  }
  .engine-verdict {
    margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line);
    display: flex; align-items: center; gap: 10px;
    font-family: var(--display); font-weight: 600;
    letter-spacing: -0.015em; font-size: 15px;
    color: #16a34a;
  }
  .engine-verdict::before {
    content: ''; width: 8px; height: 8px; border-radius: 50%;
    background: #16a34a;
    box-shadow: 0 0 0 4px rgba(22,163,74,0.18);
  }

  /* — Visuel "Trackers" : niche surveillée dans le temps — */
  .tracker-stage { display: grid; gap: 14px; }
  .tracker-head {
    background: #fff; border-radius: 16px; padding: 20px 24px;
    box-shadow:
      0 1px 2px rgba(0,0,0,0.04),
      0 8px 24px rgba(0,0,0,0.06),
      0 32px 60px rgba(0,0,0,0.08);
    display: flex; justify-content: space-between; align-items: center;
  }
  .tracker-id { display: flex; align-items: center; gap: 13px; min-width: 0; }
  .tracker-thumb {
    width: 48px; height: 48px; border-radius: 12px; overflow: hidden; flex: none;
    background: var(--cream-soft);
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.05), 0 3px 8px rgba(17,12,34,.12);
  }
  .tracker-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .tracker-eyebrow {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--ink-mute); margin-bottom: 4px;
    display: flex; align-items: center; gap: 8px;
  }
  .tracker-eyebrow::before {
    content: ''; width: 7px; height: 7px; border-radius: 50%;
    background: #16a34a;
    box-shadow: 0 0 0 4px rgba(22,163,74,0.18);
    animation: pulse 2s ease-in-out infinite;
  }
  @keyframes pulse {
    0%, 100% { box-shadow: 0 0 0 4px rgba(22,163,74,0.18); }
    50%      { box-shadow: 0 0 0 7px rgba(22,163,74,0.08); }
  }
  .tracker-name {
    font-family: var(--display); font-weight: 600;
    letter-spacing: -0.025em; font-size: 19px;
  }
  .tracker-period { display: flex; gap: 4px;
                    background: var(--cream); border-radius: 999px; padding: 3px; }
  .tracker-period button {
    appearance: none; border: 0; background: transparent;
    padding: 5px 12px; border-radius: 999px;
    font: inherit; font-size: 12px; color: var(--ink-mute);
    cursor: pointer; font-weight: 500;
  }
  .tracker-period button.active { background: var(--ink); color: var(--cream); }
  .tracker-graph {
    background: #fff; border-radius: 16px; padding: 18px 24px 22px;
    box-shadow:
      0 1px 2px rgba(0,0,0,0.04),
      0 8px 24px rgba(0,0,0,0.06),
      0 32px 60px rgba(0,0,0,0.08);
  }
  .tracker-graph-lbl {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--ink-mute); margin-bottom: 10px;
    display: flex; justify-content: space-between; align-items: center;
  }
  .tracker-graph-lbl .legend {
    display: inline-flex; align-items: center; gap: 6px;
    text-transform: none; letter-spacing: 0; font-size: 12px;
  }
  .tracker-graph-lbl .legend::before {
    content: ''; width: 14px; height: 2px; background: var(--accent); border-radius: 2px;
  }
  .tracker-graph svg { width: 100%; height: 130px; display: block; }
  .tracker-kpis {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
  }
  .tracker-kpi {
    background: #fff; border-radius: 14px; padding: 14px 16px;
    box-shadow:
      0 1px 2px rgba(0,0,0,0.04),
      0 6px 18px rgba(0,0,0,0.05);
  }
  .tracker-kpi-lbl {
    font-size: 10px; text-transform: uppercase; letter-spacing: 0.10em;
    color: var(--ink-mute); margin-bottom: 4px;
  }
  .tracker-kpi-val {
    font-family: var(--display); font-weight: 600;
    letter-spacing: -0.022em; font-size: 22px;
    font-variant-numeric: tabular-nums;
  }
  .tracker-kpi-val .up { color: #16a34a; font-size: 13px; margin-left: 6px; font-weight: 500; }
  .tracker-feed {
    background: #fff; border-radius: 16px; padding: 18px 24px;
    box-shadow:
      0 1px 2px rgba(0,0,0,0.04),
      0 8px 24px rgba(0,0,0,0.06),
      0 32px 60px rgba(0,0,0,0.08);
  }
  .tracker-feed-h {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--ink-mute); margin-bottom: 12px;
    display: flex; justify-content: space-between;
  }
  .tracker-sale {
    display: grid; grid-template-columns: 1fr auto auto; gap: 12px;
    align-items: center; padding: 8px 0; font-size: 13px;
    border-bottom: 1px solid var(--line);
  }
  .tracker-sale:last-child { border-bottom: 0; }
  .tracker-sale-title { font-weight: 500; }
  .tracker-sale-meta { font-size: 11px; color: var(--ink-mute); display: block; margin-top: 2px; }
  .tracker-sale-px {
    font-family: var(--display); font-weight: 600;
    font-variant-numeric: tabular-nums; font-size: 14px;
  }
  .tracker-sale-tag {
    font-size: 10px; padding: 3px 8px; border-radius: 999px;
    background: rgba(22,163,74,0.12); color: #16a34a;
    font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em;
  }

  /* ── SECTION "POUR QUI" ─────────────────────────────── */
  .for-who { padding: 120px 0; border-bottom: 1px solid var(--line); }
  .for-who-intro {
    display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px;
    align-items: end; margin-bottom: 64px;
  }
  .for-who-h {
    font-family: var(--display);
    font-size: clamp(30px, 4.4vw, 58px); font-weight: 600;
    line-height: 1.12; letter-spacing: -0.032em; max-width: 460px;
    text-wrap: balance;
    padding-bottom: 0.08em;
    overflow-wrap: break-word;
  }
  .for-who-h em {
    font-style: normal; font-weight: 500;
    background: linear-gradient(180deg, var(--accent), #8b5cf6);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .for-who-sub { font-size: 17px; color: var(--ink-soft); max-width: 460px; line-height: 1.55; }
  .for-who-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  }
  .for-who-card {
    background: #fff; border-radius: 20px; padding: 32px;
    position: relative; transition: transform .3s ease;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
    display: flex; flex-direction: column;
  }
  .for-who-card:hover { transform: translateY(-4px); }
  .for-who-card.featured { background: var(--ink); color: var(--cream); transform: translateY(-12px); }
  .for-who-card.featured:hover { transform: translateY(-16px); }
  .for-who-num {
    font-family: var(--display); font-weight: 600;
    font-size: 13px; letter-spacing: 0.16em;
    color: var(--ink-mute); margin-bottom: 32px;
    display: flex; align-items: center; gap: 10px;
  }
  .for-who-num::after {
    content: ''; flex: 1; height: 1px; background: var(--line);
  }
  .for-who-card.featured .for-who-num { color: rgba(255,255,255,0.65); }
  .for-who-card.featured .for-who-num::after { background: rgba(255,255,255,0.12); }
  .for-who-title {
    font-family: var(--display); font-weight: 600;
    font-size: 26px; letter-spacing: -0.025em; line-height: 1.15;
    margin-bottom: 12px;
  }
  .for-who-desc { font-size: 15px; color: var(--ink-soft); line-height: 1.5; margin-bottom: 28px; flex: 1; }
  .for-who-card.featured .for-who-desc { color: rgba(255,255,255,0.72); }
  .for-who-stats { display: grid; gap: 12px; padding-top: 20px;
                    border-top: 1px solid var(--line); }
  .for-who-card.featured .for-who-stats { border-color: rgba(255,255,255,0.12); }
  .for-who-stat { display: flex; justify-content: space-between; align-items: baseline;
                  font-size: 13px; }
  .for-who-stat-lbl { color: var(--ink-mute); }
  .for-who-card.featured .for-who-stat-lbl { color: rgba(255,255,255,0.55); }
  .for-who-stat-val {
    font-family: var(--display); font-weight: 600;
    letter-spacing: -0.015em; font-variant-numeric: tabular-nums;
    font-size: 17px;
  }
  .for-who-plan {
    margin-top: 24px; padding: 8px 14px;
    background: var(--cream); border-radius: 999px;
    font-size: 12px; color: var(--ink-mute);
    display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
  }
  .for-who-card.featured .for-who-plan {
    background: rgba(255,255,255,0.10); color: rgba(255,255,255,0.85);
  }
  .for-who-plan strong { color: var(--ink); font-weight: 600; }
  .for-who-card.featured .for-who-plan strong { color: var(--accent); }
  /* Affordance cliquable : flèche qui glisse + profondeur au survol (les cartes mènent aux plans) */
  .for-who-card { cursor: pointer; }
  .for-who-card:hover { box-shadow: 0 18px 50px rgba(26,26,26,0.10); }
  .for-who-card.featured:hover { box-shadow: 0 22px 60px rgba(26,26,26,0.30); }
  .for-who-plan::after {
    content: '→'; margin-left: 2px; display: inline-block; opacity: .55;
    transition: transform .25s ease, opacity .25s ease;
  }
  .for-who-card:hover .for-who-plan::after { transform: translateX(5px); opacity: 1; }
  @media (max-width: 900px) {
    .for-who-intro, .for-who-grid { grid-template-columns: 1fr; gap: 32px; }
    .for-who-card.featured, .for-who-card.featured:hover { transform: none; }
  }

  /* ── FAQ ────────────────────────────────────────────── */
  .faq { padding: 120px 0; border-bottom: 1px solid var(--line); }
  .faq-grid {
    display: grid; grid-template-columns: 0.9fr 1.3fr; gap: 80px;
    align-items: start;
  }
  .faq-h {
    font-family: var(--display);
    font-size: clamp(30px, 4.4vw, 58px); font-weight: 600;
    line-height: 1.12; letter-spacing: -0.032em;
    margin-bottom: 24px;
    text-wrap: balance;
    padding-bottom: 0.08em;
    overflow-wrap: break-word;
  }
  .faq-h em {
    font-style: normal; font-weight: 500;
    background: linear-gradient(180deg, var(--accent), #8b5cf6);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .faq-intro { font-size: 17px; color: var(--ink-soft); line-height: 1.55;
               margin-bottom: 28px; }
  .faq-contact {
    padding: 20px; background: var(--cream-soft);
    border-radius: 14px; font-size: 14px;
  }
  .faq-contact strong { display: block; font-family: var(--display);
                        font-weight: 600; font-size: 16px; margin-bottom: 4px; }
  .faq-contact a { color: var(--accent); font-weight: 500; }
  .faq-list { border-top: 1px solid var(--line); }
  .faq-item { border-bottom: 1px solid var(--line); }
  .faq-item summary {
    list-style: none; cursor: pointer;
    padding: 24px 0; position: relative;
    font-family: var(--display); font-weight: 500;
    font-size: 19px; letter-spacing: -0.018em;
    padding-right: 48px;
    transition: color .2s;
  }
  .faq-item summary::-webkit-details-marker { display: none; }
  .faq-item summary:hover { color: var(--accent); }
  .faq-item summary::after {
    content: '+'; position: absolute; right: 0; top: 50%;
    transform: translateY(-50%);
    width: 32px; height: 32px;
    display: grid; place-items: center;
    border: 1px solid var(--line); border-radius: 50%;
    font-family: var(--display); font-weight: 400;
    font-size: 18px; line-height: 1;
    color: var(--ink-mute);
    transition: transform .25s ease, background .2s, color .2s;
  }
  .faq-item[open] summary::after {
    content: '−'; background: var(--ink); color: var(--cream);
    border-color: var(--ink);
  }
  .faq-item-body {
    padding: 0 0 28px;
    font-size: 15.5px; color: var(--ink-soft); line-height: 1.65;
    max-width: 620px;
  }
  .faq-item-body p + p { margin-top: 12px; }
  .faq-item-body a { color: var(--accent); }
  @media (max-width: 900px) {
    .faq-grid { grid-template-columns: 1fr; gap: 40px; }
  }
  .feature-eyebrow {
    display: inline-block; padding: 5px 14px; border: 1px solid var(--ink);
    border-radius: 999px; font-size: 11px; font-weight: 500;
    text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 24px;
  }
  .feature-date {
    display: inline-block; margin-left: 12px; font-size: 12px; color: var(--ink-mute);
  }
  .feature-title {
    font-family: var(--display);
    font-size: clamp(30px, 4.4vw, 58px); line-height: 1.12;
    font-weight: 600; letter-spacing: -0.032em; margin-bottom: 24px;
    text-wrap: balance;
    padding-bottom: 0.08em;
    overflow-wrap: break-word;
  }
  .feature-body {
    font-size: 17px; color: var(--ink-soft); max-width: 460px;
    line-height: 1.55; margin-bottom: 30px;
  }
  .feature-cta { display: flex; gap: 12px; }

  /* ── TABLE COMPARATIF Loopya vs Manuel ─────────────── */
  .compare-section { padding: 100px 0; }
  .compare-h2 {
    font-family: var(--display);
    font-size: clamp(30px, 4.4vw, 58px); font-weight: 600;
    line-height: 1.12; letter-spacing: -0.032em;
    margin-bottom: 56px; max-width: 760px;
    text-wrap: balance;
    padding-bottom: 0.08em;
    overflow-wrap: break-word;
  }
  .compare-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 40px;
  }
  .compare-col {
    background: #fff; border-radius: 18px; padding: 36px;
    border: 1px solid var(--line);
  }
  .compare-col.featured {
    background: var(--ink); color: var(--cream);
    border-color: var(--ink);
  }
  .compare-col-eyebrow { font-size: 12px; text-transform: uppercase;
                         letter-spacing: 0.12em; opacity: 0.65; margin-bottom: 16px; }
  .compare-col-title {
    font-family: var(--display); font-size: 30px; font-weight: 600;
    letter-spacing: -0.028em; margin-bottom: 24px;
  }
  .compare-col ul { list-style: none; }
  .compare-col li { padding: 12px 0; border-bottom: 1px solid var(--line); font-size: 15px;
                    display: flex; gap: 12px; align-items: flex-start; }
  .compare-col.featured li { border-color: rgba(255,255,255,0.12); }
  /* "À la main" = tirets sobres (la corvée) · "Avec Loopya" = coches violettes (le résultat) */
  .compare-col li::before {
    content: ''; flex-shrink: 0;
    width: 11px; height: 2px; border-radius: 2px; background: var(--ink-mute);
    margin-top: 10px;
  }
  .compare-col.featured li::before {
    width: 7px; height: 12px; border-radius: 0; background: none;
    margin: 2px 4px 0 1px;
    border: solid var(--accent); border-width: 0 2px 2px 0;
    transform: rotate(45deg);
  }

  /* ── PRICING ────────────────────────────────────────── */
  .pricing { padding: 100px 0; background: #fff; }
  .pricing-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
    margin-top: 56px;
  }
  .price-card {
    background: var(--cream); border-radius: 18px; padding: 36px 32px;
    position: relative; transition: transform .3s;
  }
  .price-card.featured { background: var(--ink); color: var(--cream); transform: scale(1.03); }
  .price-card-name {
    font-size: 13px; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--ink-mute); margin-bottom: 16px;
  }
  .price-card.featured .price-card-name { color: rgba(255,255,255,0.7); }
  .price-card-amount {
    font-family: var(--display);
    line-height: 1; font-weight: 600; letter-spacing: -0.035em;
    font-variant-numeric: tabular-nums;
    display: flex; align-items: baseline; gap: 8px;
  }
  .price-card-amount .big { font-size: 54px; }
  .price-card-amount .unit { font-size: 15px; color: var(--ink-mute); font-weight: 500;
                              letter-spacing: 0; }
  .price-card.featured .price-card-amount .unit { color: rgba(255,255,255,0.65); }
  .price-card ul { list-style: none; margin: 32px 0; }
  .price-card li { padding: 8px 0; font-size: 14px;
                   display: flex; gap: 8px; align-items: flex-start; }
  .price-card li::before {
    content: '→'; color: var(--accent); flex-shrink: 0;
  }

  /* ── FOOTER CTA ─────────────────────────────────────── */
  footer.final-cta {
    padding: 140px 0; text-align: center;
    background: var(--cream-soft);
  }
  .final-cta-h2 {
    font-family: var(--display);
    font-size: clamp(38px, 5.6vw, 80px); line-height: 1.04;
    font-weight: 600; letter-spacing: -0.036em;
    margin-bottom: 40px;
    text-wrap: balance;
  }
  .final-cta-h2 em {
    font-style: normal; font-weight: 500;
    background: linear-gradient(180deg, var(--accent) 0%, #8b5cf6 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  /* ── FOOTER ÉDITORIAL ───────────────────────────────── */
  footer.site-foot {
    background: var(--ink); color: var(--cream);
    padding: 80px 0 28px;
  }
  .foot-grid {
    display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr;
    gap: 56px; margin-bottom: 64px;
  }
  .foot-brand-logo {
    font-family: var(--display); font-size: 38px; font-weight: 600;
    letter-spacing: -0.04em; margin-bottom: 18px;
  }
  .foot-brand-logo .dot { color: var(--accent); }
  .foot-pitch {
    color: rgba(245,240,230,0.65);
    font-size: 15px; max-width: 320px; line-height: 1.5;
    margin-bottom: 24px;
  }
  .foot-beta {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(107,70,193,0.15); border: 1px solid rgba(107,70,193,0.35);
    color: #c4b5fd;
    padding: 6px 14px; border-radius: 999px;
    font-size: 12px; font-weight: 500;
  }
  .foot-beta::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: #c4b5fd;
    box-shadow: 0 0 0 4px rgba(196,181,253,0.18);
  }
  .foot-col h3 {
    font-family: var(--display); font-size: 12px;
    text-transform: uppercase; letter-spacing: 0.16em;
    font-weight: 600; color: rgba(245,240,230,0.5);
    margin-bottom: 22px;
  }
  .foot-col ul { list-style: none; }
  .foot-col li { margin-bottom: 12px; font-size: 14.5px; }
  .foot-col a {
    color: rgba(245,240,230,0.78);
    transition: color .2s;
  }
  .foot-col a:hover { color: var(--cream); }
  .foot-col .new {
    margin-left: 8px;
    font-size: 10px;
    padding: 2px 8px;
    background: var(--accent); color: #fff;
    border-radius: 999px;
    font-weight: 600;
    letter-spacing: 0.05em;
    vertical-align: 2px;
  }
  .foot-bar {
    padding-top: 28px;
    border-top: 1px solid rgba(245,240,230,0.10);
    display: flex; justify-content: space-between; align-items: center;
    font-size: 13px; color: rgba(245,240,230,0.5);
    flex-wrap: wrap; gap: 16px;
  }
  .foot-bar a { color: inherit; }
  .foot-bar a:hover { color: var(--cream); }
  .foot-bar-meta { display: flex; gap: 18px; align-items: center; }
  .foot-bar-meta .pill-status {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 10px; border-radius: 999px;
    background: rgba(22,163,74,0.12); border: 1px solid rgba(22,163,74,0.30);
    color: #86efac; font-size: 12px;
  }
  .foot-bar-meta .pill-status::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%; background: #4ade80;
  }
  @media (max-width: 900px) {
    .foot-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
    .foot-brand { grid-column: 1 / -1; }
    .foot-bar { justify-content: flex-start; }
  }

  /* ── VIEW TRANSITIONS (Chrome 126+) ───────────────────────────── */
  @view-transition { navigation: auto; }
  /* Tout le reste de la page : fade + slight slide */
  ::view-transition-old(root) {
    animation: vt-fade-out .22s cubic-bezier(.4,0,1,1) forwards;
  }
  ::view-transition-new(root) {
    animation: vt-fade-in .38s cubic-bezier(0,0,.2,1) forwards;
  }
  @keyframes vt-fade-out { to { opacity: 0; transform: translateY(-6px); } }
  @keyframes vt-fade-in  { from { opacity: 0; transform: translateY(10px); } }

  /* Shared elements : logo et CTA principal flottent en place */
  .nav .logo { view-transition-name: brand-logo; }
  .nav-cta > .btn-pill:not(.btn-pill-light) { view-transition-name: cta-primary; }
  ::view-transition-old(brand-logo),
  ::view-transition-new(brand-logo),
  ::view-transition-old(cta-primary),
  ::view-transition-new(cta-primary) {
    animation-duration: .48s;
    animation-timing-function: cubic-bezier(.22,.61,.36,1);
  }

  @media (prefers-reduced-motion: reduce) {
    ::view-transition-old(root), ::view-transition-new(root),
    ::view-transition-old(brand-logo), ::view-transition-new(brand-logo),
    ::view-transition-old(cta-primary), ::view-transition-new(cta-primary) {
      animation: none;
    }
  }

  /* ── ANIMATIONS SCROLL (.reveal) ────────────────────── */
  .reveal {
    opacity: 0; transform: translateY(24px);
    transition:
      opacity .7s cubic-bezier(.22,.61,.36,1),
      transform .8s cubic-bezier(.22,.61,.36,1);
    will-change: opacity, transform;
  }
  .reveal.in-view { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Hover boutons : élévation via box-shadow (brief : pas de translate-Y) */
  .btn-pill, .btn-pill-light {
    transition: background .25s ease, color .25s ease, border-color .25s ease,
                box-shadow .25s ease;
  }
  .btn-pill:hover {
    box-shadow: 0 8px 20px rgba(26, 26, 26, 0.18);
  }
  .btn-pill-light:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  }
  .for-who-card, .price-card, .compare-col, .engine-card, .engine-fiche, .tracker-head, .tracker-graph, .tracker-feed {
    transition: transform .4s cubic-bezier(.22,.61,.36,1), box-shadow .4s cubic-bezier(.22,.61,.36,1);
  }
  .price-card:hover { transform: translateY(-4px); box-shadow: 0 1px 2px rgba(0,0,0,0.04), 0 24px 48px rgba(0,0,0,0.08); }
  .price-card.featured:hover { transform: scale(1.03) translateY(-4px); }

  /* ── RESPONSIVE ─────────────────────────────────────── */
  @media (max-width: 900px) {
    .hero, .feature-row, .compare-grid, .pricing-grid, .ticker-grid {
      grid-template-columns: 1fr; gap: 40px;
    }
    .nav-inner { grid-template-columns: 1fr auto; }
    .nav-links { display: none; }
    .nav-cta > .btn-pill, .nav-cta > .btn-pill-light { display: none; }
    .nav-burger { display: inline-flex; }
    .hero-text { padding-left: 0; }
    .hero-sub { max-width: 100%; }
    section.feature { padding: 80px 0; }
  }

  /* — Tablette / petit desktop — */
  @media (max-width: 700px) {
    .container { padding: 0 24px; }
    .hero { padding: 48px 0 32px; gap: 32px; }
    .ticker { padding: 24px 0; }
    .ticker-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
    .ticker-num { font-size: 36px; }
    section.feature { padding: 64px 0; }
    .for-who, .compare-section, .pricing, .faq { padding: 64px 0; }
    .for-who-intro { gap: 32px; margin-bottom: 40px; }
    .for-who-grid { grid-template-columns: 1fr; gap: 20px; }
    .for-who-card.featured, .for-who-card.featured:hover { transform: none; }
    .compare-h2, .for-who-h, .faq-h, .feature-title { margin-bottom: 32px; }
    .compare-col { padding: 28px 24px; }
    .price-card { padding: 28px 24px; }
    .faq-grid { grid-template-columns: 1fr; gap: 40px; }
    footer.final-cta { padding: 80px 0; }
    .foot-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
    .foot-brand { grid-column: 1 / -1; }
    .foot-bar { justify-content: flex-start; }
  }

  /* — Mobile — */
  @media (max-width: 600px) {
    .container { padding: 0 20px; }
    .nav { padding: 16px 0; }
    .nav-cta-price { display: none; }
    .hero { padding: 32px 0 24px; gap: 28px; }
    .hero-eyebrow { font-size: 12px; margin-bottom: 18px; letter-spacing: 0.12em; }
    .hero-sub { font-size: 16px; margin-bottom: 28px; }
    .hero-cta { flex-direction: column; align-items: stretch; gap: 10px; }
    .hero-cta .btn-pill { justify-content: center; }
    .mockup { padding: 16px; border-radius: 16px; }
    .mockup-cards { grid-template-columns: 1fr; gap: 8px; margin-bottom: 14px; }
    .mockup-card { padding: 12px 14px; }
    .mockup-card-value { font-size: 22px; }
    .mockup-stage { min-height: 0; }
    .mockup-row { grid-template-columns: 1fr auto; gap: 10px; padding: 10px 12px; }
    .mockup-row-tag, .mockup-row-action { display: none; }
    .ticker-grid { grid-template-columns: 1fr 1fr; gap: 20px; }
    .ticker-num { font-size: 30px; }
    .ticker-lbl { font-size: 12px; }
    section.feature { padding: 56px 0; }
    .for-who, .compare-section, .pricing, .faq { padding: 56px 0; }
    .for-who-card { padding: 26px; }
    .compare-col { padding: 24px 20px; }
    .price-card { padding: 26px 22px; }
    .price-card-amount .big { font-size: 44px; }
    .scn-line, .mockup-row { font-size: 12.5px; }
    .scn-scan-head { flex-wrap: wrap; }
    .scn-scan-cat { margin-left: 0; font-size: 11px; }
    .scn-progress-meta { flex-direction: column; align-items: flex-start; gap: 4px; font-size: 11px; }
    .tracker-head { flex-direction: column; align-items: flex-start; gap: 14px; }
    .tracker-period { width: 100%; }
    .tracker-period button { flex: 1; }
    .tracker-kpis { grid-template-columns: 1fr; gap: 8px; }
    .tracker-sale { grid-template-columns: 1fr auto; gap: 8px; }
    .tracker-sale-tag { display: none; }
    .faq-q-contact, .topup-box { flex-direction: column; align-items: flex-start; gap: 14px; }
    footer.final-cta { padding: 64px 0; }
    .foot-grid { grid-template-columns: 1fr; gap: 32px; }
    .foot-brand-logo { font-size: 32px; }
  }

  /* — Petit mobile (375 / iPhone SE) — */
  @media (max-width: 420px) {
    .container { padding: 0 16px; }
    .hero-title { line-height: 1.08; }
    .feature-title, .compare-h2, .for-who-h, .faq-h {
      letter-spacing: -0.028em;
    }
    .btn-pill, .btn-pill-light { padding: 9px 18px; font-size: 13px; }
    .mockup-paginator .lbl { font-size: 12px; }
    .mockup-paginator .num { font-size: 9px; letter-spacing: 0.10em; }
  }

  /* ── COMPARATIF · LOOPYA vs AUTRES OUTILS ──────────────────────── */
  .vs-section { padding: 24px 0 100px; }
  .vs-h2 {
    font-family: var(--display);
    font-size: clamp(28px, 4vw, 50px); font-weight: 600;
    line-height: 1.13; letter-spacing: -0.03em;
    margin-bottom: 16px; max-width: 720px; text-wrap: balance;
  }
  .vs-sub {
    font-size: 17px; color: var(--ink-soft); line-height: 1.55;
    max-width: 660px; margin-bottom: 40px;
  }
  .vs-table {
    background: #fff; border: 1px solid var(--line); border-radius: 18px;
    overflow: hidden; max-width: 880px;
    box-shadow: 0 30px 60px rgba(0,0,0,0.05);
  }
  .vs-row {
    display: grid; grid-template-columns: 1fr 116px 116px;
    align-items: stretch; border-bottom: 1px solid var(--line);
  }
  .vs-row:last-child { border-bottom: none; }
  .vs-feat {
    padding: 15px 24px; font-size: 15px; color: var(--ink);
    font-weight: 500; line-height: 1.4; align-self: center;
  }
  .vs-loopya, .vs-other {
    padding: 15px 10px; display: flex; align-items: center; justify-content: center;
  }
  .vs-loopya {
    background: rgba(107,70,193,0.045);
    border-left: 1px solid var(--line); border-right: 1px solid var(--line);
  }
  .vs-head { background: var(--cream-soft); }
  .vs-head .vs-feat {
    font-size: 12px; text-transform: uppercase; letter-spacing: 0.10em;
    color: var(--ink-mute); font-weight: 600;
  }
  .vs-head .vs-other {
    font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em;
    color: var(--ink-mute); font-weight: 600; line-height: 1.3; text-align: center;
  }
  .vs-head .vs-loopya {
    background: var(--ink); color: var(--cream);
    font-size: 15px; font-weight: 700; letter-spacing: -0.01em;
  }
  .vs-ic {
    width: 19px; height: 19px; fill: none; stroke: currentColor;
    stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round;
  }
  .vs-ic.ok { color: var(--accent); }
  .vs-ic.ok.muted { color: var(--ink-mute); opacity: 0.5; }
  .vs-ic.no { color: var(--ink-mute); opacity: 0.32; }
  .vs-foot { margin-top: 22px; font-size: 14px; color: var(--ink-mute); }

  @media (max-width: 560px) {
    .vs-row { grid-template-columns: 1fr 58px 58px; }
    .vs-feat { padding: 14px 14px; font-size: 13.5px; }
    .vs-loopya, .vs-other { padding: 14px 4px; }
    .vs-head .vs-other { font-size: 9.5px; letter-spacing: 0.02em; }
    .vs-head .vs-loopya { font-size: 13px; }
    .vs-ic { width: 16px; height: 16px; }
  }

  /* ── BLOG & GUIDES (contenu éditorial) ─────────────────────────── */
  .guide-hero { max-width: 760px; margin: 0 auto; padding: 72px 24px 28px; }
  .guide-hero .section-eyebrow {
    display: block; font-size: 12px; text-transform: uppercase;
    letter-spacing: 0.12em; color: var(--accent); font-weight: 600; margin-bottom: 14px;
  }
  .guide-hero h1 {
    font-family: var(--display); font-weight: 600;
    font-size: clamp(32px, 5vw, 56px); line-height: 1.1; letter-spacing: -0.032em;
    color: var(--ink); margin: 0 0 16px; text-wrap: balance;
  }
  .guide-meta { color: var(--ink-mute); font-size: 15px; margin: 0; }
  .back-link {
    display: inline-block; color: var(--ink-mute); font-size: 14px;
    text-decoration: none; margin-bottom: 22px; font-weight: 500;
  }
  .back-link:hover { color: var(--accent); }

  .guide-body {
    max-width: 720px; margin: 0 auto; padding: 8px 24px 80px;
    font-family: var(--text); color: var(--ink-soft);
  }
  .guide-body > p { font-size: 17px; line-height: 1.7; margin: 0 0 20px; }
  .guide-body h2 {
    font-family: var(--display); font-weight: 600;
    font-size: clamp(24px, 3.2vw, 33px); line-height: 1.2; letter-spacing: -0.024em;
    color: var(--ink); margin: 46px 0 16px;
  }
  .guide-body h3 {
    font-family: var(--display); font-weight: 600; font-size: 21px;
    color: var(--ink); margin: 34px 0 12px; letter-spacing: -0.018em;
  }
  .guide-body ul { margin: 0 0 20px; padding: 0; list-style: none; }
  .guide-body li {
    position: relative; padding-left: 26px; margin-bottom: 12px;
    font-size: 17px; line-height: 1.6;
  }
  .guide-body li::before {
    content: ''; position: absolute; left: 3px; top: 11px;
    width: 6px; height: 6px; border-radius: 50%; background: var(--accent);
  }
  .guide-body strong { color: var(--ink); font-weight: 600; }
  .guide-body a {
    color: var(--accent); text-decoration: underline; text-underline-offset: 2px;
  }

  .guide-cta {
    background: var(--ink); color: var(--cream); border-radius: 18px;
    padding: 38px; margin: 48px 0 32px; text-align: center;
  }
  .guide-cta h3 {
    font-family: var(--display); font-weight: 600; font-size: 24px;
    color: var(--cream); margin: 0 0 10px; letter-spacing: -0.02em;
  }
  .guide-cta p { color: rgba(255,255,255,0.78); font-size: 16px; line-height: 1.55; margin: 0 0 22px; }
  .guide-cta .btn-pill { background: var(--cream); color: var(--ink); }
  .guide-cta .btn-pill:hover { background: rgba(255,255,255,0.86); color: var(--ink); }

  .guide-related {
    border-top: 1px solid var(--line); padding-top: 24px; margin-top: 8px;
    font-size: 15px; color: var(--ink-mute);
  }
  .guide-related strong { color: var(--ink); }
  .guide-related a { color: var(--accent); text-decoration: none; font-weight: 600; margin-left: 6px; }
  .guide-related a:hover { text-decoration: underline; }

  .blog-card {
    display: block; background: #fff; border: 1px solid var(--line);
    border-radius: 18px; padding: 30px 32px; margin-bottom: 20px;
    text-decoration: none; color: var(--ink);
    transition: box-shadow .25s ease, transform .25s ease;
  }
  .blog-card:hover { box-shadow: 0 24px 50px rgba(0,0,0,0.07); transform: translateY(-2px); }
  .blog-card-tag {
    display: inline-block; font-size: 12px; text-transform: uppercase;
    letter-spacing: 0.1em; color: var(--accent); font-weight: 600; margin-bottom: 12px;
  }
  .blog-card h2 {
    font-family: var(--display); font-weight: 600; font-size: 24px;
    letter-spacing: -0.022em; margin: 0 0 10px; line-height: 1.25; color: var(--ink);
  }
  .blog-card p { color: var(--ink-soft); font-size: 16px; line-height: 1.55; margin: 0 0 14px; }
  .blog-card-more { color: var(--accent); font-weight: 600; font-size: 15px; }

  @media (max-width: 560px) {
    .guide-hero { padding: 48px 20px 22px; }
    .guide-body { padding: 8px 20px 56px; }
    .guide-cta, .blog-card { padding: 26px 22px; }
  }

  /* ── RESPONSIVE — finitions session (maquette moteur, comparatif, lecture) ── */
  @media (max-width: 600px) {
    /* Maquette « Le moteur » : padding + tailles adaptés au mobile (était 28-30px, trop serré) */
    .engine-card, .engine-fiche { padding: 20px 18px; }
    .engine-title { font-size: 14px; }
    .engine-fiche-head { font-size: 10.5px; margin-bottom: 12px; padding-bottom: 10px; }
    .engine-fiche-row { font-size: 13px; gap: 10px; }
    .engine-fiche-row > strong { white-space: nowrap; }        /* "+ 11,70 €" reste sur une ligne */
    .engine-fiche-row.hl > strong.margin,
    .engine-fiche-row.total > strong { font-size: 15px; }
    .engine-verdict { font-size: 13.5px; align-items: flex-start; gap: 8px; }
    .engine-verdict::before { margin-top: 5px; flex-shrink: 0; }
    .engine-arrow span { font-size: 10px; padding: 4px 12px; }

    /* Confort de lecture blog/guides */
    .guide-body > p, .guide-body li { font-size: 16px; }
    .guide-body h2 { margin-top: 36px; }
    .blog-card h2, .guide-cta h3 { font-size: 21px; }
  }

  /* Très petit mobile (≤ 380 / iPhone SE) : comparatif vs lisible */
  @media (max-width: 380px) {
    .vs-row { grid-template-columns: 1fr 46px 46px; }
    .vs-feat { font-size: 12.5px; padding: 12px 12px; }
    .vs-head .vs-loopya { font-size: 12px; }
    .vs-head .vs-other { font-size: 9px; }
  }
