/**
 * Page Home — patte « Claude Design v3 » Clinical Tech.
 * Sections (11) : Hero, Statsbar, Tendances, Catalogue, Marques,
 *                 Témoignages, Mission, Engagements, Process, FAQ, CTA Final.
 *
 * Hypothèses : tokens.css déjà chargé (palette, spacing, radius, easing).
 * Préfixe `home-` pour scoper et éviter les collisions avec les autres pages.
 */

/* ───────────────────────────────────────────────
 * Helpers locaux
 * ─────────────────────────────────────────────── */
.home-page { --section-py: var(--section-default); }

.home-page .home-wrap {
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 clamp(20px, 4vw, 56px);
}

.home-page .home-eyebrow {
    font-family: 'JetBrains Mono', Menlo, Consolas, monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-cyan-tech);
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin: 0 0 18px;
}
.home-page .home-eyebrow::before {
    content: '';
    width: 32px;
    height: 1px;
    background: currentColor;
    flex-shrink: 0;
}
.home-page .home-eyebrow--light {
    font-family: 'Inter', system-ui, sans-serif;
    letter-spacing: 0.16em;
    color: var(--color-blue);
}

.home-page .home-h2 {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: clamp(28px, 2.6vw, 40px);
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.12;
    text-wrap: balance;
    margin: 0 0 16px;
}
.home-page .home-h2--dark { color: var(--color-text-on-dark); }

.home-page .home-lead {
    font-size: clamp(15px, 1.15vw, 17px);
    color: var(--color-text-body);
    line-height: 1.7;
    margin: 0;
}
.home-page .home-lead--dark { color: rgb(var(--rgb-on-dark) / 0.66); }

.home-page .home-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Inter', sans-serif;
    font-size: 15px;
    font-weight: 600;
    border-radius: var(--radius-pill);
    padding: 14px 28px;
    cursor: pointer;
    border: 0;
    white-space: nowrap;
    transition:
        background var(--dur-state) var(--ease-out),
        transform 150ms var(--ease-out),
        box-shadow var(--dur-state) var(--ease-out),
        color var(--dur-state) var(--ease-out);
}
.home-page .home-btn--primary { background: var(--color-blue); color: var(--color-white); }
.home-page .home-btn--primary:hover {
    background: var(--color-blue-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-blue-glow);
}
.home-page .home-btn--ghost {
    background: transparent;
    color: var(--color-text-on-dark);
    border: 1.5px solid rgb(var(--rgb-on-dark) / 0.32);
}
.home-page .home-btn--ghost:hover {
    background: rgb(var(--rgb-on-dark) / 0.08);
    border-color: rgb(var(--rgb-on-dark) / 0.6);
}

/* keyframes aura-pulse / hero-zoom / bar-grow définis dans components.css.
 * Note: home perd un scale(1→1.08) sur aura-pulse pour éviter le re-blur du filter:blur(60px). */

/* ═══════════════════════════════════════════════
 * S01 — HERO
 * ═══════════════════════════════════════════════ */
.home-hero {
    position: relative;
    background: var(--color-navy-deepest);
    color: var(--color-text-on-dark);
    overflow: hidden;
    min-height: 720px;
    display: flex;
    align-items: center;
    padding: clamp(80px, 9vw, 120px) 0 clamp(64px, 7vw, 96px);
}
.home-hero__bg { position: absolute; inset: 0; z-index: var(--z-base); }
.home-hero__bg-img {
    width: 100%; height: 100%;
    object-fit: cover; object-position: right center;
    opacity: 0.55;
}
.home-hero__bg-shade {
    position: absolute; inset: 0;
    background: linear-gradient(105deg,
        rgb(var(--rgb-navy-deepest) / 0.96) 0%,
        rgb(var(--rgb-navy-deepest) / 0.78) 45%,
        rgb(var(--rgb-navy-deepest) / 0.35) 80%,
        rgb(var(--rgb-navy-deepest) / 0.15) 100%);
}
.home-hero__grid-overlay {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgb(var(--rgb-blue-electric) / 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgb(var(--rgb-blue-electric) / 0.05) 1px, transparent 1px);
    background-size: 80px 80px;
    mask-image: radial-gradient(ellipse at center, var(--color-navy-deepest) 30%, transparent 70%);
    pointer-events: none;
}
.home-hero__inner { position: relative; z-index: var(--z-float); width: 100%; }
.home-hero__split {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    gap: clamp(32px, 5vw, 80px);
    align-items: center;
}
.home-hero__copy { min-width: 0; }
.home-hero__title {
    font-family: 'Inter', sans-serif;
    font-size: clamp(40px, 5vw, 68px);
    font-weight: 600;
    line-height: 1.02;
    letter-spacing: -0.035em;
    margin: 0 0 24px;
    text-wrap: balance;
    max-width: 18ch;
    color: var(--color-text-on-dark);
}
.home-hero__title em {
    font-style: normal;
    color: var(--color-blue-electric);
}
.home-hero__lead {
    font-size: clamp(16px, 1.2vw, 19px);
    color: rgb(var(--rgb-on-dark) / 0.78);
    max-width: 52ch;
    margin: 0 0 16px;
    line-height: 1.55;
}
.home-hero__sublead {
    font-size: 14px;
    color: rgb(var(--rgb-on-dark) / 0.55);
    max-width: 56ch;
    margin: 0 0 32px;
    line-height: 1.65;
}
.home-hero__actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.home-hero__product {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 480px;
}
.home-hero__product-glow {
    position: absolute; inset: -10%;
    background: radial-gradient(circle at center,
        rgb(var(--rgb-blue) / 0.5) 0%,
        rgb(var(--rgb-blue) / 0.15) 35%,
        transparent 65%);
    filter: blur(60px);
    z-index: var(--z-base);
    animation: aura-pulse 4.5s ease-in-out infinite;
}
.home-hero__product-img {
    position: relative;
    z-index: var(--z-pop);
    max-width: 480px;
    width: 100%;
    filter: drop-shadow(0 30px 60px rgb(var(--rgb-navy-deepest) / 0.55));
    animation: hero-zoom 1500ms var(--ease-out);
}
.home-hero__product-tag {
    position: absolute;
    z-index: var(--z-overlay);
    background: rgb(var(--rgb-navy) / 0.85);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgb(var(--rgb-blue-electric) / 0.3);
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 11px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.home-hero__product-tag b {
    font-family: 'JetBrains Mono', monospace;
    color: var(--color-cyan-tech);
    font-size: 10px;
    letter-spacing: 0.1em;
    font-weight: 600;
}
.home-hero__product-tag span { color: rgb(var(--rgb-white) / 0.85); font-weight: 500; }
.home-hero__product-tag--1 { top: 18%; left: 0; }
.home-hero__product-tag--2 { bottom: 22%; right: 0; }
.home-hero__product-tag--3 { top: 50%; right: -12px; }

.home-hero__specs {
    display: flex;
    gap: clamp(20px, 3vw, 48px);
    align-items: center;
    flex-wrap: wrap;
    padding-top: 28px;
    margin-top: 32px;
    border-top: 1px solid rgb(var(--rgb-on-dark) / 0.10);
}
.home-hero__spec { display: flex; flex-direction: column; gap: 4px; }
.home-hero__spec-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-cyan-tech);
}
.home-hero__spec-value {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-on-dark);
    letter-spacing: -0.01em;
    font-variant-numeric: tabular-nums;
}

@media (max-width: 1024px) {
    .home-hero__split { grid-template-columns: 1fr; }
    .home-hero__product { display: none; }
}

/* ═══════════════════════════════════════════════
 * S02 — STATSBAR
 * ═══════════════════════════════════════════════ */
.home-statsbar {
    background: var(--color-white);
    border-top: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
    padding: clamp(40px, 5vw, 72px) 0;
}
.home-statsbar__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}
.home-statsbar__item {
    text-align: center;
    padding: 0 24px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.home-statsbar__item:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 56px;
    background: var(--color-border-light);
}
.home-statsbar__accent {
    width: 28px;
    height: 3px;
    border-radius: 2px;
    background: var(--color-blue);
    margin-bottom: 4px;
}
.home-statsbar__num {
    font-size: clamp(36px, 3vw, 48px);
    font-weight: 700;
    letter-spacing: -0.035em;
    line-height: 1;
    color: var(--color-text-primary);
    font-variant-numeric: tabular-nums;
    margin: 0;
}
.home-statsbar__unit {
    font-size: 0.5em;
    color: var(--color-blue);
    font-weight: 600;
    margin-left: 6px;
    vertical-align: baseline;
    letter-spacing: -0.01em;
}
.home-statsbar__label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-body);
    max-width: 18ch;
    line-height: 1.45;
    margin: 0;
}
@media (max-width: 900px) {
    .home-statsbar__grid { grid-template-columns: repeat(2, 1fr); row-gap: 32px; }
    .home-statsbar__item:nth-child(2)::after { display: none; }
}
@media (max-width: 480px) {
    .home-statsbar__grid { grid-template-columns: 1fr; }
    .home-statsbar__item::after { display: none !important; }
}

/* ═══════════════════════════════════════════════
 * S03 — TENDANCES
 * ═══════════════════════════════════════════════ */
.home-tendances {
    background: var(--color-off-white);
    padding: var(--section-py) 0 calc(var(--section-py) * 0.7);
}
.home-tendances__head {
    text-align: center;
    max-width: 64ch;
    margin: 0 auto 64px;
}
.home-tendances__head .home-eyebrow { justify-content: center; }

.home-thero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(40px, 5vw, 80px);
    align-items: center;
    margin-bottom: 80px;
    padding: 56px 0;
    border-top: 1px solid var(--color-border-medium);
    border-bottom: 1px solid var(--color-border-medium);
}
.home-thero__big {
    font-size: clamp(72px, 8vw, 120px);
    font-weight: 700;
    letter-spacing: -0.045em;
    line-height: 0.9;
    color: var(--color-blue);
    font-variant-numeric: tabular-nums;
    margin: 0 0 20px;
    display: block;
}
.home-thero__big sup {
    font-size: 0.38em;
    color: rgb(var(--rgb-blue) / 0.65);
    font-weight: 600;
    margin-left: 4px;
    vertical-align: 0.5em;
}
.home-thero__caption {
    font-size: clamp(18px, 1.4vw, 22px);
    font-weight: 500;
    letter-spacing: -0.01em;
    line-height: 1.4;
    color: var(--color-text-primary);
    max-width: 32ch;
    margin: 0 0 16px;
    text-wrap: balance;
}
.home-thero__source {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-muted);
}
.home-thero__chart {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.home-tbar {
    display: grid;
    grid-template-columns: 70px 1fr 80px;
    align-items: center;
    gap: 14px;
    font-size: 13px;
}
.home-tbar__y {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-muted);
    letter-spacing: 0.05em;
}
.home-tbar__bar {
    height: 18px;
    border-radius: 4px;
    background: linear-gradient(90deg, var(--color-blue) 0%, rgb(var(--rgb-blue) / 0.6) 100%);
    transform-origin: left center;
    animation: bar-grow 1200ms var(--ease-out) backwards;
}
.home-tbar__val {
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    color: var(--color-text-primary);
    text-align: right;
    font-size: 15px;
}

.home-taside {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(32px, 4vw, 64px);
}
.home-taside__num {
    font-size: clamp(32px, 2.6vw, 42px);
    font-weight: 700;
    letter-spacing: -0.028em;
    line-height: 1;
    color: var(--color-text-primary);
    font-variant-numeric: tabular-nums;
    margin: 0 0 12px;
}
.home-taside__num sup {
    font-size: 0.5em;
    color: var(--color-text-body);
    font-weight: 500;
    margin-left: 4px;
    vertical-align: 0.4em;
}
.home-taside__text {
    font-size: 14px;
    color: var(--color-text-body);
    line-height: 1.65;
    max-width: 38ch;
    margin: 0 0 10px;
}
.home-taside__source {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-muted);
}
@media (max-width: 720px) {
    .home-thero { grid-template-columns: 1fr; }
    .home-taside { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════
 * S04 — CATALOGUE
 * ═══════════════════════════════════════════════ */
.home-catalogue {
    background: var(--color-navy-deep);
    color: var(--color-text-on-dark);
    padding: var(--section-py) 0;
    position: relative;
    overflow: hidden;
}
.home-catalogue::before {
    content: '';
    position: absolute;
    top: -200px; left: -200px;
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgb(var(--rgb-blue) / 0.14) 0%, transparent 70%);
    filter: blur(80px);
    pointer-events: none;
}
.home-catalogue::after {
    content: '';
    position: absolute;
    bottom: -300px; right: -200px;
    width: 800px; height: 800px;
    background: radial-gradient(circle, rgb(var(--rgb-blue-electric) / 0.09) 0%, transparent 70%);
    filter: blur(100px);
    pointer-events: none;
}
.home-catalogue__head {
    text-align: center;
    max-width: 60ch;
    margin: 0 auto 64px;
    position: relative;
    z-index: var(--z-raised);
}
.home-catalogue__head .home-eyebrow { justify-content: center; }
.home-cat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    position: relative;
    z-index: var(--z-raised);
}
@media (max-width: 900px) {
    .home-cat-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
    .home-cat-grid { grid-template-columns: 1fr; }
}
.home-cat-more {
    margin: 32px auto 0;
    text-align: center;
    color: rgb(var(--rgb-on-dark) / 0.62);
    font-size: 14px;
    line-height: 1.7;
    letter-spacing: 0.01em;
    position: relative;
    z-index: var(--z-raised);
}
.home-cat-more__label {
    color: rgb(var(--rgb-on-dark) / 0.45);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 11px;
    font-weight: 600;
    margin-right: 10px;
}
.home-cat-more__link {
    color: rgb(var(--rgb-on-dark) / 0.88);
    text-decoration: none;
    border-bottom: 1px solid rgb(var(--rgb-on-dark) / 0.20);
    padding-bottom: 1px;
    transition:
        color 200ms var(--ease-out),
        border-color 200ms var(--ease-out);
}
.home-cat-more__link:hover {
    color: rgb(var(--rgb-on-dark) / 1);
    border-bottom-color: rgb(var(--rgb-on-dark) / 0.6);
}
.home-cat-more__sep {
    margin: 0 10px;
    color: rgb(var(--rgb-on-dark) / 0.28);
}
@media (max-width: 560px) {
    .home-cat-more__label { display: block; margin-bottom: 8px; }
}
.home-cat-card {
    background: rgb(var(--rgb-on-dark) / 0.03);
    border: 1px solid rgb(var(--rgb-on-dark) / 0.07);
    border-radius: 16px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition:
        border-color 300ms var(--ease-out),
        transform 300ms var(--ease-out),
        background 300ms;
}
.home-cat-card:hover {
    border-color: rgb(var(--rgb-blue) / 0.5);
    transform: translateY(-3px);
    background: rgb(var(--rgb-on-dark) / 0.05);
}
.home-cat-banner {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    border-bottom: 1px solid rgb(var(--rgb-on-dark) / 0.07);
    display: flex;
    align-items: flex-end;
    padding: 18px 22px;
}
.home-cat-banner--01 { background: linear-gradient(135deg, var(--color-navy-deep), var(--color-navy-soft)); }
.home-cat-banner--02 { background: linear-gradient(135deg, var(--color-navy-deep), var(--color-blue-hover)); }
.home-cat-banner--03 { background: linear-gradient(135deg, var(--color-blue-deep), var(--color-navy)); }
.home-cat-banner--04 { background: linear-gradient(135deg, var(--color-navy), var(--color-blue)); }
.home-cat-banner--05 { background: linear-gradient(135deg, var(--color-navy-deep), var(--color-blue-deep)); }


.home-cat-banner__chip {
    position: absolute;
    top: 14px; left: 14px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgb(var(--rgb-white) / 0.8);
    background: rgb(var(--rgb-navy) / 0.5);
    border: 1px solid rgb(var(--rgb-white) / 0.12);
    border-radius: var(--radius-pill);
    padding: 5px 10px;
}
.home-cat-banner__placeholder {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    pointer-events: none;
}
.home-cat-banner__overlay {
    position: relative;
    z-index: var(--z-pop);
    width: 100%;
}
.home-cat-h3 {
    font-family: 'Inter', sans-serif;
    font-size: 19px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--color-text-on-dark);
    margin: 0;
    line-height: 1.2;
    text-wrap: balance;
}
.home-cat-banner__sub {
    font-size: 12px;
    color: rgb(var(--rgb-on-dark) / 0.7);
    margin: 4px 0 0;
    font-weight: 500;
}
.home-cat-body {
    padding: 24px;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 16px;
}
.home-cat-desc {
    font-size: 14px;
    color: rgb(var(--rgb-on-dark) / 0.65);
    line-height: 1.65;
    margin: 0;
}
.home-cat-meta {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 8px 14px;
    padding-top: 16px;
    border-top: 1px solid rgb(var(--rgb-on-dark) / 0.07);
    font-size: 13px;
    margin: 0;
}
.home-cat-meta dt { color: rgb(var(--rgb-on-dark) / 0.45); margin: 0; font-weight: 400; }
.home-cat-meta dd { color: var(--color-text-on-dark); margin: 0; font-weight: 500; }
.home-cat-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--color-blue-electric);
    font-size: 14px;
    font-weight: 600;
    margin-top: auto;
    transition: gap 200ms;
}
.home-cat-card:hover .home-cat-link { gap: 10px; }

/* ═══════════════════════════════════════════════
 * S05 — MARQUES
 * ═══════════════════════════════════════════════ */
.home-marques {
    background: var(--color-off-white);
    padding: var(--section-py) 0;
}
.home-marques__head {
    text-align: center;
    max-width: 62ch;
    margin: 0 auto 64px;
}
.home-marques__head .home-eyebrow { justify-content: center; }
.home-brand-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
@media (max-width: 1024px) { .home-brand-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .home-brand-grid { grid-template-columns: 1fr; } }

.home-brand-card {
    background: var(--color-white);
    border: 1px solid var(--color-border-light);
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    box-shadow: 0 2px 12px rgb(var(--rgb-navy) / 0.04);
    transition:
        border-color 280ms,
        transform 280ms var(--ease-out),
        box-shadow 280ms;
    overflow: hidden;
}
.home-brand-card:hover {
    border-color: rgb(var(--rgb-blue) / 0.25);
    transform: translateY(-3px);
    box-shadow: 0 16px 40px rgb(var(--rgb-navy) / 0.1);
}
.home-brand__logo {
    height: 110px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 28px;
    background: var(--color-surface-soft);
    border-bottom: 1px solid var(--color-border-light);
    position: relative;
}
.home-brand__logo::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: -1px;
    height: 2px;
    background: var(--color-blue);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 320ms var(--ease-out);
}
.home-brand-card:hover .home-brand__logo::after { transform: scaleX(1); }
.home-brand__logo img { max-height: 52px; max-width: 170px; object-fit: contain; }
.home-brand__logo--text {
    font-family: 'Inter', sans-serif;
    font-size: 28px;
    font-weight: 700;
    letter-spacing: -0.045em;
    color: var(--color-text-primary);
}
.home-brand__body {
    padding: 22px 24px 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    flex: 1;
}
.home-brand__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin: 0;
}
.home-brand__meta-flag { font-size: 14px; letter-spacing: 0; }
.home-brand__meta-dot {
    width: 3px; height: 3px;
    background: var(--color-text-muted);
    border-radius: 50%;
}
.home-brand__name {
    font-family: 'Inter', sans-serif;
    font-size: 19px;
    font-weight: 700;
    letter-spacing: -0.025em;
    color: var(--color-text-primary);
    margin: 0;
    line-height: 1.15;
}
.home-brand__tagline {
    font-size: 13px;
    color: var(--color-text-body);
    line-height: 1.55;
    margin: 0;
    flex: 1;
}
.home-brand__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding-top: 4px;
}
.home-brand__chip {
    font-size: 11px;
    font-weight: 500;
    color: var(--color-text-body);
    background: var(--color-cream);
    padding: 4px 9px;
    border-radius: var(--radius-pill);
    border: 1px solid var(--color-border-light);
    transition: background 200ms, color 200ms, border-color 200ms;
}
.home-brand-card:hover .home-brand__chip {
    background: rgb(var(--rgb-blue) / 0.06);
    border-color: rgb(var(--rgb-blue) / 0.18);
    color: var(--color-blue);
}
.home-brand__stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--color-border-light);
    margin-top: 4px;
}
.home-brand__stat-num {
    font-size: 17px;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--color-text-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1;
    display: block;
    margin-bottom: 4px;
}
.home-brand__stat-lbl {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    line-height: 1.3;
}
.home-brand__badge-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 2px;
}
.home-brand__badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: rgb(var(--rgb-blue) / 0.08);
    color: var(--color-blue);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.04em;
    padding: 4px 9px;
    border-radius: var(--radius-pill);
    width: fit-content;
}
.home-brand__link {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-blue);
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    transition: gap 150ms;
}
.home-brand-card:hover .home-brand__link { gap: 7px; }
.home-brand-card--cta {
    background: linear-gradient(155deg, var(--color-navy-deep) 0%, var(--color-navy) 100%);
    border: 1px solid rgb(var(--rgb-blue) / 0.3);
    color: var(--color-text-on-dark);
    position: relative;
    overflow: hidden;
}
.home-brand-card--cta .home-brand__meta { color: rgb(var(--rgb-on-dark) / 0.55); }
.home-brand-card--cta::before {
    content: '';
    position: absolute;
    top: -40%; right: -30%;
    width: 280px; height: 280px;
    background: radial-gradient(circle, rgb(var(--rgb-blue) / 0.4) 0%, transparent 65%);
    filter: blur(24px);
    pointer-events: none;
}
.home-brand-card--cta .home-brand__logo {
    background: transparent;
    border-bottom: 1px solid rgb(var(--rgb-on-dark) / 0.08);
    position: relative;
    z-index: var(--z-raised);
}
.home-brand-card--cta .home-brand__body { position: relative; z-index: var(--z-raised); }
.home-brand__cta-num {
    font-size: 44px;
    font-weight: 700;
    color: var(--color-blue-electric);
    letter-spacing: -0.03em;
    line-height: 1;
    margin: 0;
    font-variant-numeric: tabular-nums;
}
.home-brand__cta-lbl {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-on-dark);
    margin: 0;
}
.home-brand__cta-desc {
    font-size: 12px;
    color: rgb(var(--rgb-on-dark) / 0.65);
    line-height: 1.55;
    margin: 0;
    flex: 1;
}
.home-brand__cta-link {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-blue-electric);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding-top: 10px;
    border-top: 1px solid rgb(var(--rgb-on-dark) / 0.08);
    transition: gap 150ms;
}
.home-brand-card--cta:hover .home-brand__cta-link { gap: 10px; }

/* ═══════════════════════════════════════════════
 * S06 — TÉMOIGNAGES
 * ═══════════════════════════════════════════════ */
.home-temoignages {
    background: var(--color-cream);
    padding: var(--section-py) 0;
}
.home-temoignages__head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 32px;
    margin-bottom: 48px;
}
.home-temoignages__head h2 { margin: 0 0 8px; }
.home-temoignages__lead {
    font-size: 15px;
    color: var(--color-text-body);
    max-width: 52ch;
    margin: 0;
}
.home-temoignages__cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--color-blue);
    font-size: 14px;
    font-weight: 600;
    transition: gap 150ms;
}
.home-temoignages__cta:hover { gap: 10px; }

.home-testimonials {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 900px) { .home-testimonials { grid-template-columns: 1fr; } }
.home-testimonial {
    background: var(--color-white);
    border: 1px solid var(--color-border-light);
    border-radius: 16px;
    padding: 24px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 18px;
    align-items: flex-start;
    box-shadow: 0 2px 12px rgb(var(--rgb-navy) / 0.04);
}
.home-testimonial__avatar {
    width: 56px; height: 56px;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: 0 2px 8px rgb(var(--rgb-navy) / 0.12);
}
.home-testimonial__name {
    font-size: 15px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin: 0 0 2px;
}
.home-testimonial__role {
    font-size: 12px;
    color: var(--color-text-muted);
    margin: 0 0 12px;
}
.home-testimonial__chip {
    display: inline-block;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-blue);
    background: rgb(var(--rgb-blue) / 0.07);
    padding: 3px 9px;
    border-radius: 4px;
    margin-bottom: 14px;
}
.home-testimonial__quote {
    font-size: 13px;
    line-height: 1.75;
    color: var(--color-text-body);
    font-style: italic;
    margin: 0;
}

/* ═══════════════════════════════════════════════
 * S07 — MISSION
 * ═══════════════════════════════════════════════ */
.home-mission {
    background: var(--color-off-white);
    padding: var(--section-py) 0;
}
.home-mission__split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(40px, 5vw, 80px);
    align-items: center;
}
@media (max-width: 900px) { .home-mission__split { grid-template-columns: 1fr; } }
.home-mission__copy h2 { margin: 0 0 24px; }
.home-mission__copy p {
    font-size: 15px;
    line-height: 1.75;
    color: var(--color-text-body);
    margin: 0 0 18px;
}
.home-mission__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
    margin-top: 8px;
}
.home-mission__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--color-blue);
    font-size: 15px;
    font-weight: 600;
    transition: gap 150ms;
}
.home-mission__link:hover { gap: 10px; }
.home-mission__photo {
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: 0 8px 40px rgb(var(--rgb-navy) / 0.12);
    line-height: 0;
}
.home-mission__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    min-height: 360px;
}

/* ═══════════════════════════════════════════════
 * S08 — ENGAGEMENTS
 * ═══════════════════════════════════════════════ */
.home-engagements {
    background: var(--color-navy-deep);
    color: var(--color-text-on-dark);
    padding: var(--section-py) 0;
    position: relative;
    overflow: hidden;
}
.home-engagements::before,
.home-engagements::after {
    content: '';
    position: absolute;
    pointer-events: none;
    z-index: var(--z-base);
}
.home-engagements::before {
    top: -200px; left: -200px;
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgb(var(--rgb-blue) / 0.2) 0%, transparent 70%);
    filter: blur(100px);
}
.home-engagements::after {
    bottom: -200px; right: -200px;
    width: 700px; height: 700px;
    background: radial-gradient(circle, rgb(var(--rgb-blue-electric) / 0.12) 0%, transparent 70%);
    filter: blur(100px);
}
.home-engagements__inner { position: relative; z-index: var(--z-raised); }
.home-engagements__head {
    text-align: center;
    max-width: 60ch;
    margin: 0 auto 64px;
}
.home-engagements__head .home-eyebrow { justify-content: center; }
.home-eng-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
@media (max-width: 1024px) { .home-eng-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .home-eng-grid { grid-template-columns: 1fr; } }
.home-eng-card {
    padding: 28px;
    background: rgb(var(--rgb-on-dark) / 0.03);
    border: 1px solid rgb(var(--rgb-on-dark) / 0.08);
    border-radius: 16px;
    transition: border-color 300ms, box-shadow 300ms, transform 300ms var(--ease-out);
}
.home-eng-card:hover {
    border-color: rgb(var(--rgb-blue) / 0.4);
    box-shadow: 0 0 40px rgb(var(--rgb-blue) / 0.18);
    transform: translateY(-2px);
}
.home-eng-card svg { color: var(--color-blue-electric); margin-bottom: 18px; }
.home-eng-card__num {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-cyan-tech);
    margin: 0 0 12px;
}
.home-eng-card__title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-on-dark);
    margin: 0 0 12px;
    letter-spacing: -0.02em;
}
.home-eng-card__desc {
    font-size: 13px;
    line-height: 1.7;
    color: rgb(var(--rgb-on-dark) / 0.55);
    margin: 0;
}

/* ═══════════════════════════════════════════════
 * S09 — PROCESS
 * ═══════════════════════════════════════════════ */
.home-process {
    background: var(--color-cream);
    padding: var(--section-py) 0;
    overflow: hidden;
}
.home-process__head {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 64px;
}
.home-process__head .home-eyebrow { justify-content: center; }
.home-process__timeline { position: relative; }

.home-process__nodes {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    align-items: center;
    height: 56px;
    position: relative;
    margin-bottom: 24px;
}
.home-process__nodes::before {
    content: '';
    position: absolute;
    left: 12.5%;
    right: 12.5%;
    top: 50%;
    height: 0;
    border-top: 1.5px dashed rgb(var(--rgb-navy) / 0.18);
    z-index: var(--z-base);
}
.home-process__node {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-blue) 0%, var(--color-blue-electric) 100%);
    color: var(--color-white);
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    justify-self: center;
    position: relative;
    z-index: var(--z-raised);
    box-shadow: 0 4px 12px rgb(var(--rgb-blue) / 0.3);
}

.home-process-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
@media (max-width: 900px) {
    .home-process-grid { grid-template-columns: 1fr 1fr; }
    .home-process__nodes { grid-template-columns: repeat(2, 1fr); height: auto; gap: 16px; margin-bottom: 16px; }
    .home-process__nodes::before { display: none; }
}
@media (max-width: 560px) {
    .home-process-grid { grid-template-columns: 1fr; }
    .home-process__nodes { display: none; }
}
.home-process-card {
    background: var(--color-white);
    border: 1px solid var(--color-border-light);
    border-radius: 12px;
    padding: 24px;
    border-top: 3px solid var(--color-blue);
    box-shadow: 0 2px 12px rgb(var(--rgb-navy) / 0.04);
}
.home-process-card__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0 0 12px;
}
.home-process-card__desc {
    font-size: 13px;
    line-height: 1.7;
    color: var(--color-text-body);
    margin: 0 0 16px;
}
.home-process-card__chip {
    display: inline-block;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-blue);
    background: rgb(var(--rgb-blue) / 0.08);
    border: 1px solid rgb(var(--rgb-blue) / 0.18);
    padding: 3px 9px;
    border-radius: 100px;
}
.home-process__cta {
    text-align: center;
    margin-top: 64px;
}

/* ═══════════════════════════════════════════════
 * S10 — FAQ
 * ═══════════════════════════════════════════════ */
.home-faq {
    background: var(--color-off-white);
    padding: var(--section-py) 0;
}
.home-faq__head {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 48px;
}
.home-faq__head .home-eyebrow { justify-content: center; }
.home-faq__list {
    max-width: 800px;
    margin: 0 auto;
    border-top: 1px solid var(--color-border-light);
}
.home-faq__item { border-bottom: 1px solid var(--color-border-light); }
.home-faq__item summary {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
    padding: 24px 0;
    cursor: pointer;
    list-style: none;
}
.home-faq__item summary::-webkit-details-marker { display: none; }
.home-faq__q {
    font-size: clamp(15px, 1.6vw, 17px);
    font-weight: 600;
    color: var(--color-text-primary);
    line-height: 1.35;
    flex: 1;
    padding-top: 2px;
}
.home-faq__ico {
    width: 28px; height: 28px;
    border: 1.5px solid rgb(var(--rgb-navy) / 0.15);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--color-blue);
    transition: transform 220ms var(--ease-out), background 220ms;
}
.home-faq__item[open] .home-faq__ico {
    transform: rotate(45deg);
    background: rgb(var(--rgb-blue) / 0.08);
}
.home-faq__a {
    padding: 0 48px 24px 0;
    color: var(--color-text-body);
    line-height: 1.75;
    font-size: 15px;
}

/* ═══════════════════════════════════════════════
 * S11 — CTA FINAL
 * ═══════════════════════════════════════════════ */
.home-cta-final {
    background: var(--color-navy-deepest);
    color: var(--color-text-on-dark);
    padding: var(--section-py) 0;
    position: relative;
    overflow: hidden;
    text-align: center;
}
.home-cta-final::before {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 800px; height: 800px;
    background: radial-gradient(circle, rgb(var(--rgb-blue) / 0.22) 0%, transparent 60%);
    filter: blur(100px);
    pointer-events: none;
}
.home-cta-final__inner {
    position: relative;
    z-index: var(--z-raised);
    max-width: 740px;
    margin: 0 auto;
}
.home-cta-final h2 {
    font-family: 'Inter', sans-serif;
    font-size: clamp(32px, 3.6vw, 52px);
    font-weight: 600;
    letter-spacing: -0.035em;
    line-height: 1.05;
    color: var(--color-text-on-dark);
    margin: 0 0 20px;
    text-wrap: balance;
}
.home-cta-final p {
    font-size: 17px;
    color: rgb(var(--rgb-on-dark) / 0.66);
    line-height: 1.6;
    margin: 0 auto 36px;
    max-width: 56ch;
}
.home-cta-final__actions {
    display: flex;
    gap: 14px;
    justify-content: center;
    flex-wrap: wrap;
}
.home-cta-final .home-eyebrow { justify-content: center; }

/* Mention « Préférez le téléphone ? » sous le CTA — bloc optionnel.
 * Utilise --rgb-on-dark pour basculer texte blanc (V3 dark) → ink
 * (theme light) en un seul flip de token.
 *
 * Spécificité bumpée (p.home-cta-final__tel + .home-cta-final scope)
 * pour battre la règle générale `.home-cta-final p` qui impose
 * font-size 17px / line-height 1.6 / max-width 56ch / margin auto. */
.home-cta-final p.home-cta-final__tel {
    margin: 20px 0 0;
    max-width: none;
    font-size: 12px;
    line-height: 1.4;
    letter-spacing: 0.04em;
    color: rgb(var(--rgb-on-dark) / 0.45);
}
.home-cta-final__tel span {
    color: rgb(var(--rgb-on-dark) / 0.65);
}
.home-cta-final__tel a {
    color: rgb(var(--rgb-on-dark) / 0.85);
    text-decoration: none;
    font-variant-numeric: tabular-nums;
    border-bottom: 1px solid rgb(var(--rgb-on-dark) / 0.25);
}
.home-cta-final__tel a:hover {
    color: var(--color-blue);
    border-bottom-color: var(--color-blue);
}

/* ═══════════════════════════════════════════════
 * Reduced motion (override animations)
 * ═══════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
    .home-hero__product-glow,
    .home-hero__product-img,
    .home-tbar__bar { animation: none !important; }
}
