/* ====================================================================
   Documail — site vitrine
   Identité visuelle « Documail » : bleu marine + bleu ciel, accent vert
   doux, typographie Inter. Feuille autonome (le marketing tourne sur un
   service séparé, sans partager les assets du portail client).

   Police : Inter est demandée par la DA. La CSP du service interdit les
   polices externes (font-src 'self' data:) ; on déclare donc Inter en
   tête de pile et on retombe proprement sur la police système moderne
   (SF Pro / Segoe UI / Roboto) pour les postes qui n'ont pas Inter.
   ==================================================================== */

:root {
    /* Palette DA */
    --marine: #0D1B2A;       /* Bleu marine  */
    --ardoise: #334A6B;      /* Bleu ardoise */
    --ciel: #5DA9E9;         /* Bleu ciel    */
    --vert: #17B39A;         /* Vert doux    */
    --gris: #E6EBF1;         /* Gris clair   */
    --blanc-casse: #FAFBFC;  /* Blanc cassé  */

    /* Surfaces */
    --bg: var(--blanc-casse);
    --bg-subtle: #F1F4F8;
    --surface: #FFFFFF;
    --surface-hover: #F7F9FC;

    /* Encre */
    --ink: #0D1B2A;
    --ink-body: #41506A;
    --ink-muted: #76849A;
    --ink-inverse: #FFFFFF;
    --ink-inverse-soft: rgba(255, 255, 255, 0.72);
    --ink-inverse-faint: rgba(255, 255, 255, 0.52);

    /* Bordures */
    --border: #E6EBF1;
    --border-strong: #D4DDEA;

    /* Teintes douces */
    --ciel-soft: rgba(93, 169, 233, 0.12);
    --ciel-border: rgba(93, 169, 233, 0.28);
    --vert-soft: rgba(23, 179, 154, 0.12);
    --vert-border: rgba(23, 179, 154, 0.28);
    --marine-soft: rgba(13, 27, 42, 0.05);

    /* Ombres — froides, discrètes */
    --shadow-xs: 0 1px 2px rgba(13, 27, 42, 0.05);
    --shadow-sm: 0 2px 6px rgba(13, 27, 42, 0.06);
    --shadow-md: 0 10px 24px -8px rgba(13, 27, 42, 0.14);
    --shadow-lg: 0 22px 44px -16px rgba(13, 27, 42, 0.22);
    --shadow-xl: 0 36px 70px -24px rgba(13, 27, 42, 0.30);

    /* Rayons */
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 22px;

    /* Animation */
    --ease: cubic-bezier(0.4, 0, 0.2, 1);
    --fast: 0.16s;
    --normal: 0.26s;

    --font: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
            "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--ink-body);
    font-family: var(--font);
    font-size: 16px;
    line-height: 1.62;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a { color: inherit; text-decoration: none; }

h1, h2, h3, h4 {
    margin: 0;
    color: var(--ink);
    font-weight: 600;          /* Inter SemiBold — titres */
    line-height: 1.18;
    letter-spacing: -0.022em;
}

p { margin: 0; }

img, svg { display: block; }

::selection { background: var(--ciel-soft); color: var(--marine); }

.container {
    width: 100%;
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 28px;
}

/* --- En-tête ------------------------------------------------------- */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(250, 251, 252, 0.86);
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-bottom: 1px solid var(--border);
}

.header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 70px;
    gap: 24px;
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    font-size: 19px;
    letter-spacing: -0.02em;
    color: var(--marine);
}

.brand__logo { width: 28px; height: 28px; }

.nav {
    display: flex;
    align-items: center;
    gap: 30px;
}

.nav__links {
    display: flex;
    align-items: center;
    gap: 28px;
    font-size: 14.5px;
    font-weight: 500;          /* Inter Medium — libellés UI */
    color: var(--ink-body);
}

.nav__links a { transition: color var(--fast) var(--ease); }
.nav__links a:hover { color: var(--marine); }

.nav__actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* --- Boutons ------------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 11px 20px;
    border-radius: var(--radius-sm);
    font-family: var(--font);
    font-weight: 500;
    font-size: 14.5px;
    line-height: 1;
    border: 1px solid transparent;
    cursor: pointer;
    white-space: nowrap;
    transition: background var(--fast) var(--ease),
                border-color var(--fast) var(--ease),
                color var(--fast) var(--ease),
                box-shadow var(--fast) var(--ease),
                transform var(--fast) var(--ease);
}
.btn:active { transform: scale(0.985); }
.btn svg { width: 16px; height: 16px; }

.btn--primary {
    background: var(--marine);
    color: #fff;
    box-shadow: 0 6px 16px -8px rgba(13, 27, 42, 0.55);
}
.btn--primary:hover {
    background: #16304a;
    color: #fff;
    box-shadow: 0 12px 24px -10px rgba(13, 27, 42, 0.6);
}

.btn--secondary {
    background: var(--surface);
    border-color: var(--border-strong);
    color: var(--marine);
}
.btn--secondary:hover {
    border-color: var(--ardoise);
    background: var(--surface-hover);
}

.btn--accent {
    background: var(--vert);
    color: #fff;
    box-shadow: 0 6px 16px -8px rgba(23, 179, 154, 0.6);
}
.btn--accent:hover { background: #149983; color: #fff; }

.btn--ghost {
    background: transparent;
    color: var(--ink-body);
    padding: 11px 14px;
}
.btn--ghost:hover { color: var(--marine); background: var(--marine-soft); }

.btn--on-dark {
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.20);
    color: #fff;
}
.btn--on-dark:hover {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.34);
}

.btn--lg { padding: 14px 26px; font-size: 15.5px; }

/* --- Pilules & tags ------------------------------------------------ */
.pill {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 500;
    color: var(--ardoise);
    background: var(--ciel-soft);
    border: 1px solid var(--ciel-border);
}
.pill::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--ciel);
}

.tag {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 500;
    color: #0E7F6E;
    background: var(--vert-soft);
    border: 1px solid var(--vert-border);
}
.tag::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--vert);
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--ardoise);
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-xs);
}
.eyebrow svg { width: 14px; height: 14px; color: var(--ciel); }

/* --- Hero ---------------------------------------------------------- */
.hero {
    position: relative;
    overflow: hidden;
}
.hero::before {
    content: "";
    position: absolute;
    top: -260px;
    right: -160px;
    width: 720px;
    height: 720px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(93, 169, 233, 0.16), transparent 68%);
    pointer-events: none;
}
.hero__inner {
    position: relative;
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 56px;
    align-items: center;
    padding: 84px 0 92px;
}

.hero__copy { max-width: 540px; }

.hero h1 {
    margin: 22px 0 0;
    font-size: clamp(36px, 4.6vw, 56px);
    font-weight: 600;
    line-height: 1.07;
    letter-spacing: -0.035em;
    color: var(--marine);
}
.hero h1 .accent { color: var(--ciel); }

.hero .lead {
    margin: 22px 0 0;
    font-size: clamp(16px, 1.3vw, 18px);
    line-height: 1.62;
    color: var(--ink-body);
}

.hero__cta {
    margin-top: 30px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.hero__trust {
    margin-top: 38px;
    padding-top: 30px;
    border-top: 1px solid var(--border);
    display: flex;
    gap: 26px;
    flex-wrap: wrap;
}
.hero__trust-item {
    display: flex;
    gap: 11px;
    align-items: flex-start;
    max-width: 200px;
}
.hero__trust-icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ciel-soft);
    color: var(--ardoise);
}
.hero__trust-icon svg { width: 17px; height: 17px; }
.hero__trust-title {
    font-size: 13.5px;
    font-weight: 600;
    color: var(--marine);
}
.hero__trust-desc {
    font-size: 12.5px;
    color: var(--ink-muted);
    line-height: 1.45;
}

/* --- Aperçu produit (carte du hero) -------------------------------- */
.preview {
    position: relative;
    border-radius: var(--radius-xl);
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-xl);
    overflow: hidden;
}
.preview::after {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 4px;
    background: linear-gradient(90deg, var(--marine), var(--ciel) 60%, var(--vert));
}
.preview__bar {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--border);
    background: var(--blanc-casse);
}
.preview__dots { display: inline-flex; gap: 6px; }
.preview__dots span {
    width: 9px; height: 9px; border-radius: 50%;
    background: var(--border-strong);
}
.preview__chip {
    margin-left: auto;
    font-size: 11.5px;
    font-weight: 500;
    color: var(--ink-muted);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.preview__chip svg { width: 13px; height: 13px; color: var(--ciel); }

/* ====================================================================
   Démo animée — l'explorateur de dossiers Documail, repris de l'espace
   client (barre latérale sombre + arborescence personnes / dossiers de
   type / documents). 100 % CSS (la CSP interdit le JS inline) : chaque
   élément porte une animation infinie de même durée (--loop), les % des
   @keyframes choisissant son entrée. Boucle : un email arrive ->
   Documail analyse -> les pièces se classent dans l'arborescence.
   ==================================================================== */
.app {
    --loop: 10s;
    display: flex;
    min-height: 332px;
}

/* Barre latérale — comme dans l'espace client */
.app__side {
    flex-shrink: 0;
    width: 52px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    padding: 14px 0;
    background: var(--marine);
}
.app__logo {
    width: 32px;
    height: 32px;
    border-radius: 9px;
    background: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.app__logo img { width: 21px; height: 21px; }
.app__nav { display: flex; flex-direction: column; gap: 6px; }
.app__nav-item {
    width: 34px;
    height: 34px;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.46);
}
.app__nav-item svg { width: 17px; height: 17px; }
.app__nav-item--active {
    background: rgba(93, 169, 233, 0.18);
    color: var(--ciel);
}

/* Zone principale — l'explorateur du dossier */
.app__main {
    position: relative;
    flex: 1;
    min-width: 0;
    padding: 16px 18px 18px;
    background: var(--surface);
}

/* Étape 1 — un email arrive (toast) */
.demo__toast {
    position: absolute;
    top: 12px;
    left: 16px;
    right: 16px;
    z-index: 4;
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 11px 13px;
    border-radius: var(--radius-md);
    background: var(--marine);
    box-shadow: 0 18px 34px -14px rgba(13, 27, 42, 0.6);
    opacity: 0;
    animation: demoToast var(--loop) var(--ease) infinite;
}
.demo__toast-icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(93, 169, 233, 0.20);
    color: var(--ciel);
}
.demo__toast-icon svg { width: 17px; height: 17px; }
.demo__toast-text { display: flex; flex-direction: column; line-height: 1.35; }
.demo__toast-text strong { font-size: 12.5px; font-weight: 600; color: #fff; }
.demo__toast-text span { font-size: 10.5px; color: var(--ink-inverse-faint); }
.demo__toast-badge {
    margin-left: auto;
    padding: 3px 9px;
    border-radius: 999px;
    background: var(--vert);
    color: #fff;
    font-size: 11px;
    font-weight: 600;
}

/* En-tête du dossier */
.app__head { display: flex; align-items: center; gap: 9px; }
.app__head-icon {
    flex-shrink: 0;
    width: 30px;
    height: 30px;
    border-radius: var(--radius-sm);
    background: var(--ciel-soft);
    color: var(--ardoise);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.app__head-icon svg { width: 16px; height: 16px; }
.app__head-title { font-size: 13.5px; font-weight: 600; color: var(--marine); }
.app__head-status {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    color: #0E7F6E;
    background: var(--vert-soft);
    border: 1px solid var(--vert-border);
}
.app__head-status::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--vert);
}

/* Barre « Arborescence » + statut analyse/à jour */
.app__treebar {
    margin-top: 15px;
    padding-top: 13px;
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.app__treebar-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink-muted);
}
.demo__status { position: relative; width: 116px; height: 16px; }
.demo__status > span {
    position: absolute;
    inset: 0;
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
}
.demo__status-analyse { color: var(--ardoise); opacity: 0;
    animation: demoStatusA var(--loop) var(--ease) infinite; }
.demo__status-done { color: #0E7F6E; opacity: 1;
    animation: demoStatusD var(--loop) var(--ease) infinite; }
.demo__status-done svg { width: 13px; height: 13px; }
.demo__spinner {
    width: 11px;
    height: 11px;
    border-radius: 50%;
    border: 2px solid var(--ciel-border);
    border-top-color: var(--ciel);
    animation: demoSpin 0.7s linear infinite;
}

/* Arborescence du dossier */
.tree { position: relative; margin-top: 8px; }
.demo__scan {
    position: absolute;
    left: -4px;
    right: -4px;
    top: 0;
    height: 40px;
    z-index: 3;
    pointer-events: none;
    border-radius: var(--radius-sm);
    border-top: 2px solid var(--ciel);
    background: linear-gradient(180deg, rgba(93, 169, 233, 0.26), rgba(93, 169, 233, 0));
    opacity: 0;
    animation: demoScan var(--loop) var(--ease) infinite;
}
.tree__row {
    position: relative;
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 5px 8px;
    border-radius: 7px;
    border-left: 2px solid transparent;
    font-size: 13px;
    color: var(--ink-body);
    white-space: nowrap;
}
.tree__row--id { font-weight: 600; color: var(--marine); }
.tree__row--type { font-weight: 500; color: var(--ink); }
.tree__row--doc {
    font-weight: 400;
    color: var(--ardoise);
    background: var(--vert-soft);
    border-left-color: var(--vert);
}
.tree__chevron {
    flex-shrink: 0;
    width: 12px;
    height: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ink-muted);
    transform: rotate(90deg);
}
.tree__chevron svg { width: 10px; height: 10px; }
.tree__icon {
    flex-shrink: 0;
    width: 17px;
    height: 17px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ardoise);
}
.tree__icon svg { width: 14px; height: 14px; }
.tree__icon--doc { color: var(--vert); }
.tree__label { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.tree__check {
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--vert);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.tree__check svg { width: 9px; height: 9px; }
.tree__children {
    margin-left: 16px;
    padding-left: 4px;
    border-left: 1.5px solid var(--border);
}

/* Lignes document animées + pastilles de validation */
.demo__doc--1 { animation: demoDoc1 var(--loop) var(--ease) infinite; }
.demo__doc--2 { animation: demoDoc2 var(--loop) var(--ease) infinite; }
.demo__doc--3 { animation: demoDoc3 var(--loop) var(--ease) infinite; }
.demo__check--1 { animation: demoCheck1 var(--loop) var(--ease) infinite; }
.demo__check--2 { animation: demoCheck2 var(--loop) var(--ease) infinite; }
.demo__check--3 { animation: demoCheck3 var(--loop) var(--ease) infinite; }

@keyframes demoSpin { to { transform: rotate(360deg); } }
@keyframes demoToast {
    0%, 3%    { opacity: 0; transform: translateY(-150%); }
    8%, 22%   { opacity: 1; transform: translateY(0); }
    28%, 100% { opacity: 0; transform: translateY(-150%); }
}
@keyframes demoScan {
    0%, 30%   { opacity: 0; transform: translateY(0); }
    34%       { opacity: 1; transform: translateY(0); }
    74%       { opacity: 0.8; transform: translateY(148px); }
    78%, 100% { opacity: 0; transform: translateY(148px); }
}
@keyframes demoStatusA {
    0%, 28%   { opacity: 0; }
    33%, 80%  { opacity: 1; }
    85%, 100% { opacity: 0; }
}
@keyframes demoStatusD {
    0%, 82%   { opacity: 0; }
    87%, 98%  { opacity: 1; }
    100%      { opacity: 0; }
}
@keyframes demoDoc1 {
    0%, 34%   { opacity: 0; transform: translateX(12px); }
    40%, 95%  { opacity: 1; transform: translateX(0); }
    99%, 100% { opacity: 0; transform: translateX(12px); }
}
@keyframes demoDoc2 {
    0%, 50%   { opacity: 0; transform: translateX(12px); }
    56%, 95%  { opacity: 1; transform: translateX(0); }
    99%, 100% { opacity: 0; transform: translateX(12px); }
}
@keyframes demoDoc3 {
    0%, 66%   { opacity: 0; transform: translateX(12px); }
    72%, 95%  { opacity: 1; transform: translateX(0); }
    99%, 100% { opacity: 0; transform: translateX(12px); }
}
@keyframes demoCheck1 {
    0%, 44%   { opacity: 0; transform: scale(0); }
    49%       { opacity: 1; transform: scale(1.35); }
    53%, 95%  { opacity: 1; transform: scale(1); }
    99%, 100% { opacity: 0; transform: scale(0); }
}
@keyframes demoCheck2 {
    0%, 60%   { opacity: 0; transform: scale(0); }
    65%       { opacity: 1; transform: scale(1.35); }
    69%, 95%  { opacity: 1; transform: scale(1); }
    99%, 100% { opacity: 0; transform: scale(0); }
}
@keyframes demoCheck3 {
    0%, 76%   { opacity: 0; transform: scale(0); }
    81%       { opacity: 1; transform: scale(1.35); }
    85%, 95%  { opacity: 1; transform: scale(1); }
    99%, 100% { opacity: 0; transform: scale(0); }
}

/* --- Bandeau logos / réassurance ----------------------------------- */
.strip {
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    background: var(--surface);
}
.strip__inner {
    display: flex;
    align-items: center;
    gap: 18px 40px;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 22px 0;
}
.strip__label {
    font-size: 12.5px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--ink-muted);
}
.strip__items {
    display: flex;
    gap: 14px 28px;
    flex-wrap: wrap;
}
.strip__item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--ardoise);
}
.strip__item svg { width: 16px; height: 16px; color: var(--ciel); }

/* --- Trame des sections -------------------------------------------- */
.section { padding: 92px 0; }
.section--tight { padding: 72px 0; }

.section__head {
    max-width: 680px;
    margin: 0 auto 48px;
    text-align: center;
}
.section__head--left {
    margin-left: 0;
    text-align: left;
}
.section__eyebrow {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--ciel);
}
.section__title {
    margin-top: 12px;
    font-size: clamp(27px, 3vw, 38px);
    font-weight: 600;
    letter-spacing: -0.03em;
    color: var(--marine);
}
.section__lead {
    margin-top: 14px;
    font-size: 16.5px;
    line-height: 1.6;
    color: var(--ink-body);
}

/* --- Piliers (4 tâches) -------------------------------------------- */
.pillars {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}
.pillar {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 30px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    background: var(--surface);
    box-shadow: var(--shadow-xs);
    transition: box-shadow var(--normal) var(--ease),
                transform var(--normal) var(--ease),
                border-color var(--normal) var(--ease);
}
.pillar:hover {
    transform: translateY(-3px);
    border-color: var(--border-strong);
    box-shadow: var(--shadow-md);
}
.pillar__icon {
    width: 46px;
    height: 46px;
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: linear-gradient(140deg, var(--marine), var(--ardoise));
    box-shadow: 0 10px 20px -10px rgba(13, 27, 42, 0.55);
}
.pillar__icon svg { width: 23px; height: 23px; }
.pillar__kicker {
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    color: var(--ciel);
}
.pillar h3 { font-size: 21px; font-weight: 600; }
.pillar p {
    font-size: 15px;
    color: var(--ink-body);
    line-height: 1.6;
}
.pillar p code {
    background: var(--bg-subtle);
    border: 1px solid var(--border);
    padding: 1px 6px;
    border-radius: 6px;
    font-size: 12.5px;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    color: var(--ardoise);
}
.pillar__points {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.pillar__points li {
    position: relative;
    padding-left: 26px;
    font-size: 14px;
    color: var(--ink-body);
}
.pillar__points li svg {
    position: absolute;
    left: 0;
    top: 2px;
    width: 16px;
    height: 16px;
    color: var(--vert);
}
.pillar__metric {
    margin-top: auto;
    display: inline-flex;
    align-items: baseline;
    gap: 9px;
    padding: 12px 15px;
    border-radius: var(--radius-md);
    background: var(--bg-subtle);
    border: 1px solid var(--border);
}
.pillar__metric-value {
    font-size: 19px;
    font-weight: 600;
    color: var(--marine);
    letter-spacing: -0.02em;
}
.pillar__metric-label { font-size: 12.5px; color: var(--ink-muted); }

/* --- Étapes -------------------------------------------------------- */
.steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}
.step {
    position: relative;
    padding: 28px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    background: var(--surface);
    box-shadow: var(--shadow-xs);
}
.step__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: var(--marine);
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 16px;
}
.step h3 { font-size: 17px; margin-bottom: 8px; }
.step p { font-size: 14.5px; color: var(--ink-body); }
.step__line {
    position: absolute;
    top: 47px;
    right: -10px;
    width: 20px;
    height: 2px;
    background: var(--border-strong);
}

/* --- Cartes audience ----------------------------------------------- */
.features {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}
.feature {
    padding: 26px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    background: var(--surface);
    box-shadow: var(--shadow-xs);
    transition: border-color var(--fast) var(--ease),
                box-shadow var(--fast) var(--ease);
}
.feature:hover {
    border-color: var(--border-strong);
    box-shadow: var(--shadow-sm);
}
.feature__icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ciel-soft);
    color: var(--ardoise);
    margin-bottom: 16px;
}
.feature__icon svg { width: 20px; height: 20px; }
.feature h3 { font-size: 16px; margin-bottom: 7px; }
.feature p { font-size: 14px; color: var(--ink-body); }

/* --- Section sombre + grille des gains ----------------------------- */
.section--dark {
    background: var(--marine);
    position: relative;
    overflow: hidden;
}
.section--dark::before {
    content: "";
    position: absolute;
    top: -200px;
    left: -120px;
    width: 560px;
    height: 560px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(93, 169, 233, 0.16), transparent 70%);
    pointer-events: none;
}
.section--dark .container { position: relative; }
.section--dark .section__eyebrow { color: var(--ciel); }
.section--dark .section__title { color: #fff; }
.section--dark .section__lead { color: var(--ink-inverse-soft); }

.gain-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}
.gain {
    display: flex;
    flex-direction: column;
    gap: 9px;
    padding: 26px;
    border-radius: var(--radius-lg);
    background: rgba(255, 255, 255, 0.045);
    border: 1px solid rgba(255, 255, 255, 0.10);
    transition: background var(--normal) var(--ease),
                border-color var(--normal) var(--ease);
}
.gain:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.20);
}
.gain__label {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--ink-inverse-faint);
}
.gain__value {
    font-size: 42px;
    font-weight: 600;
    letter-spacing: -0.035em;
    color: #fff;
    line-height: 1;
}
.gain__value span {
    font-size: 17px;
    font-weight: 500;
    color: var(--ink-inverse-faint);
    margin-left: 4px;
}
.gain__hint {
    font-size: 13px;
    color: var(--ink-inverse-soft);
    line-height: 1.5;
}
.gain--accent {
    background: linear-gradient(140deg, rgba(23, 179, 154, 0.20), rgba(93, 169, 233, 0.10));
    border-color: var(--vert-border);
}
.gain--accent .gain__value span { color: rgba(255, 255, 255, 0.7); }

/* --- Tarifs -------------------------------------------------------- */
.pricing {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
    align-items: stretch;
}
.plan {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 30px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    background: var(--surface);
    box-shadow: var(--shadow-xs);
}
.plan--featured {
    border-color: transparent;
    background: var(--marine);
    box-shadow: var(--shadow-lg);
}
.plan__name {
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--marine);
}
.plan--featured .plan__name { color: var(--ciel); }
.plan__price {
    display: flex;
    align-items: baseline;
    gap: 7px;
}
.plan__price strong {
    font-size: 36px;
    font-weight: 600;
    letter-spacing: -0.03em;
    color: var(--marine);
}
.plan--featured .plan__price strong { color: #fff; }
.plan__price span { font-size: 13.5px; color: var(--ink-muted); }
.plan--featured .plan__price span { color: var(--ink-inverse-faint); }
.plan__desc { font-size: 13.5px; color: var(--ink-body); }
.plan--featured .plan__desc { color: var(--ink-inverse-soft); }
.plan__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.plan__list li {
    position: relative;
    padding-left: 26px;
    font-size: 13.5px;
    color: var(--ink-body);
}
.plan--featured .plan__list li { color: var(--ink-inverse-soft); }
.plan__list li svg {
    position: absolute;
    left: 0;
    top: 1px;
    width: 16px;
    height: 16px;
    color: var(--vert);
}
.plan .btn { margin-top: auto; }
.plan__badge {
    align-self: flex-start;
    padding: 4px 11px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--marine);
    background: var(--ciel);
}

/* --- Sécurité ------------------------------------------------------ */
.trust {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}
.trust__item {
    display: flex;
    gap: 15px;
    align-items: flex-start;
    padding: 24px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    background: var(--surface);
    box-shadow: var(--shadow-xs);
}
.trust__icon {
    flex-shrink: 0;
    width: 42px;
    height: 42px;
    border-radius: var(--radius-md);
    background: var(--marine);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.trust__icon svg { width: 20px; height: 20px; }
.trust__title { font-size: 15.5px; font-weight: 600; color: var(--marine); }
.trust__desc {
    margin-top: 4px;
    font-size: 13.5px;
    color: var(--ink-body);
    line-height: 1.55;
}

/* --- Valeurs de marque --------------------------------------------- */
.values {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}
.value {
    text-align: center;
    padding: 30px 24px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    background: var(--surface);
}
.value__icon {
    width: 48px;
    height: 48px;
    margin: 0 auto 14px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ciel-soft);
    color: var(--ardoise);
}
.value__icon svg { width: 22px; height: 22px; }
.value h3 { font-size: 17px; }
.value p {
    margin-top: 7px;
    font-size: 13.5px;
    color: var(--ink-body);
}

/* --- FAQ ----------------------------------------------------------- */
.faq {
    max-width: 760px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.faq__item {
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--surface);
    overflow: hidden;
}
.faq__item summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 22px;
    font-size: 15.5px;
    font-weight: 600;
    color: var(--marine);
    cursor: pointer;
    list-style: none;
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after {
    content: "";
    flex-shrink: 0;
    width: 11px;
    height: 11px;
    border-right: 2px solid var(--ink-muted);
    border-bottom: 2px solid var(--ink-muted);
    transform: rotate(45deg);
    transition: transform var(--fast) var(--ease);
}
.faq__item[open] summary::after { transform: rotate(-135deg); }
.faq__item p {
    padding: 0 22px 20px;
    font-size: 14.5px;
    color: var(--ink-body);
    line-height: 1.6;
}

/* --- CTA final ----------------------------------------------------- */
.cta-band {
    position: relative;
    overflow: hidden;
    padding: 72px 56px;
    border-radius: var(--radius-xl);
    background: var(--marine);
    text-align: center;
    box-shadow: var(--shadow-lg);
}
.cta-band::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(560px 280px at 18% 16%, rgba(93, 169, 233, 0.22), transparent 70%),
        radial-gradient(520px 300px at 86% 92%, rgba(23, 179, 154, 0.18), transparent 70%);
    pointer-events: none;
}
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 {
    font-size: clamp(24px, 2.6vw, 34px);
    color: #fff;
    letter-spacing: -0.03em;
}
.cta-band p {
    margin: 14px auto 0;
    max-width: 540px;
    color: var(--ink-inverse-soft);
    font-size: 16px;
}
.cta-band .hero__cta { justify-content: center; margin-top: 28px; }

/* --- Pied de page -------------------------------------------------- */
.site-footer {
    border-top: 1px solid var(--border);
    background: var(--surface);
    padding: 56px 0 36px;
}
.footer__top {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 40px;
}
.footer__brand .brand { margin-bottom: 12px; }
.footer__tagline {
    font-size: 14.5px;
    color: var(--ink-body);
    max-width: 320px;
}
.footer__motto {
    margin-top: 14px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: var(--ciel);
}
.footer__col h4 {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-muted);
    margin-bottom: 14px;
}
.footer__col a,
.footer__col span {
    display: block;
    font-size: 14px;
    color: var(--ink-body);
    margin-bottom: 9px;
}
.footer__col a { transition: color var(--fast) var(--ease); }
.footer__col a:hover { color: var(--marine); }
.footer__bottom {
    margin-top: 40px;
    padding-top: 24px;
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    font-size: 13px;
    color: var(--ink-muted);
}
.footer__bottom a { color: var(--ink-body); }
.footer__bottom a:hover { color: var(--marine); }

/* --- Responsive ---------------------------------------------------- */
@media (max-width: 1000px) {
    .hero__inner {
        grid-template-columns: 1fr;
        gap: 44px;
        padding: 60px 0 68px;
    }
    .hero__copy { max-width: 620px; }
    .preview { max-width: 480px; }
    .section { padding: 68px 0; }
    .pillars { grid-template-columns: 1fr; }
    .steps,
    .features,
    .pricing,
    .values,
    .gain-grid { grid-template-columns: repeat(2, 1fr); }
    .step__line { display: none; }
    .footer__top { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 680px) {
    html, body { font-size: 15px; }
    .container { padding: 0 18px; }
    .nav__links { display: none; }
    .header__inner { height: 62px; }
    .hero__inner { padding: 44px 0 52px; }
    .hero__cta .btn { flex: 1 1 auto; }
    .hero__trust { gap: 18px; }
    .section { padding: 56px 0; }
    .section--tight { padding: 44px 0; }
    .section__head { margin-bottom: 36px; }
    .steps,
    .features,
    .pricing,
    .values,
    .gain-grid,
    .trust { grid-template-columns: 1fr; }
    .strip__inner { flex-direction: column; align-items: flex-start; }
    .cta-band { padding: 52px 24px; }
    .pillar,
    .plan { padding: 24px; }
    .footer__top { grid-template-columns: 1fr; gap: 28px; }
}

@media (max-width: 420px) {
    .preview__stats { grid-template-columns: 1fr; }
    .hero h1 { font-size: 33px; }
}

/* Mouvement réduit : on coupe transitions ET animations. La démo
   retombe alors sur son état de repos (état CSS de base) — un tableau
   de bord déjà peuplé : 3 pièces classées, statut « À jour ». */
@media (prefers-reduced-motion: reduce) {
    * {
        transition: none !important;
        animation: none !important;
    }
}
