/* ============================================================
   VELACO — Landing Page CSS v1.2
   Palette : #000c66 navy · #f8ff64 yellow · #dcdcdc gray · #fff
   2 sections dark (navy) max : Results + Final CTA
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@100..900&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* Halo jaune fixe — même halo que le hero, reste en place au scroll */
.vc-halo-bg {
    position: fixed;
    top: 44%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 700px;
    height: 560px;
    background: radial-gradient(ellipse at center,
        rgba(248,255,100,.60) 0%,
        rgba(248,255,100,.22) 30%,
        transparent 68%);
    pointer-events: none;
    z-index: -1;
}

:root {
    --navy:      #000c66;
    --yellow:    #f8ff64;
    --yellow-dark:#9a8700;
    --gray:      #e5e7eb;
    --gray-light:#f4f5f7;
    --gray-card: #f3f4f6;
    --white:     #ffffff;
    --text:      #0a0a0a;
    --text-muted:#6b7280;

    --font: 'Geist', 'Inter', -apple-system, 'Helvetica Neue', Arial, sans-serif;

    --r-sm:   6px;
    --r-md:   12px;
    --r-lg:   20px;
    --r-xl:   28px;
    --r-full: 9999px;

    --shadow-sm:  0 1px 4px rgba(0,0,0,.05);
    --shadow-md:  0 4px 24px rgba(0,0,0,.07);
    --shadow-lg:  0 8px 40px rgba(0,0,0,.09);
    --shadow-navy:0 6px 28px rgba(0,12,102,.2);

    --max-w: 1180px;
    --px:    clamp(12px, 1vw, 14px);
    --py:    clamp(56px, 6.5vw, 92px);
}

html { scroll-behavior: smooth; }

html { background: transparent; }

/* Geist appliquée globalement à toutes les pages du thème (front, audit, blog, etc.) */
body {
    font-family: var(--font);
    -webkit-font-smoothing: antialiased;
}

body.home {
    position: relative;
    background: var(--white);
    color: var(--text);
    line-height: 1.6;
    overflow-x: hidden;
}

.vc-wrap {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 var(--px);
}

/* ─── NAVBAR ─────────────────────────────────── */
.vc-nav {
    position: fixed; top: 12px; left: 0; right: 0; z-index: 100;
    background: transparent;
}

.vc-nav .vc-wrap {
    position: relative;
    background: transparent;
}

/* Le fond flouté est sur ::before (pseudo-element) plutôt que sur __inner :
   ainsi __inner ne crée pas un stacking context qui bloquerait le backdrop-filter
   des descendants (notamment le dropdown). */
.vc-nav__inner {
    position: relative;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    height: 70px;
    padding: 0 20px;
    border-radius: 9999px;
}
.vc-nav__inner::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    z-index: -1;
    pointer-events: none;
    background: rgba(255,255,255,.72);
    backdrop-filter: blur(24px) saturate(180%);
    -webkit-backdrop-filter: blur(24px) saturate(180%);
    border: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 2px 16px rgba(0,0,0,.07);
    opacity: 0;
    transition: opacity .45s;
}
.vc-nav.scrolled .vc-nav__inner::before {
    opacity: 1;
}

/* Logo — s'écarte à gauche au top, rentre dans le pill au scroll */
.vc-nav__logo {
    text-decoration: none;
    display: flex; align-items: center;
    justify-self: start;
    transform: translateX(-18px);
    transition: transform .45s cubic-bezier(.4,0,.2,1);
}
.vc-nav.scrolled .vc-nav__logo {
    transform: translateX(0);
}

.vc-nav__logo-img {
    height: 30px; width: auto; display: block;
}

.vc-nav__links {
    display: flex; align-items: center; gap: 0; list-style: none;
    justify-self: center;
}
.vc-nav__links a,
.vc-nav__dropdown-trigger {
    text-decoration: none; font-family: var(--font);
    font-size: .875rem; font-weight: 600;
    color: var(--text-muted); padding: 6px 14px;
    border-radius: var(--r-full);
    background: transparent; border: none; cursor: pointer;
    display: inline-flex; align-items: center; gap: 5px;
    transition: color .15s, background .15s;
}
.vc-nav__links a:hover,
.vc-nav__dropdown-trigger:hover { background: transparent; color: var(--navy); }
.vc-nav__item--has-dropdown.is-open .vc-nav__dropdown-trigger { color: var(--navy); }

/* ── Dropdown (Offres) ── */
.vc-nav__item--has-dropdown { position: relative; }
.vc-nav__item-header { display: inline-flex; align-items: center; }
.vc-nav__item--has-dropdown.is-open .vc-nav__item-anchor { color: var(--navy); }
.vc-nav__chevron { transition: transform .2s; flex-shrink: 0; }
.vc-nav__item--has-dropdown.is-open .vc-nav__chevron { transform: rotate(180deg); }

.vc-nav__dropdown {
    /* position: absolute relative au LI parent → toujours aligné sous le trigger,
       garanti, sans dépendre de JS de positioning. top calc compense la hauteur
       de la pill pour que le dropdown sorte 8px sous le bord bas. */
    position: absolute;
    top: calc(100% + 30px);
    left: 0;
    transform: translateY(-6px);
    min-width: 240px;
    /* Backdrop-filter fonctionne maintenant (le pseudo-element du header a
       libéré le stacking context). Mêmes valeurs que le header pour matcher. */
    background: rgba(255, 255, 255, .72);
    backdrop-filter: blur(24px) saturate(180%);
    -webkit-backdrop-filter: blur(24px) saturate(180%);
    border: 1px solid rgba(0, 0, 0, .08);
    border-radius: var(--r-md);
    box-shadow: 0 2px 16px rgba(0, 0, 0, .07);
    list-style: none; padding: 6px;
    opacity: 0; pointer-events: none;
    transition: opacity .18s, transform .18s;
    z-index: 110;
}
/* Bridge invisible : couvre les 8px de gap entre le bouton et le dropdown,
   pour que le hover reste continu quand la souris traverse l'espace vide. */
.vc-nav__dropdown::before {
    content: '';
    position: absolute;
    top: -8px; left: 0; right: 0;
    height: 8px;
}
.vc-nav__item--has-dropdown.is-open .vc-nav__dropdown {
    opacity: 1; pointer-events: auto;
    transform: translateY(0);
}
.vc-nav__dropdown a {
    display: block;
    padding: 10px 14px;
    font-size: .875rem; font-weight: 600;
    color: var(--text-muted);
    border-radius: 8px;
    white-space: nowrap;
}
.vc-nav__dropdown a:hover { background: transparent; color: var(--navy); }

/* Actions — s'écarte à droite au top, rentre dans le pill au scroll */
.vc-nav__actions {
    display: flex; align-items: center; gap: 10px; justify-self: end;
    transform: translateX(18px);
    transition: transform .45s cubic-bezier(.4,0,.2,1);
}
.vc-nav.scrolled .vc-nav__actions {
    transform: translateX(0);
}
.vc-nav__actions .vc-btn {
    padding: 16px 22px;
    border-radius: var(--r-full);
    font-size: .875rem;
}
.vc-nav__actions .vc-btn--primary:hover {
    background: var(--navy);
    box-shadow: var(--shadow-navy);
}

.vc-nav__mobile-btn {
    display: none; background: none; border: none;
    cursor: pointer; padding: 8px; color: var(--navy);
}

/* ─── SVG FILTER ──────────────────────────────── */
.vc-lg-filter { position: absolute; width: 0; height: 0; overflow: hidden; }

/* ─── BUTTONS ─────────────────────────────────── */
.vc-btn {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--font); font-weight: 600; font-size: .9375rem;
    text-decoration: none; border: none; cursor: pointer;
    border-radius: 14px; padding: 18px 26px;
    white-space: nowrap; transition: all .18s; line-height: 1;
    flex-shrink: 0;
}
.vc-btn--primary {
    background: var(--navy); color: #fff;
}
.vc-btn--primary:hover {
    background: #001299;
    transform: translateY(-1px); box-shadow: var(--shadow-navy);
}
.vc-btn--cta {
    background: var(--yellow); color: var(--navy);
    box-shadow: 0 4px 20px rgba(248,255,100,.35);
}
.vc-btn--cta:hover {
    background: #eef500;
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(248,255,100,.5);
}
.vc-btn--outline {
    background: transparent; color: var(--navy);
    border: 1.5px solid var(--navy);
}
.vc-btn--outline:hover {
    background: var(--navy); color: #fff;
}
.vc-btn--outline-white {
    background: transparent; color: #fff;
    border: 1.5px solid rgba(255,255,255,.35);
}
.vc-btn--outline-white:hover {
    border-color: #fff; background: rgba(255,255,255,.08);
}
.vc-btn--soft {
    background: var(--gray-light); color: var(--text);
    border: 1.5px solid transparent;
}
.vc-btn--soft:hover {
    background: var(--navy); color: #fff;
    transform: translateY(-2px);
    box-shadow: var(--shadow-navy);
}
.vc-btn--sm  { font-size: .8125rem; padding: 9px 18px; }
.vc-btn--lg  { font-size: 1rem;     padding: 15px 30px; }
.vc-btn__arr { display: inline-flex; transition: transform .18s; }
.vc-btn:hover .vc-btn__arr { transform: translateX(3px); }

/* Circle arrow (Softriver style) */
.vc-btn__arr-wrap {
    display: inline-flex; align-items: center; justify-content: center;
    width: 30px; height: 30px;
    background: rgba(0,12,102,.13);
    border-radius: 50%; flex-shrink: 0;
    transition: transform .18s;
}
.vc-btn:hover .vc-btn__arr-wrap { transform: translateX(3px); }

/* ─── LIQUID GLASS BUTTONS ───────────────────────── */
.vc-btn--cta.vc-btn--liquid,
.vc-btn--soft.vc-btn--liquid {
    background: rgba(255,255,255,.18) !important;
    color: var(--navy) !important;
    border: 1px solid rgba(255,255,255,.45) !important;
    box-shadow: none !important;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    box-shadow:
        0 2px 8px rgba(0,0,0,.08),
        inset 0 1px 0 rgba(255,255,255,.6),
        inset 0 -1px 0 rgba(0,0,0,.06),
        inset 1px 0 0 rgba(255,255,255,.35),
        inset -1px 0 0 rgba(255,255,255,.35) !important;
    backdrop-filter: blur(16px) saturate(160%);
    -webkit-backdrop-filter: blur(16px) saturate(160%);
    transition: box-shadow .2s, transform .18s, background .2s;
}
.vc-btn--cta.vc-btn--liquid::before,
.vc-btn--soft.vc-btn--liquid::before {
    content: '';
    position: absolute; inset: 0; z-index: -1;
    border-radius: inherit;
    backdrop-filter: url('#liquid-glass');
    -webkit-backdrop-filter: url('#liquid-glass');
}
.vc-btn--cta.vc-btn--liquid:hover,
.vc-btn--soft.vc-btn--liquid:hover {
    background: rgba(255,255,255,.28) !important;
    transform: translateY(-1px);
    box-shadow:
        0 4px 16px rgba(0,0,0,.1),
        inset 0 1px 0 rgba(255,255,255,.7),
        inset 0 -1px 0 rgba(0,0,0,.05),
        inset 1px 0 0 rgba(255,255,255,.4),
        inset -1px 0 0 rgba(255,255,255,.4) !important;
}

/* ─── SECTION LABELS & HEADINGS ─────────────────── */
.vc-label {
    display: block; text-align: center;
    font-size: .6875rem; font-weight: 700; letter-spacing: .11em;
    text-transform: uppercase; color: var(--navy); margin-bottom: 14px;
}
.vc-label--light { color: rgba(255,255,255,.5); }

.vc-h2 {
    font-size: clamp(1.875rem, 3.5vw, 3.25rem);
    font-weight: 500; line-height: 1.08; letter-spacing: -0.03em;
    color: var(--navy); margin-bottom: 16px;
}
.vc-h2--light { color: #fff; }

.vc-sub {
    font-size: 1rem; color: var(--text-muted);
    line-height: 1.55; max-width: 540px;
}
.vc-sub--light { color: rgba(255,255,255,.6); }

.vc-head        { margin-bottom: clamp(40px,5vw,64px); }
.vc-head--c     { text-align: center; }
.vc-head--c .vc-sub { margin: 0 auto; }

/* ─── HERO V2 (centré, Lemrock-style) ───────────── */
.vc-hero-v2 {
    padding-top: calc(78px + clamp(64px, 9vw, 112px));
    padding-bottom: 0;
    background: transparent;
    position: relative; overflow: hidden;
    text-align: center;
}
/* Halo supprimé — remplacé par .vc-halo-bg fixe */
.vc-hero-v2__inner {
    position: relative; z-index: 2;
    display: flex; flex-direction: column; align-items: center;
    gap: 0;
}

/* ── HERO ENTRY ANIMATION — fade-up staggered, framer-motion timing ── */
@keyframes vc-hero-fade-up {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
@media (prefers-reduced-motion: no-preference) {
    .vc-hero-v2__badges,
    .vc-hero-v2__h1,
    .vc-hero-v2__sub,
    .vc-hero-v2__cta,
    .vc-hero-v2__proof {
        opacity: 0;
        transform: translateY(24px);
        animation: vc-hero-fade-up 0.6s ease-out forwards;
    }
    .vc-hero-v2__badges { animation-delay: 0.10s; }
    .vc-hero-v2__h1     { animation-delay: 0.22s; }
    .vc-hero-v2__sub    { animation-delay: 0.34s; }
    .vc-hero-v2__cta    { animation-delay: 0.46s; }
    .vc-hero-v2__proof  { animation-delay: 0.58s; }
}
/* Badges row — urgence + rating, même ligne centrée */
.vc-hero-v2__badges {
    display: flex; align-items: center; justify-content: center; gap: 16px;
    flex-wrap: wrap; margin-bottom: 36px;
}
.vc-hero-v2__urgency {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: .8125rem; color: var(--text-muted);
}
.vc-hero-v2__urgency-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #ef4444; flex-shrink: 0;
    animation: vc-urgency-blink 1.6s ease-in-out infinite;
}
.vc-hero-v2__rating {
    display: inline-flex; align-items: center; gap: 8px;
    border: 1px solid var(--gray); border-radius: var(--r-full);
    padding: 6px 14px;
    font-size: .8125rem; font-weight: 500; color: var(--text-muted);
    background: rgba(255,255,255,.85); backdrop-filter: blur(8px);
}
.vc-hero-v2__rating strong { color: var(--navy); font-weight: 700; }

/* H1 avec rotating words */
.vc-hero-v2__h1 {
    font-size: clamp(2.25rem, 5vw, 3.75rem);
    font-weight: 500; line-height: 1.08;
    letter-spacing: -0.03em; color: var(--navy);
    margin-bottom: 24px;
    max-width: 1100px;
    white-space: nowrap;
}
.vc-hero-v2__rotating-wrap {
    display: inline-block; overflow: hidden;
    vertical-align: bottom;
    /* hauteur définie par JS après rendu */
}
.vc-hero-v2__rotating-track {
    display: flex; flex-direction: column;
    transition: transform 0.55s cubic-bezier(0.16, 1, 0.3, 1);
}
.vc-hero-v2__rotating-word {
    display: block;
    line-height: 1.05; color: var(--navy); white-space: nowrap;
    padding-bottom: 0; /* aligné sur line-height du H1 (1.05) pour égaliser l'espacement entre lignes */
}

.vc-hero-v2__sub {
    font-size: clamp(1rem, 1.5vw, 1.125rem);
    color: var(--text-muted); line-height: 1.6;
    max-width: 740px; margin-bottom: 40px;
}
.vc-hero-v2__sub strong { color: var(--navy); font-weight: 700; }
.vc-hero-v2__cta {
    display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
    margin-bottom: 32px;
}
.vc-hero-v2__cta .vc-btn {
    border-radius: 9999px;
    padding: 15px 24px 15px 28px;
}
.vc-hero-v2__cta .vc-btn--cta {
    background: var(--yellow); color: var(--navy);
    box-shadow: 0 4px 20px rgba(248,255,100,.4);
}
.vc-hero-v2__cta .vc-btn--cta:hover {
    background: #f0f752;
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(248,255,100,.55);
}
.vc-hero-v2__cta .vc-btn--cta .vc-btn__arr-wrap {
    background: rgba(0,12,102,.12);
}
.vc-hero-v2__cta .vc-btn--soft {
    padding: 15px 32px;
}

/* Social proof — 3 stats sous les CTAs */
.vc-hero-v2__proof {
    display: flex; align-items: center; justify-content: center;
    flex-wrap: wrap; gap: 0;
}
.vc-hero-v2__proof-item {
    display: flex; align-items: center; gap: 6px;
    font-size: .875rem; color: var(--text-muted);
    padding: 0 24px;
    border-right: 1px solid var(--gray);
}
.vc-hero-v2__proof-item:first-child { padding-left: 0; }
.vc-hero-v2__proof-item:last-child { border-right: none; padding-right: 0; }
.vc-hero-v2__proof-item strong { color: var(--navy); font-weight: 700; }
.vc-hero-v2__proof-item svg { color: var(--navy); flex-shrink: 0; }

/* ─── HERO ──────────────────────────────────────── */
.vc-hero {
    padding-top:    calc(66px + clamp(52px,8vw,96px));
    padding-bottom: clamp(64px,8vw,100px);
    background: transparent;
    position: relative; overflow: hidden;
}

/* Strong yellow radial — charte Velaco page 8 */
.vc-hero::before {
    content: ''; position: absolute;
    top: -60px; left: -80px;
    width: 820px; height: 620px;
    background: radial-gradient(ellipse at 40% 40%,
        rgba(248,255,100,.55) 0%,
        rgba(248,255,100,.18) 30%,
        transparent 65%);
    pointer-events: none; z-index: 0;
}

/* Second yellow radial — bottom-right symmetry */
.vc-hero::after {
    content: ''; position: absolute;
    bottom: -80px; right: -80px;
    width: 640px; height: 520px;
    background: radial-gradient(ellipse at 60% 60%,
        rgba(248,255,100,.38) 0%,
        rgba(248,255,100,.11) 35%,
        transparent 65%);
    pointer-events: none; z-index: 0;
}

.vc-hero__inner {
    position: relative; z-index: 1;
}

/* Badges row */
.vc-hero__badges {
    display: flex; align-items: center; gap: 10px;
    flex-wrap: wrap; margin-bottom: 32px;
}

/* Urgency badge */
.vc-hero__urgency {
    display: inline-flex; align-items: center; gap: 8px;
    border: 1px solid var(--gray); border-radius: var(--r-full);
    padding: 7px 14px;
    font-size: .8125rem; font-weight: 600; color: var(--navy);
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(8px);
}

/* Rating badge */
.vc-hero__rating {
    display: inline-flex; align-items: center; gap: 8px;
    border: 1px solid var(--gray); border-radius: var(--r-full);
    padding: 7px 14px;
    font-size: .8125rem; font-weight: 500; color: var(--text-muted);
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(8px);
}
.vc-hero__rating strong { color: var(--navy); font-weight: 700; }
.vc-hero__stars { display: inline-flex; align-items: center; gap: 2px; color: var(--navy); }
.vc-hero__urgency-dot {
    width: 7px; height: 7px;
    background: #ef4444; border-radius: 50%; flex-shrink: 0;
    position: relative;
}
.vc-hero__urgency-dot::before {
    content: ''; position: absolute; inset: -3px;
    background: #ef4444; border-radius: 50%;
    opacity: .2; animation: pulse-red 1.8s ease-out infinite;
}
@keyframes pulse-red {
    0%   { transform: scale(.8); opacity: .3; }
    70%  { transform: scale(2.4); opacity: 0; }
    100% { transform: scale(2.4); opacity: 0; }
}

.vc-hero__h1 {
    font-size: clamp(2.25rem, 5vw, 3.75rem);
    font-weight: 500; line-height: 1.08;
    letter-spacing: -0.03em; color: var(--navy);
    margin-bottom: 24px;
}

/* ── Rotating words animation ─────────────────── */
.vc-hero__rotating-wrap {
    display: inline-block;
    overflow: hidden;
    vertical-align: bottom;
    height: 1.2em;
}
.vc-hero__rotating-track {
    display: flex;
    flex-direction: column;
    transition: transform 0.55s cubic-bezier(0.16, 1, 0.3, 1);
}
.vc-hero__rotating-word {
    display: block;
    height: 1.2em;
    line-height: 1.2;
    color: var(--navy);
    white-space: nowrap;
}

.vc-hero__sub {
    font-size: clamp(1rem, 1.5vw, 1.125rem);
    color: var(--text-muted); line-height: 1.7;
    max-width: 580px; margin-bottom: 36px;
}
.vc-hero__sub strong { color: var(--navy); font-weight: 700; }

/* CTA + proof inline — même ligne */
.vc-hero__cta-row {
    display: flex; align-items: center; flex-wrap: nowrap; gap: 12px;
}
.vc-hero__cta-btns {
    display: flex; gap: 12px; flex-shrink: 0;
}
.vc-hero__cta-btns .vc-btn { flex: 1; justify-content: center; }

/* Social proof — inline avec les CTAs */
.vc-hero__proof {
    display: flex; align-items: center; flex-wrap: nowrap; gap: 0;
    padding-left: 16px; margin-left: 4px;
    border-left: 1px solid var(--gray);
    flex-shrink: 1; min-width: 0;
}
.vc-hero__proof-item {
    display: flex; align-items: center; gap: 6px;
    font-size: .875rem; color: var(--text-muted); white-space: nowrap;
    padding: 0 18px 0 0; margin: 0 18px 0 0;
    border-right: 1px solid var(--gray);
}
.vc-hero__proof-item:last-child { border-right: none; padding-right: 0; margin-right: 0; }
.vc-hero__proof-item strong { color: var(--navy); font-weight: 700; }
.vc-hero__proof-icon { color: var(--navy); flex-shrink: 0; }

/* ─── LOGOS STRIP ─────────────────────────────── */
.vc-logos {
    padding: 16px 0 12px; overflow: hidden;
    position: relative;
}
.vc-logos::before,
.vc-logos::after {
    content: '';
    position: absolute;
    top: 0; bottom: 0; width: 25%;
    z-index: 2; pointer-events: none;
}
.vc-logos::before {
    left: 0;
    background: linear-gradient(to right, #fff 0%, #fff 30%, rgba(255,255,255,.8) 55%, rgba(255,255,255,.3) 80%, transparent 100%);
}
.vc-logos::after {
    right: 0;
    background: linear-gradient(to left, #fff 0%, #fff 30%, rgba(255,255,255,.8) 55%, rgba(255,255,255,.3) 80%, transparent 100%);
}
.vc-logos__label {
    text-align: center; font-size: clamp(1.25rem, 2vw, 1.75rem); font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--navy); margin-bottom: clamp(20px, 2.5vw, 32px);
}
.vc-logos__track-wrap { overflow: hidden; }
.vc-logos__track {
    display: flex; align-items: center; gap: 0;
    animation: marquee 55s linear infinite; width: max-content;
}
/* pas de pause au hover */
@keyframes marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}
/* Gap géré par padding pour que -50% soit parfaitement symétrique */
.vc-logos__item { padding: 0 40px; }
.vc-logos__item {
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    font-size: .9375rem; font-weight: 700;
    color: #cacdd6; letter-spacing: -.01em;
    white-space: nowrap; transition: color .2s;
    cursor: default; user-select: none;
}
.vc-logos__img {
    display: block; object-fit: contain;
    filter: brightness(0) opacity(.55);
    height: 26px; width: auto;
}

/* Ajustements individuels — uniformité visuelle */
.vc-logos__img[data-logo="othrys"]        { height: 38px; }
.vc-logos__img[data-logo="biux"]          { height: 54px; }
.vc-logos__img[data-logo="valode-pistre"] { height: auto; width: 200px; }
.vc-logos__img[data-logo="essca"]         { height: 98px; }
.vc-logos__img[data-logo="mindsales"]     { height: 44px; }
.vc-logos__img[data-logo="la-guilde"]     { height: 68px; }
.vc-logos__img[data-logo="premices"]      { height: 84px; }

/* ─── PROBLEM ─────────────────────────────────── */
.vc-problem {
    padding: var(--py) 0;
    background: transparent;
}
.vc-problem .vc-wrap {
    max-width: var(--max-w);
}
.vc-problem__quote {
    font-size: clamp(1.75rem, 3vw, 2.75rem);
    font-weight: 500; color: var(--navy);
    line-height: 1.1; letter-spacing: -0.03em;
    max-width: 1100px;
    margin: 0 auto;
    text-wrap: balance;
    text-align: center;
}
.vc-problem__stats {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    margin-top: clamp(40px, 5vw, 56px);
    border-top: 1px solid var(--gray);
    border-bottom: 1px solid var(--gray);
}
.vc-problem__stat {
    grid-column: span 2;
    padding: clamp(28px, 3vw, 44px) clamp(20px, 2vw, 28px);
    text-align: center;
    border-right: 1px solid var(--gray);
    transition: background .2s;
}
.vc-problem__stat:nth-child(3) { border-right: none; }
.vc-problem__stat:nth-child(1),
.vc-problem__stat:nth-child(2),
.vc-problem__stat:nth-child(3) { border-bottom: 1px solid var(--gray); }
.vc-problem__stat:nth-child(4) { grid-column: 2 / span 2; }
.vc-problem__stat:nth-child(5) { grid-column: 4 / span 2; border-right: none; }
.vc-problem__stat:hover { background: rgba(0, 12, 102, 0.02); }
.vc-problem__stat-num {
    font-size: clamp(2.25rem, 4vw, 3.5rem);
    font-weight: 600;
    color: var(--navy);
    letter-spacing: -0.04em;
    line-height: 1;
    margin-bottom: 14px;
    white-space: nowrap;
}
.vc-problem__stat-unit {
    font-size: 0.55em;
    font-weight: 500;
    color: var(--text-muted);
    letter-spacing: -0.02em;
}
.vc-problem__stat-label {
    font-size: 0.875rem;
    color: var(--text-muted);
    line-height: 1.55;
    max-width: 240px;
    margin: 0 auto;
}
@media (max-width: 900px) {
    .vc-problem__stats { grid-template-columns: repeat(4, 1fr); }
    .vc-problem__stat,
    .vc-problem__stat:nth-child(4),
    .vc-problem__stat:nth-child(5) { grid-column: span 2; border-right: 1px solid var(--gray); border-bottom: 1px solid var(--gray); }
    .vc-problem__stat:nth-child(2),
    .vc-problem__stat:nth-child(4) { border-right: none; }
    .vc-problem__stat:nth-child(5) { grid-column: 2 / span 2; border-right: none; border-bottom: none; }
    .vc-problem__stat:nth-child(3) { border-right: 1px solid var(--gray); }
}
@media (max-width: 560px) {
    .vc-problem__stats { grid-template-columns: 1fr; }
    .vc-problem__stat,
    .vc-problem__stat:nth-child(4),
    .vc-problem__stat:nth-child(5) { grid-column: 1 / -1; border-right: none; border-bottom: 1px solid var(--gray); }
    .vc-problem__stat:last-child { border-bottom: none; }
}

/* ─── PROBLEM — CARDS MODE ─────────────────────── */
.vc-problem__stats--cards {
    border: none;
    gap: 20px;
    margin-top: clamp(40px, 5vw, 64px);
}
.vc-problem__stats--cards .vc-problem__stat,
.vc-problem__stats--cards .vc-problem__stat:nth-child(1),
.vc-problem__stats--cards .vc-problem__stat:nth-child(2),
.vc-problem__stats--cards .vc-problem__stat:nth-child(3),
.vc-problem__stats--cards .vc-problem__stat:nth-child(4),
.vc-problem__stats--cards .vc-problem__stat:nth-child(5) {
    border: none;
    background: var(--white);
    border-radius: var(--r-md);
    box-shadow: var(--shadow-sm);
    padding: clamp(28px, 3vw, 36px) clamp(22px, 2.4vw, 30px);
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 14px;
    transition: transform .35s cubic-bezier(.22,1,.36,1), box-shadow .25s ease, border-color .25s ease;
    border: 1px solid var(--gray);
    opacity: 0;
    transform: translateY(20px);
    position: relative;
    overflow: hidden;
}
.vc-problem__stats--cards .vc-problem__stat.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.vc-problem__stats--cards .vc-problem__stat:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 32px -16px rgba(0, 12, 102, .25), 0 4px 12px -4px rgba(0, 12, 102, .08);
    border-color: var(--navy);
    background: var(--white);
}

.vc-problem__stats--cards .vc-problem__stat-num {
    text-align: left;
    margin-bottom: 4px;
    font-size: clamp(2rem, 3.4vw, 2.75rem);
}
.vc-problem__stats--cards .vc-problem__stat-label {
    text-align: left;
    max-width: none;
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.55;
}
.vc-problem__stats--cards .vc-problem__stat-counter {
    display: inline-block;
    font-variant-numeric: tabular-nums;
}

@media (max-width: 900px) {
    .vc-problem__stats--cards { grid-template-columns: repeat(4, 1fr); }
    .vc-problem__stats--cards .vc-problem__stat,
    .vc-problem__stats--cards .vc-problem__stat:nth-child(4),
    .vc-problem__stats--cards .vc-problem__stat:nth-child(5) { border: 1px solid var(--gray); }
    .vc-problem__stats--cards .vc-problem__stat:nth-child(5) { grid-column: 2 / span 2; }
}
@media (max-width: 560px) {
    .vc-problem__stats--cards { grid-template-columns: 1fr; gap: 14px; }
    .vc-problem__stats--cards .vc-problem__stat,
    .vc-problem__stats--cards .vc-problem__stat:nth-child(4),
    .vc-problem__stats--cards .vc-problem__stat:nth-child(5) { grid-column: 1 / -1; border: 1px solid var(--gray); }
}

@media (prefers-reduced-motion: reduce) {
    .vc-problem__stats--cards .vc-problem__stat {
        opacity: 1;
        transform: none;
        transition: none;
    }
    .vc-problem__stats--cards .vc-problem__stat::before { display: none; }
}

/* ─── OFFERS ──────────────────────────────────── */
.vc-offers__proof {
    display: inline-flex; align-items: center; gap: 8px;
    margin-bottom: 16px;
}
.vc-offers__proof-stars {
    display: inline-flex; align-items: center; gap: 2px; color: var(--navy);
}
.vc-offers__proof-text {
    font-size: .875rem; color: var(--text-muted);
}
.vc-offers__proof-text strong { color: var(--navy); font-weight: 700; }

.vc-offers {
    padding: var(--py) 0;
    background: transparent;
}
.vc-offers .vc-head .vc-sub { max-width: 880px; }

.vc-offers__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: auto; /* rangées auto pour subgrid */
    gap: 32px;
    align-items: stretch;
    padding-top: 44px; /* espace pour que la carte centrale dépasse */
}

/* Variante 2 cartes — pas de carte featured qui dépasse */
.vc-offers__grid--two {
    grid-template-columns: repeat(2, 1fr);
    padding-top: 0;
}
.vc-offers__grid--two .vc-offer-card {
    padding: 44px 40px;
}

/* Carte mise en avant — surélevée pour effet de grandeur, contenu en flex pour casser le subgrid (le contenu se stacke depuis le haut, sans subir les blancs imposés par les rangées des cartes voisines) */
.vc-offer-card--highlighted {
    margin-top: -44px;
    z-index: 2;
    box-shadow: 0 24px 60px -12px rgba(0,12,102,.22), 0 8px 20px -6px rgba(0,12,102,.12);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    grid-row: span 7;
}
/* Bouton navy de la carte highlighted — garde la couleur d'origine au hover, juste le zoom */
.vc-offer-card--highlighted .vc-btn--primary:hover {
    background: var(--navy);
}

.vc-offers__cta-full {
    display: flex; align-items: center; justify-content: center; gap: 12px;
    margin-top: 32px;
    width: 100%;
    padding: 24px 32px;
    border: 1.5px solid var(--navy); border-radius: 14px;
    background: #fff;
    font-family: var(--font); font-size: 1rem; font-weight: 600;
    color: var(--navy); text-decoration: none;
    text-align: center;
    transition: background .2s, color .2s, box-shadow .2s, transform .2s;
}
.vc-offers__cta-full:hover {
    background: var(--navy); color: #fff;
    box-shadow: var(--shadow-navy);
    transform: translateY(-2px);
}
.vc-offers__cta-full .vc-btn__arr { transition: transform .2s; }
.vc-offers__cta-full:hover .vc-btn__arr { transform: translateX(4px); }

.vc-offers .vc-wrap {
    max-width: var(--max-w);
}

.vc-offer-card {
    border: 1px solid var(--gray);
    border-radius: var(--r-md);
    padding: 32px;
    background: var(--white);
    box-shadow: var(--shadow-md);
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 7; /* icon, title, desc, price, btn, urgency, list */
    position: relative; overflow: hidden;
    row-gap: 0;
    align-content: start;
    isolation: isolate;
}

/* Icône halo jaune */
.vc-offer-card__icon {
    width: 68px; height: 68px; border-radius: 50%;
    background: radial-gradient(circle at center, #f8ff7d 0%, rgba(248,255,125,.6) 25%, rgba(248,255,125,.2) 50%, rgba(248,255,125,0) 70%);
    color: var(--navy);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 18px; flex-shrink: 0;
}

/* Titre */
.vc-offer-card__title {
    font-size: 1.375rem; font-weight: 600;
    color: var(--navy); margin-bottom: 12px;
    line-height: 1.2; letter-spacing: -0.025em;
}

/* Description */
.vc-offer-card__desc {
    font-size: .9375rem; color: var(--text-muted);
    line-height: 1.7; margin-bottom: 24px;
}

/* Prix */
.vc-offer-card__price {
    margin-top: 0;
    margin-bottom: 20px;
    display: flex; align-items: baseline; gap: 7px; flex-wrap: wrap;
}
/* "À partir de" — même typo que "Tarif sur mesure" */
.vc-offer-card__price-label {
    font-size: .9375rem; color: var(--text-muted); font-weight: 500;
}
/* "700 €" — même typo que les titres de prix de référence */
.vc-offer-card__price-amount {
    font-size: 2.25rem; font-weight: 800;
    color: var(--navy); line-height: 1; letter-spacing: -0.03em;
}
/* "Tarif sur mesure" — légèrement gras pour être lisible */
.vc-offer-card__price-custom {
    font-size: .9375rem; color: var(--text-muted); font-weight: 500;
}

/* CTAs pleine largeur, centrés — comme le site de référence */
.vc-offer-card .vc-btn {
    width: 100%;
    justify-content: center;
    text-align: center;
    padding: 15px 24px;
    font-size: 1rem;
}

/* Bouton outline pour cartes latérales */
.vc-offer-card .vc-btn--soft {
    background: transparent;
    border: 1.5px solid var(--navy);
    color: var(--navy);
    font-weight: 600;
}
.vc-offer-card .vc-btn--soft:hover {
    background: var(--navy); color: #fff;
    transform: none; box-shadow: none;
}

/* Bouton central — pas de changement de couleur au hover */
.vc-btn--primary.vc-btn--featured-cta:hover {
    background: var(--navy);
    box-shadow: none;
    transform: none;
}

/* Urgence — centrée, sous le CTA */
.vc-offer-card__urgency {
    display: flex; align-items: center; justify-content: center; gap: 7px;
    font-size: .75rem; color: var(--text-muted);
    margin-top: 12px; margin-bottom: 32px;
}
.vc-offer-card__urgency-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #ef4444; flex-shrink: 0;
    animation: vc-urgency-blink 1.6s ease-in-out infinite;
}
@keyframes vc-urgency-blink {
    0%, 100% { opacity: 1; box-shadow: 0 0 0 2px rgba(239,68,68,.2); }
    50%       { opacity: .4; box-shadow: 0 0 0 5px rgba(239,68,68,0); }
}

/* Liste de features — coches bleues simples */
.vc-offer-card__list {
    list-style: none; display: flex; flex-direction: column;
    gap: 16px; margin: 0;
}
.vc-offer-card__list li {
    display: flex; align-items: flex-start; gap: 12px;
    font-size: .9375rem; color: var(--text-muted); line-height: 1.5;
}
.vc-offer-card__list li::before {
    content: ''; display: block; flex-shrink: 0;
    width: 15px; height: 15px; margin-top: 2px;
    background: url("data:image/svg+xml,%3Csvg width='15' height='15' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2.5 7.5l4 4 6-8' stroke='%23000c66' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;
}

/* ─── DASHBOARD MOCKUP CLEAN ──────────────────── */
.vc-dash2 {
    padding: var(--py) 0 0;
    background: transparent;
}
.vc-dash2 .vc-head { margin-bottom: clamp(32px,4vw,56px); }
.vc-dash2 .vc-sub { max-width: none; text-align: center; font-size: 1.0625rem; white-space: nowrap; }

/* Conteneur style Lemrock */
.vc-dash2__scene {
    background: linear-gradient(155deg, #f1f3f8 0%, #e8ecf5 100%);
    border-radius: 28px;
    padding: 48px 48px 0;
    overflow: hidden;
    display: flex; justify-content: center; align-items: flex-start;
}
.vc-dash2__window {
    width: 90%;
    background: #fff;
    border-radius: 14px 14px 0 0;
    box-shadow: 0 32px 100px rgba(0,0,0,.18), 0 4px 16px rgba(0,0,0,.08);
    overflow: hidden;
    border: 1px solid #dde1ea;
    border-bottom: none;
    /* Gauche vers spectateur — orientation Lemrock */
    transform: perspective(2000px) rotateX(10deg) rotateY(-14deg) rotateZ(3deg);
    transform-origin: 50% bottom;
}
/* Chrome */
.vc-dash2__chrome {
    display: flex; align-items: center; gap: 6px;
    padding: 9px 14px;
    background: #f2f2f2;
    border-bottom: 1px solid #e0e0e0;
}
.vc-dash2__dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.vc-dash2__urlbar {
    margin-left: 8px;
    background: #e6e6e6; border-radius: 5px;
    font-size: 10px; color: #999; padding: 3px 10px;
    max-width: 220px;
}
/* App */
.vc-dash2__app { display: flex; height: 520px; }

/* Sidebar grise */
.vc-dash2__sidebar {
    width: 155px; flex-shrink: 0;
    background: #f7f8fa;
    border-right: 1px solid #e8eaef;
    padding: 14px 10px;
    display: flex; flex-direction: column; gap: 14px;
    overflow: hidden;
}
.vc-dash2__brand { padding: 2px 4px 8px; border-bottom: 1px solid #ebebeb; }
.vc-dash2__nav-group { display: flex; flex-direction: column; gap: 1px; }
.vc-dash2__nav-label {
    font-size: 8px; font-weight: 700; color: #bec3cc;
    letter-spacing: .07em; padding: 0 7px; margin-bottom: 2px;
}
.vc-dash2__nav-item {
    display: flex; align-items: center; gap: 6px;
    font-size: 10px; font-weight: 500; color: #6b7280;
    padding: 5px 7px; border-radius: 6px; cursor: pointer;
}
.vc-dash2__nav-item--active {
    background: #fff; color: #0a0a0a; font-weight: 600;
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.vc-dash2__nav-item svg { flex-shrink: 0; color: #b0b7c3; }
.vc-dash2__nav-item--active svg { color: #000c66; }

/* Main blanc */
.vc-dash2__main {
    flex: 1; overflow: hidden;
    background: #fff;
    padding: 14px 16px;
    display: flex; flex-direction: column; gap: 10px;
}
/* Topbar */
.vc-dash2__topbar {
    display: flex; align-items: center; justify-content: space-between;
    padding-bottom: 10px; border-bottom: 1px solid #efefef;
}
.vc-dash2__page-title { font-size: 12px; font-weight: 700; color: #0a0a0a; }
.vc-dash2__period-btn {
    font-size: 10px; color: #6b7280; background: #fff;
    border: 1px solid #e5e7eb; border-radius: 6px; padding: 4px 10px; cursor: pointer;
}
/* KPIs */
.vc-dash2__kpis {
    display: grid; grid-template-columns: repeat(5,1fr); gap: 8px;
}
.vc-dash2__kpi {
    background: #fff; border-radius: 9px; padding: 10px 12px;
    border: 1px solid #efefef;
}
.vc-dash2__kpi-label { font-size: 9px; color: #9ca3af; margin-bottom: 3px; }
.vc-dash2__kpi-val { font-size: 13px; font-weight: 700; color: #0a0a0a; line-height: 1.2; }
.vc-dash2__kpi-trend { font-size: 9px; margin-top: 2px; color: #9ca3af; }
.vc-dash2__kpi-trend--up { color: #16a34a; }

/* Section title */
.vc-dash2__section-title {
    font-size: 10px; font-weight: 700; color: #374151;
}
/* Table */
.vc-dash2__table { display: flex; flex-direction: column; }
.vc-dash2__table-head {
    display: grid; grid-template-columns: 1.2fr 2fr 0.7fr 0.9fr 1fr;
    font-size: 9px; font-weight: 600; color: #9ca3af;
    padding: 5px 8px;
    background: #f8f9fb; border-radius: 6px;
}
.vc-dash2__table-row {
    display: grid; grid-template-columns: 1.2fr 2fr 0.7fr 0.9fr 1fr;
    font-size: 9.5px; color: #374151;
    padding: 6px 8px;
    border-bottom: 1px solid #f3f4f6;
    align-items: center;
}
/* Badges statut */
.vc-dash2__badge {
    display: inline-flex; align-items: center;
    font-size: 8.5px; font-weight: 600;
    padding: 2px 7px; border-radius: 99px;
}
.vc-dash2__badge--ok   { background: #dcfce7; color: #16a34a; }
.vc-dash2__badge--warn { background: #fef9c3; color: #a16207; }
.vc-dash2__badge--new  { background: #dbeafe; color: #1d4ed8; }
.vc-dash2__badge--gray { background: #f3f4f6; color: #6b7280; }

/* Charts row */
.vc-dash2__charts {
    display: grid; grid-template-columns: 1fr 148px; gap: 8px;
    flex: 1; min-height: 0;
}
.vc-dash2__card {
    background: #fff; border-radius: 9px; padding: 10px 12px;
    border: 1px solid #f0f1f4;
    display: flex; flex-direction: column; gap: 4px;
    overflow: hidden;
}
.vc-dash2__card--sm { justify-content: center; }
.vc-dash2__card-header {
    display: flex; align-items: center; justify-content: space-between; gap: 6px;
}
.vc-dash2__card-title { font-size: 9px; font-weight: 600; color: #374151; }
.vc-dash2__badge-green {
    font-size: 8.5px; font-weight: 600; color: #16a34a;
    background: #dcfce7; padding: 1px 6px; border-radius: 99px;
}
.vc-dash2__bigval { font-size: 18px; font-weight: 700; color: #0a0a0a; line-height: 1; }
.vc-dash2__area { width: 100%; height: 56px; flex-shrink: 0; }
.vc-dash2__chart-legend {
    display: flex; gap: 12px;
}
.vc-dash2__chart-legend span {
    display: flex; align-items: center; gap: 4px;
    font-size: 8.5px; color: #6b7280;
}
.vc-dash2__chart-legend i {
    display: inline-block; width: 8px; height: 3px; border-radius: 99px;
}
/* Donut */
.vc-dash2__donut-wrap {
    display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.vc-dash2__donut { width: 88px; height: 88px; }
.vc-dash2__donut-legend {
    display: flex; flex-direction: column; gap: 3px; width: 100%;
}
.vc-dash2__donut-legend div {
    display: flex; align-items: center; gap: 5px;
    font-size: 8.5px; color: #555;
}
.vc-dash2__donut-legend span {
    width: 7px; height: 7px; border-radius: 2px; flex-shrink: 0;
}

/* ─── DASHBOARD DEMO ─────────────────────────── */
.vc-erp-demo {
    padding: var(--py) 0;
    background: var(--gray-light);
    overflow: hidden;
}
.vc-erp-demo .vc-label { color: var(--navy); opacity: .55; }
.vc-erp-demo .vc-h2   { color: var(--navy); }
.vc-erp-demo .vc-sub  { color: var(--text); max-width: 440px; margin-bottom: 24px; }

.vc-erp-demo__inner {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: clamp(40px, 6vw, 80px); align-items: center;
}
.vc-erp-demo__list {
    list-style: none; margin-bottom: 32px;
    display: flex; flex-direction: column; gap: 12px;
}
.vc-erp-demo__list li {
    font-size: .9rem; color: var(--text);
    padding-left: 20px; position: relative; line-height: 1.5;
}
.vc-erp-demo__list li::before {
    content: ''; position: absolute; left: 0; top: 7px;
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--navy);
}

/* ── Device wrapper ── */
.vc-erp-demo__device {
    position: relative;
    width: 100%; max-width: 520px;
    aspect-ratio: 16/10;
    perspective: 1200px;
    margin: 0 auto;
}

/* 3D scene — the rotating container that holds all layers */
.vc-erp-device__scene {
    position: absolute; inset: 0;
    transform-style: preserve-3d;
    /* Default: held at starting angle, invisible */
    transform: rotateX(-22deg) rotateY(28deg);
}

/* Laptop layers — default: invisible, at rest position */
.vc-erp-device__lid,
.vc-erp-device__bezel,
.vc-erp-device__screen {
    position: absolute; inset: 0;
    border-radius: 12px;
    opacity: 0;
}
.vc-erp-device__lid {
    background: linear-gradient(160deg, #dde0e6 0%, #c8ccd4 100%);
    border: 1px solid rgba(0,0,0,.1);
    box-shadow: 0 40px 80px rgba(0,12,102,.18), inset 0 1px 0 rgba(255,255,255,.85);
}
.vc-erp-device__base {
    position: absolute; bottom: -18px; left: -24px; right: -24px; height: 18px;
    background: linear-gradient(180deg, #cdd0d7 0%, #b8bcc4 100%);
    border-radius: 0 0 10px 10px;
    border: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 20px 40px rgba(0,12,102,.12);
    opacity: 0;
}
.vc-erp-device__bezel {
    background: #1c1c1e;
    border: 1px solid rgba(0,0,0,.2);
    box-shadow: inset 0 0 0 2px rgba(0,0,0,.06);
}
.vc-erp-device__screen {
    inset: 10px;
    border-radius: 5px; overflow: hidden;
}
.vc-erp-device__screen-black {
    position: absolute; inset: 0; background: #000; z-index: 2;
    /* stays opaque until wake animation runs */
}
.vc-erp-device__shimmer {
    position: absolute; inset: 0; z-index: 4; pointer-events: none;
    background: linear-gradient(115deg, transparent 40%, rgba(255,255,255,.5) 50%, transparent 60%);
    transform: translateX(-120%);
}
.vc-erp-device__ui { position: absolute; inset: 0; z-index: 1; display: flex; flex-direction: column; }

/* ── Animations — fire only when .is-visible is added by IntersectionObserver ── */
.vc-erp-demo__device.is-visible .vc-erp-device__scene {
    animation: erp-scene-rotate 1.4s cubic-bezier(.16,1,.3,1) forwards;
}
.vc-erp-demo__device.is-visible .vc-erp-device__lid {
    animation: erp-lid-assemble 1.4s cubic-bezier(.16,1,.3,1) forwards;
}
.vc-erp-demo__device.is-visible .vc-erp-device__base {
    animation: erp-base-assemble 1.4s cubic-bezier(.16,1,.3,1) .05s forwards;
}
.vc-erp-demo__device.is-visible .vc-erp-device__bezel {
    animation: erp-bezel-assemble 1.4s cubic-bezier(.16,1,.3,1) .1s forwards;
}
.vc-erp-demo__device.is-visible .vc-erp-device__screen {
    animation: erp-screen-assemble 1.4s cubic-bezier(.16,1,.3,1) .15s forwards;
}
.vc-erp-demo__device.is-visible .vc-erp-device__screen-black {
    animation: erp-wake 0.55s ease-out 1.15s forwards;
}
.vc-erp-demo__device.is-visible .vc-erp-device__shimmer {
    animation: erp-shimmer-sweep 0.75s ease-out 1.3s forwards;
}

/* Assembly keyframes — faithful to Remotion spring (mass:1.4 damping:12 stiffness:90) */
@keyframes erp-scene-rotate {
    0%   { transform: rotateX(-22deg) rotateY(28deg); }
    100% { transform: rotateX(0deg)   rotateY(0deg); }
}
@keyframes erp-lid-assemble {
    0%   { transform: translateZ(900px); opacity: 0; }
    20%  { opacity: 1; }
    100% { transform: translateZ(0);     opacity: 1; }
}
@keyframes erp-base-assemble {
    0%   { transform: translateZ(-700px) translateY(24px); opacity: 0; }
    25%  { opacity: 1; }
    100% { transform: translateZ(0)      translateY(0);    opacity: 1; }
}
@keyframes erp-bezel-assemble {
    0%   { transform: translateZ(500px) scale(.94); opacity: 0; }
    20%  { opacity: 1; }
    100% { transform: translateZ(0)     scale(1);   opacity: 1; }
}
@keyframes erp-screen-assemble {
    0%   { transform: translateZ(280px) scale(.97); opacity: 0; }
    20%  { opacity: 1; }
    100% { transform: translateZ(0)     scale(1);   opacity: 1; }
}
@keyframes erp-wake {
    0%   { opacity: 1; }
    100% { opacity: 0; pointer-events: none; }
}
@keyframes erp-shimmer-sweep {
    0%   { transform: translateX(-120%); }
    100% { transform: translateX(240%);  }
}

/* ── Dashboard UI (light theme) ── */
.vc-erp-ui__titlebar {
    display: flex; align-items: center; gap: 5px;
    height: 26px; background: #f0f1f3;
    border-bottom: 1px solid rgba(0,0,0,.09);
    padding: 0 10px; flex-shrink: 0;
    font-size: 10px; color: rgba(0,0,0,.4);
}
.vc-erp-ui__dot {
    width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.vc-erp-ui__dot:nth-child(1) { background: #ff5f57; }
.vc-erp-ui__dot:nth-child(2) { background: #ffbd2e; }
.vc-erp-ui__dot:nth-child(3) { background: #28c840; }
.vc-erp-ui__titlebar-name { margin-left: 8px; font-weight: 600; color: rgba(0,0,0,.5); }

.vc-erp-ui__body {
    display: flex; flex: 1; min-height: 0;
    background: #fff;
}

/* Sidebar */
.vc-erp-ui__sidebar {
    width: 120px; flex-shrink: 0;
    background: #f7f8fa;
    border-right: 1px solid rgba(0,0,0,.06);
    padding: 12px 8px;
    display: flex; flex-direction: column; gap: 12px;
}
.vc-erp-ui__logo-img {
    width: 68px; height: auto; display: block;
    margin-bottom: 4px;
}
.vc-erp-ui__nav { display: flex; flex-direction: column; gap: 2px; }
.vc-erp-ui__nav-item {
    display: flex; align-items: center; gap: 6px;
    font-size: 9.5px; color: rgba(0,0,0,.4);
    padding: 5px 7px; border-radius: 6px;
    cursor: default;
}
.vc-erp-ui__nav-item--active {
    background: rgba(0,12,102,.07);
    color: var(--navy);
    font-weight: 700;
}
.vc-erp-ui__nav-item svg { flex-shrink: 0; }

/* Main */
.vc-erp-ui__main {
    flex: 1; padding: 12px 14px;
    display: flex; flex-direction: column; gap: 10px;
    overflow: hidden; background: #fff;
}
.vc-erp-ui__main-header {
    display: flex; align-items: center; justify-content: space-between;
}
.vc-erp-ui__main-title { font-size: 11.5px; font-weight: 700; color: var(--navy); }
.vc-erp-ui__badge {
    font-size: 8.5px; font-weight: 700;
    background: linear-gradient(135deg, rgba(248,255,100,.55), rgba(248,255,100,.25));
    color: #5a4a00; border: 1px solid rgba(248,255,100,.7);
    padding: 2px 8px; border-radius: 20px;
}

/* KPIs */
.vc-erp-ui__kpis { display: grid; grid-template-columns: repeat(3,1fr); gap: 7px; }
.vc-erp-ui__kpi {
    background: #f9fafb;
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 7px; padding: 9px 10px;
}
.vc-erp-ui__kpi--accent {
    background: linear-gradient(135deg, rgba(248,255,100,.3) 0%, rgba(248,255,100,.1) 100%);
    border-color: rgba(248,255,100,.55);
}
.vc-erp-ui__kpi-val {
    font-size: 15px; font-weight: 800; color: var(--navy); line-height: 1;
    margin-bottom: 3px;
}
.vc-erp-ui__kpi-label { font-size: 8.5px; color: rgba(0,0,0,.38); }

/* Table */
.vc-erp-ui__table { flex: 1; overflow: hidden; }
.vc-erp-ui__table-head {
    display: grid; grid-template-columns: 1.4fr 1.4fr .8fr .8fr;
    font-size: 7.5px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .07em; color: rgba(0,0,0,.3);
    padding: 0 8px 5px; border-bottom: 1px solid rgba(0,0,0,.07);
}
.vc-erp-ui__table-row {
    display: grid; grid-template-columns: 1.4fr 1.4fr .8fr .8fr;
    align-items: center;
    font-size: 9px; color: rgba(0,0,0,.62);
    padding: 6px 8px;
    border-bottom: 1px solid rgba(0,0,0,.04);
}
.vc-erp-ui__status {
    font-size: 8px; font-weight: 700; padding: 2px 6px;
    border-radius: 20px; display: inline-block;
}
.vc-erp-ui__status--ok   { background: rgba(34,197,94,.1); color: #15803d; }
.vc-erp-ui__status--warn { background: rgba(234,179,8,.12); color: #854d0e; }
.vc-erp-ui__status--new  { background: rgba(0,12,102,.07); color: var(--navy); }

/* Responsive */
@media (max-width: 1024px) {
    .vc-erp-demo__inner { grid-template-columns: 1fr; }
    .vc-erp-demo__device { max-width: 100%; }
}

/* ─── DASHBOARD CTA ───────────────────────────── */
.vc-dash2-cta {
    padding: clamp(32px, 4vw, 56px) 0 clamp(48px, 7vw, 96px);
}
.vc-dash2-cta .vc-sub {
    max-width: 740px;
}
.vc-dash2-cta__btn {
    border-radius: var(--r-full) !important;
    margin-top: 16px;
    padding: 20px 40px !important;
    font-size: 1.0625rem !important;
}
.vc-dash2-cta__btn:hover {
    background: var(--navy) !important;
    transform: scale(1.03) !important;
    box-shadow: none !important;
}

/* ─── RESULTS — TABS ──────────────────────────── */
.vc-results {
    padding: var(--py) 0;
    background: transparent;
}
.vc-results__copy {
    text-align: center; max-width: 600px; margin: 0 auto 32px;
}
.vc-results__copy .vc-label { margin-bottom: 8px; }
.vc-results__copy .vc-sub   { margin: 0 auto; }

/* Stats grid — bento asymétrique : la 1ʳᵉ stat (la plus parlante) occupe
   toute la colonne gauche, les 2 autres sont empilées à droite. */
.vc-results__stats {
    display: grid;
    grid-template-columns: 1.45fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: clamp(14px, 1.6vw, 20px);
    margin: clamp(40px, 6vw, 64px) 0 clamp(32px, 4vw, 48px);
    max-width: 1080px;
    margin-left: auto;
    margin-right: auto;
}
.vc-results__stat {
    padding: clamp(28px, 3vw, 40px) clamp(24px, 2.5vw, 36px);
    display: flex; flex-direction: column;
    justify-content: center;
    gap: 10px;
    text-align: left;
    background: #fff;
    border: 1px solid var(--gray);
    border-radius: var(--r-lg);
    opacity: 0;
    transform: translateY(24px);
    transition:
        opacity .7s ease-out,
        transform .7s cubic-bezier(.2,.7,.3,1),
        border-color .25s ease,
        box-shadow .25s ease;
    position: relative;
    overflow: hidden;
}
/* Carte featured : occupe la colonne de gauche, padding plus généreux.
   Tous les chiffres gardent la même taille (cohérence visuelle), le halo
   jaune en fond est retiré pour ne pas donner d'effet flou à la 1re case. */
.vc-results__stat--featured {
    grid-row: 1 / span 2;
    background: #fff;
    padding: clamp(32px, 3.5vw, 56px);
    gap: 14px;
}
.vc-results__stat--featured .vc-results__stat-label {
    font-size: 1.125rem;
}
.vc-results__stat--featured .vc-results__stat-desc {
    font-size: 1rem;
    max-width: 32ch;
}
/* Hover : pattern Velaco standard (translateY + shadow navy + bordure navy) */
.vc-results__stat:hover {
    border-color: var(--navy);
    box-shadow: var(--shadow-navy);
    transform: translateY(-2px);
}
.vc-results.is-visible .vc-results__stat              { opacity: 1; transform: translateY(0); }
.vc-results.is-visible .vc-results__stat:hover        { transform: translateY(-2px); }
.vc-results.is-visible .vc-results__stat:nth-child(2) { transition-delay: .15s; }
.vc-results.is-visible .vc-results__stat:nth-child(3) { transition-delay: .30s; }
.vc-results__stat-num {
    font-size: clamp(2.25rem, 3.8vw, 3rem);
    font-weight: 600; color: var(--navy);
    line-height: 1; letter-spacing: -0.03em;
    font-variant-numeric: tabular-nums;
}
@media (prefers-reduced-motion: reduce) {
    .vc-results__stat { opacity: 1; transform: none; transition: none; }
}
.vc-results__stat-label {
    font-size: 1rem; font-weight: 600;
    color: var(--navy);
    line-height: 1.3;
}
.vc-results__stat-desc {
    font-size: .9375rem; color: var(--text-muted); line-height: 1.65;
    margin: 0;
}
.vc-results__cta .vc-btn {
    border-radius: var(--r-full);
}
.vc-results__cta .vc-btn--primary:hover {
    background: var(--navy);
}
.vc-results__cta {
    display: flex; justify-content: center;
}

/* ─── PROCESS ─────────────────────────────────── */
.vc-process {
    padding: var(--py) 0;
    background: transparent;
}


.vc-process__steps {
    display: grid; grid-template-columns: repeat(4,1fr);
    gap: 20px; margin-top: clamp(40px,5vw,56px);
    position: relative;
}
.vc-process__step { text-align: center; padding: 0 4px; position: relative; }

/* Halo radial jaune derrière chaque cercle */
.vc-process__step::before {
    content: ''; position: absolute;
    width: 100px; height: 100px;
    top: 26px; left: 50%;
    transform: translate(-50%, -50%) scale(.4);
    background: radial-gradient(circle, rgba(248,255,100,.6) 0%, transparent 68%);
    border-radius: 50%;
    opacity: 0;
    z-index: 1; pointer-events: none;
}

/* Sequential zoom-in animation when section enters viewport */
.vc-process__steps.is-animated .vc-process__step::before {
    animation: vc-halo-pop .9s cubic-bezier(.22,1,.36,1) forwards;
}
.vc-process__steps.is-animated .vc-process__step .vc-process__step-num,
.vc-process__steps.is-animated .vc-process__step .vc-process__step-title,
.vc-process__steps.is-animated .vc-process__step .vc-process__step-text {
    animation: vc-step-pop .9s cubic-bezier(.22,1,.36,1) forwards;
}
.vc-process__step .vc-process__step-num,
.vc-process__step .vc-process__step-title,
.vc-process__step .vc-process__step-text {
    opacity: 0;
}
.vc-process__steps.is-animated .vc-process__step:nth-child(1) ::before,
.vc-process__steps.is-animated .vc-process__step:nth-child(1) .vc-process__step-num,
.vc-process__steps.is-animated .vc-process__step:nth-child(1) .vc-process__step-title,
.vc-process__steps.is-animated .vc-process__step:nth-child(1) .vc-process__step-text { animation-delay: 0s; }
.vc-process__steps.is-animated .vc-process__step:nth-child(1)::before { animation-delay: 0s; }
.vc-process__steps.is-animated .vc-process__step:nth-child(2)::before,
.vc-process__steps.is-animated .vc-process__step:nth-child(2) .vc-process__step-num,
.vc-process__steps.is-animated .vc-process__step:nth-child(2) .vc-process__step-title,
.vc-process__steps.is-animated .vc-process__step:nth-child(2) .vc-process__step-text { animation-delay: .45s; }
.vc-process__steps.is-animated .vc-process__step:nth-child(3)::before,
.vc-process__steps.is-animated .vc-process__step:nth-child(3) .vc-process__step-num,
.vc-process__steps.is-animated .vc-process__step:nth-child(3) .vc-process__step-title,
.vc-process__steps.is-animated .vc-process__step:nth-child(3) .vc-process__step-text { animation-delay: .9s; }
.vc-process__steps.is-animated .vc-process__step:nth-child(4)::before,
.vc-process__steps.is-animated .vc-process__step:nth-child(4) .vc-process__step-num,
.vc-process__steps.is-animated .vc-process__step:nth-child(4) .vc-process__step-title,
.vc-process__steps.is-animated .vc-process__step:nth-child(4) .vc-process__step-text { animation-delay: 1.35s; }

@keyframes vc-halo-pop {
    0%   { opacity: 0; transform: translate(-50%, -50%) scale(.4); }
    55%  { opacity: 1; transform: translate(-50%, -50%) scale(1.15); }
    100% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}
@keyframes vc-step-pop {
    0%   { opacity: 0; transform: scale(.6); }
    55%  { opacity: 1; transform: scale(1.12); }
    100% { opacity: 1; transform: scale(1); }
}

@media (prefers-reduced-motion: reduce) {
    .vc-process__step::before { opacity: 1; transform: translate(-50%, -50%) scale(1); }
    .vc-process__step .vc-process__step-num,
    .vc-process__step .vc-process__step-title,
    .vc-process__step .vc-process__step-text { opacity: 1; }
    .vc-process__steps.is-animated .vc-process__step::before,
    .vc-process__steps.is-animated .vc-process__step .vc-process__step-num,
    .vc-process__steps.is-animated .vc-process__step .vc-process__step-title,
    .vc-process__steps.is-animated .vc-process__step .vc-process__step-text { animation: none; }
}

/* Segmented connector — stops before/after each halo */
.vc-process__step:not(:last-child)::after {
    content: ''; position: absolute;
    top: 26px;
    left: calc(50% + 32px);
    width: calc(100% - 44px);
    height: 2px; background: var(--gray); z-index: 0;
}

.vc-process__step-num {
    width: 52px; height: 52px;
    border-radius: 50%;
    background: transparent;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; font-weight: 800; color: var(--navy);
    margin: 0 auto 20px; position: relative; z-index: 2;
}
.vc-process__step-title {
    font-size: 1.0625rem; font-weight: 600; color: var(--navy); margin-bottom: 8px; letter-spacing: -0.015em;
}
.vc-process__step-text {
    font-size: .875rem; color: var(--text-muted); line-height: 1.6;
}

/* ─── WHY ─────────────────────────────────────── */
.vc-why {
    padding: var(--py) 0;
    background: transparent;
}
.vc-why__grid {
    display: grid; grid-template-columns: repeat(2,1fr);
    gap: 16px; margin-top: clamp(40px,5vw,56px);
}
.vc-why__card {
    background: var(--white);
    border: 1.5px solid var(--gray);
    border-radius: var(--r-lg);
    padding: 28px 24px;
    display: flex; gap: 18px; align-items: flex-start;
}
.vc-why__card-icon {
    width: 52px; height: 52px; flex-shrink: 0;
    background: radial-gradient(circle at center, #f8ff7d 0%, rgba(248,255,125,.6) 25%, rgba(248,255,125,.2) 50%, transparent 70%);
    color: var(--navy);
    display: flex; align-items: center; justify-content: center;
}
.vc-why__card-title {
    font-size: 1rem; font-weight: 600; color: var(--navy); margin-bottom: 5px; letter-spacing: -0.015em;
}
.vc-why__card-text {
    font-size: .875rem; color: var(--text-muted); line-height: 1.65;
}
.vc-why__closing {
    text-align: center;
    margin: clamp(40px, 5vw, 64px) auto 0;
    max-width: 720px;
    font-size: 1rem;
    font-weight: 400;
    color: var(--text-muted);
    line-height: 1.55;
    text-wrap: balance;
}

/* ─── TESTIMONIALS ────────────────────────────── */
.vc-testimonials {
    padding: var(--py) 0;
    background: transparent;
}

/* Conteneur des 3 colonnes avec masque gradient haut/bas */
.vc-testimonials__cols {
    display: flex;
    gap: 24px;
    max-height: 740px;
    overflow: hidden;
    -webkit-mask-image: linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
    mask-image: linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
    margin-top: 48px;
}

/* Chaque colonne */
.vc-testimonials__col {
    flex: 1;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.vc-testimonials__col:nth-child(2) { display: none; }
.vc-testimonials__col:nth-child(3) { display: none; }

@media (min-width: 768px) {
    .vc-testimonials__col:nth-child(2) { display: flex; }
}
@media (min-width: 1024px) {
    .vc-testimonials__col:nth-child(3) { display: flex; }
}

/* Track animé — contient 2× les cartes pour le loop infini */
@keyframes vc-scroll-up {
    from { transform: translateY(0); }
    to   { transform: translateY(-50%); }
}

.vc-testimonials__track {
    display: flex;
    flex-direction: column;
    gap: 24px;
    animation: vc-scroll-up var(--dur, 15s) linear infinite;
    padding-bottom: 24px; /* espace final pour que le loop soit imperceptible */
}

/* Carte individuelle */
.vc-testimonial {
    background: var(--white);
    border: 1.5px solid #e2e8f0;
    border-radius: var(--r-lg);
    padding: 28px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    box-shadow: 0 4px 24px rgba(0,12,102,.05);
    flex-shrink: 0;
}

.vc-testimonial__stars {
    display: flex;
    gap: 3px;
    color: var(--navy);
}

.vc-sub--nowrap { max-width: none; white-space: nowrap; }

.vc-testimonial__author {
    display: flex; align-items: center; gap: 11px;
    margin-top: auto;
}
.vc-testimonial__avatar-img {
    width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
    object-fit: cover;
}
.vc-testimonial__name  { font-size: .875rem; font-weight: 700; color: var(--navy); }
.vc-testimonial__role  { font-size: .8125rem; color: var(--text-muted); }

.vc-testimonial__text {
    font-size: .9rem; color: var(--text-muted);
    line-height: 1.65;
    font-style: italic;
    margin: 0;
}

/* ─── FAQ ─────────────────────────────────────── */
.vc-faq {
    padding: var(--py) 0;
    background: transparent;
}
.vc-faq__head { margin-bottom: clamp(32px, 4vw, 56px); text-align: center; }
.vc-faq__head .vc-h2 { margin-bottom: 12px; }
.vc-faq__head .vc-sub { max-width: 640px; margin: 0 auto; }

.vc-faq__list {
    display: flex;
    flex-direction: column;
    gap: 14px;
    max-width: 820px;
    margin: 0 auto;
}

.vc-faq__item {
    background: var(--white);
    border: 1px solid var(--gray);
    border-radius: var(--r-md);
    box-shadow: var(--shadow-sm);
    transition: border-color .25s ease, box-shadow .25s ease, background-color .25s ease, transform .25s ease;
}
.vc-faq__item:hover {
    border-color: var(--navy);
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
}
.vc-faq__item.open {
    background: var(--gray-light);
    border-color: var(--navy);
    box-shadow: var(--shadow-navy);
    transform: translateY(0);
}

.vc-faq__q {
    width: 100%; background: none; border: none; text-align: left;
    padding: 22px 26px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 18px; cursor: pointer;
    font-family: var(--font); font-size: 1rem; font-weight: 600;
    color: var(--text); line-height: 1.45;
    border-radius: var(--r-md);
}
.vc-faq__q-text { flex: 1; }

.vc-faq__chevron {
    flex-shrink: 0;
    color: var(--text-muted);
    transition: transform .25s ease, color .2s ease;
}
.vc-faq__item.open .vc-faq__chevron {
    transform: rotate(180deg);
    color: var(--navy);
}

.vc-faq__a {
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s cubic-bezier(.22, 1, .36, 1);
}
.vc-faq__item.open .vc-faq__a { max-height: 500px; }
.vc-faq__a-inner {
    padding: 0 26px 22px;
    font-size: .9375rem; color: var(--text-muted); line-height: 1.7;
}

/* HR séparateurs masqués — les cards font déjà la séparation visuelle */
.vc-faq__sep { display: none; }

.vc-faq__support {
    text-align: center;
    margin: clamp(28px, 4vw, 40px) auto 0;
    color: var(--text-muted);
    font-size: .9375rem;
}
.vc-faq__support a {
    color: var(--navy);
    font-weight: 600;
    text-decoration: none;
    transition: text-decoration .15s;
}
.vc-faq__support a:hover {
    text-decoration: underline;
}

@media (max-width: 600px) {
    .vc-faq__list { gap: 10px; }
    .vc-faq__q { padding: 18px 20px; font-size: .9375rem; }
    .vc-faq__a-inner { padding: 0 20px 18px; }
}

/* ─── FINAL CTA — DARK SECTION 2/2 ───────────── */
.vc-cta-final {
    padding: var(--py) 0;
    background: transparent;
    text-align: center;
}
.vc-cta-final__inner { position: relative; }
.vc-cta-final__title {
    font-size: clamp(1.875rem, 3.5vw, 3.25rem);
    font-weight: 500; color: var(--navy);
    letter-spacing: -0.03em; margin-bottom: 14px; line-height: 1.08;
}
.vc-cta-final__sub {
    font-size: clamp(1rem, 1.5vw, 1.125rem); color: var(--text-muted);
    max-width: 560px; margin: 0 auto 36px; line-height: 1.6;
}
.vc-cta-final__actions .vc-btn {
    border-radius: 9999px;
    padding: 15px 24px 15px 28px;
}
.vc-cta-final__actions {
    display: flex; align-items: center; justify-content: center;
    gap: 12px; flex-wrap: wrap; margin-bottom: 20px;
}
.vc-cta-final__note { font-size: .8125rem; color: var(--text-muted); }

/* ─── FOOTER ──────────────────────────────────── */
.vc-footer {
    background: transparent;
    padding: 96px 0 260px;
    position: relative; overflow: hidden;
}
.vc-footer__watermark {
    position: absolute;
    bottom: 30px; left: 50%; transform: translateX(-50%);
    width: clamp(560px, 78vw, 960px); height: auto;
    opacity: 0.22;
    pointer-events: none; user-select: none;
    -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 35%, rgba(0,0,0,0.35) 75%, rgba(0,0,0,0) 100%);
            mask-image: linear-gradient(to bottom, #000 0%, #000 35%, rgba(0,0,0,0.35) 75%, rgba(0,0,0,0) 100%);
}
.vc-footer__top {
    display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr;
    gap: 40px; margin-bottom: 0;
    position: relative; z-index: 1;
}
.vc-footer__cta-block {
    padding: 0;
}
.vc-footer__logo-link {
    display: inline-block;
    text-decoration: none; margin-bottom: 20px;
}
.vc-footer__logo-full {
    height: 38px; width: auto; display: block;
}
.vc-footer__cta-title {
    font-size: 1.375rem; font-weight: 600; color: var(--navy);
    line-height: 1.3; margin-bottom: 8px; letter-spacing: -0.02em;
}
.vc-footer__cta-desc {
    font-size: .875rem; color: var(--text-muted);
    line-height: 1.65; max-width: 340px; margin-bottom: 16px;
}
.vc-footer__cta-btn {
    font-size: .875rem; padding: 12px 24px;
    margin-bottom: 20px;
    display: inline-flex;
    border-radius: 9999px;
    background: var(--navy); color: #fff;
    border: none;
    transition: transform .18s, box-shadow .18s;
}
.vc-footer__cta-btn:hover {
    background: var(--navy); color: #fff;
    transform: translateY(-2px);
    box-shadow: var(--shadow-navy);
}
.vc-footer__social { display: flex; gap: 14px; }
.vc-footer__social-link {
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--text-muted); text-decoration: none;
    transition: color .15s, transform .15s;
}
.vc-footer__social-link:hover { color: var(--navy); transform: translateY(-1px); }
.vc-footer__social-link svg { width: 26px; height: 26px; }
.vc-footer__col-title {
    font-size: .75rem; font-weight: 700; color: var(--navy);
    margin-bottom: 14px; text-transform: uppercase; letter-spacing: .07em;
}
.vc-footer__links { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.vc-footer__links a {
    font-size: .875rem; color: var(--text-muted);
    text-decoration: none; transition: color .15s;
}
.vc-footer__links a:hover { color: var(--navy); }
.vc-footer__bottom {
    display: flex; align-items: center; justify-content: center;
    flex-wrap: wrap; gap: 32px;
    position: absolute;
    bottom: 38px; left: 0; right: 0;
    padding: 0 clamp(20px, 5vw, 72px);
    margin: 0;
    z-index: 2;
    text-align: center;
}
.vc-footer__copy,
.vc-footer__address {
    font-size: .8125rem; color: var(--text-muted); margin: 0;
}
.vc-footer__legal { display: flex; gap: 32px; flex-wrap: wrap; justify-content: center; }
.vc-footer__legal a {
    font-size: .8125rem; color: var(--text-muted);
    text-decoration: none; transition: color .15s;
}
.vc-footer__legal a:hover { color: var(--navy); }
@media (max-width: 768px) {
    .vc-footer { padding-bottom: 200px; }
    .vc-footer__bottom { gap: 14px; bottom: 18px; }
    .vc-footer__legal { gap: 18px; }
}
@media (max-width: 480px) {
    .vc-footer { padding-bottom: 160px; }
    .vc-footer__bottom { bottom: 14px; }
}

/* ─── ADMIN BAR ───────────────────────────────── */
.admin-bar .vc-nav { top: 32px; }
@media (max-width: 782px) { .admin-bar .vc-nav { top: 46px; } }

/* ─── RESPONSIVE ──────────────────────────────── */
@media (max-width: 1024px) {
    .vc-offers__grid      { gap: 20px; }
    .vc-why__grid         { grid-template-columns: 1fr 1fr; }
    .vc-process__steps    { grid-template-columns: repeat(2,1fr); }
    .vc-process__steps::before { display: none; }
    .vc-process__steps::after  { display: none; }
    /* Tablette : on garde le bento mais en colonnes plus serrées. */
    .vc-results__stats    { grid-template-columns: 1.3fr 1fr; }
    .vc-footer__top       { grid-template-columns: 1fr 1fr 1fr; gap: 28px; }
    .vc-footer__cta-block { grid-column: 1 / -1; margin-bottom: 12px; }
    /* testimonials responsive géré dans le bloc principal */
}

@media (max-width: 768px) {
    .vc-nav__links,
    .vc-nav__actions > a:not(:last-child) { display: none; }
    .vc-nav__mobile-btn { display: flex; }
    .vc-nav__links.is-open {
        display: flex; flex-direction: column;
        position: fixed; top: 66px; left: 0; right: 0; bottom: 0;
        background: rgba(255,255,255,.97); backdrop-filter: blur(16px);
        padding: 32px 24px; gap: 4px; z-index: 99;
    }
    .vc-nav__links.is-open a,
    .vc-nav__links.is-open .vc-nav__dropdown-trigger {
        font-size: 1.125rem; padding: 12px 16px; border-radius: var(--r-md);
        width: 100%; justify-content: space-between;
    }
    /* Mobile dropdown : panneau qui s'ouvre vertical, plus en absolu */
    .vc-nav__links.is-open .vc-nav__item--has-dropdown { width: 100%; }
    .vc-nav__links.is-open .vc-nav__dropdown {
        position: static; transform: none;
        width: 100%; min-width: 0;
        border: none; box-shadow: none;
        padding: 0 0 0 16px; margin: 4px 0 0;
        opacity: 0; pointer-events: none;
        max-height: 0; overflow: hidden;
        transition: opacity .2s, max-height .25s ease;
    }
    .vc-nav__links.is-open .vc-nav__item--has-dropdown.is-open .vc-nav__dropdown {
        opacity: 1; pointer-events: auto; max-height: 300px;
    }
    .vc-nav__links.is-open .vc-nav__dropdown a {
        font-size: 1rem; padding: 10px 14px;
    }

    /* Hero — wrap CTA row at tablet */
    .vc-hero__h1           { font-size: clamp(1.875rem, 6vw, 2.5rem); }
    .vc-hero__cta-row      { flex-wrap: wrap; gap: 20px; }
    .vc-hero__cta-btns     { width: 100%; }
    .vc-hero__proof        { width: 100%; flex-wrap: wrap; gap: 10px;
                             border-left: none; padding-left: 0; margin-left: 0; margin-top: 0; }
    .vc-hero__proof-item   { white-space: normal; border-right: none; padding-right: 0; margin-right: 0; }

    .vc-offers__grid          { grid-template-columns: 1fr; padding-top: 0; }
    .vc-offer-card--highlighted { margin-top: 0; }
    .vc-offers__cta-full      { padding: 20px 24px; font-size: .95rem; }
    .vc-why__grid             { grid-template-columns: 1fr; }
    /* testimonials responsive géré dans le bloc principal */
    .vc-faq__grid             { grid-template-columns: 1fr; }
    .vc-footer__top           { grid-template-columns: 1fr 1fr; }
    .vc-footer__cta-block     { grid-column: 1 / -1; }
}

@media (max-width: 480px) {
    /* Hero — stack buttons vertically, reduce h1 */
    .vc-hero__h1              { font-size: 1.625rem; letter-spacing: -0.02em; }
    .vc-hero__cta-row         { flex-direction: column; align-items: stretch; }
    .vc-hero__cta-btns        { flex-direction: column; gap: 10px; }
    .vc-hero__cta-btns .vc-btn { width: 100%; justify-content: center; }
    .vc-hero__proof            { gap: 8px; }

    .vc-process__steps        { grid-template-columns: 1fr; }
    /* Footer : Offres / Ressources / Contact en grille 2 colonnes même sur mobile (≤480px) */
    .vc-footer__top           { grid-template-columns: 1fr 1fr; gap: 28px 20px; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        transition-duration: .01ms !important;
    }
}

/* ─── BOOKING WIDGET (floating bubble + popup) ─── */
.vc-booking-widget {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 9999;
    font-family: var(--font);
}

/* Bubble (always visible) */
.vc-booking__bubble {
    position: relative;
    width: 60px; height: 60px;
    border: none;
    border-radius: 50%;
    background: var(--navy);
    color: #fff;
    cursor: pointer;
    box-shadow: 0 8px 24px rgba(0,12,102,.35);
    animation: vc-booking-float 4.5s ease-in-out infinite, vc-booking-nudge 7s ease-in-out 3s infinite;
    transition: box-shadow .2s;
    overflow: hidden;
}
.vc-booking__bubble:hover {
    animation: none;
    transform: translateY(-3px) scale(1.06);
    box-shadow: 0 14px 36px rgba(0,12,102,.5);
}
.vc-booking__bubble:active {
    transform: scale(.94);
}
/* Subtle floating breath at rest */
@keyframes vc-booking-float {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-5px); }
}
/* Periodic nudge — small wobble at the end of each cycle to grab the eye */
@keyframes vc-booking-nudge {
    0%, 88%, 100% { transform: translateY(0) rotate(0); }
    91%           { transform: translateY(-3px) rotate(-6deg); }
    94%           { transform: translateY(-3px) rotate(5deg); }
    97%           { transform: translateY(-3px) rotate(-3deg); }
}
/* Disable animations when popup is open */
.vc-booking-widget.is-open .vc-booking__bubble {
    animation: none;
}

/* Bubble icons morph (calendar ↔ chevron) */
.vc-booking__bubble-icon {
    position: absolute;
    inset: 0;
    display: flex; align-items: center; justify-content: center;
    transition: opacity .28s ease, transform .35s cubic-bezier(.5,0,.3,1.3);
}
.vc-booking__bubble-icon--calendar { opacity: 1; transform: rotate(0); }
.vc-booking__bubble-icon--chevron  { opacity: 0; transform: rotate(-90deg) scale(.6); }
.vc-booking-widget.is-open .vc-booking__bubble-icon--calendar { opacity: 0; transform: rotate(90deg) scale(.6); }
.vc-booking-widget.is-open .vc-booking__bubble-icon--chevron  { opacity: 1; transform: rotate(0) scale(1); }

/* Popup */
.vc-booking__popup {
    position: absolute;
    bottom: 84px; right: 0;
    width: 360px;
    background: #fff;
    border-radius: 18px;
    padding: 26px 26px 24px;
    box-shadow: 0 24px 64px rgba(0,12,102,.22), 0 8px 20px rgba(0,0,0,.08);
    transform-origin: bottom right;
    animation: vc-booking-popin .5s cubic-bezier(.34, 1.56, .64, 1);
    font-family: var(--font);
}
.vc-booking__popup[hidden] { display: none; }
@keyframes vc-booking-popin {
    0%   { opacity: 0; transform: scale(.25); }
    55%  { opacity: 1; transform: scale(1.06); }
    78%  { transform: scale(.97); }
    100% { opacity: 1; transform: scale(1); }
}
.vc-booking__close {
    position: absolute;
    top: 10px; right: 10px;
    width: 30px; height: 30px;
    border: none; background: transparent;
    color: var(--text-muted);
    font-size: 1.5rem; line-height: 1; cursor: pointer;
    border-radius: 50%;
    transition: background .15s, color .15s;
}
.vc-booking__close:hover { background: var(--gray-light); color: var(--navy); }

.vc-booking__head {
    display: flex; align-items: center; gap: 14px;
    margin-bottom: 22px;
}
.vc-booking__avatar {
    position: relative;
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--navy);
    color: var(--yellow);
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 1.125rem;
    flex-shrink: 0;
    overflow: visible;
}
.vc-booking__avatar-img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 50%;
}
.vc-booking__avatar-initial {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: inherit;
    color: inherit;
}
.vc-booking__name {
    font-weight: 500; color: var(--navy);
    font-size: 1.0625rem;
    line-height: 1.2;
}
.vc-booking__dot {
    position: absolute;
    bottom: 1px; right: 1px;
    width: 12px; height: 12px;
    border-radius: 50%;
    background: #22c55e;
    box-shadow: 0 0 0 2.5px #fff;
}
.vc-booking__role {
    font-size: .875rem;
    color: var(--text-muted);
    margin-top: 3px;
    line-height: 1.3;
}

.vc-booking__title {
    font-size: 1.0625rem; font-weight: 500;
    color: var(--navy);
    margin: 0 0 10px;
    line-height: 1.35;
    letter-spacing: -0.01em;
}
.vc-booking__desc {
    font-size: .9375rem;
    color: var(--text-muted);
    line-height: 1.6;
    margin: 0 0 20px;
}

.vc-booking__urgency {
    position: relative;
    display: flex; align-items: center; justify-content: space-between;
    background: var(--gray-light);
    padding: 13px 15px;
    border-radius: 10px;
    margin-bottom: 18px;
    font-size: .8125rem;
    overflow: hidden;
}
.vc-booking__urgency-bar {
    position: absolute;
    top: 0; left: 0;
    height: 2.5px;
    width: 100%;
    background: var(--navy);
    transition: width .9s linear;
    transform-origin: left;
}
.vc-booking__urgency-text { color: var(--navy); font-weight: 500; }
.vc-booking__urgency-time {
    font-weight: 500;
    color: var(--navy);
    font-variant-numeric: tabular-nums;
}

/* Days picker */
.vc-booking__days {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 6px;
    margin-bottom: 18px;
}
.vc-booking__day {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 4px;
    padding: 11px 4px;
    border: 1px solid var(--gray);
    border-radius: 10px;
    background: #fff;
    color: var(--navy);
    font-family: var(--font);
    cursor: pointer;
    transition: border-color .15s, background .15s, transform .12s;
}
.vc-booking__day:hover { border-color: var(--navy); }
.vc-booking__day:active { transform: scale(.96); }
.vc-booking__day.is-selected {
    border-color: var(--navy);
    border-width: 1.5px;
    padding: 10.5px 3.5px;
}
.vc-booking__day-name {
    font-size: .75rem;
    font-weight: 500;
    color: var(--text-muted);
    line-height: 1;
}
.vc-booking__day.is-selected .vc-booking__day-name { color: var(--navy); }
.vc-booking__day-num {
    font-size: 1rem;
    font-weight: 500;
    line-height: 1;
}

.vc-booking__cta {
    width: 100%;
    padding: 13px 20px;
    background: var(--navy);
    color: #fff;
    border: none;
    border-radius: 10px;
    font-family: var(--font);
    font-size: .9375rem;
    font-weight: 500;
    cursor: pointer;
    transition: background .15s, transform .15s, box-shadow .15s;
}
.vc-booking__cta:hover {
    background: var(--navy);
}

@media (max-width: 480px) {
    .vc-booking-widget { bottom: 16px; right: 16px; }
    .vc-booking__popup { width: calc(100vw - 32px); right: 0; bottom: 76px; }
    .vc-booking__bubble { width: 52px; height: 52px; }
}


/* ─── SCROLL REVEAL ──────────────────────────────── */
/* Sections fade-in + translate-up au scroll. Hero exclu (apparaît directement). */
@media (prefers-reduced-motion: no-preference) {
    body.home > section {
        opacity: 0;
        transform: translateY(28px);
        transition: opacity .8s cubic-bezier(.16, 1, .3, 1),
                    transform .8s cubic-bezier(.16, 1, .3, 1);
        will-change: opacity, transform;
    }
    body.home > section.is-visible {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ─── PAGE OFFRE — HERO + DÉTAIL DE LA SOLUTION ─────── */
/* Pages d'offre : le dashboard mockup est la 1re section, on compense la navbar fixe */
body.page-offre .vc-dash2 {
    padding-top: calc(78px + clamp(56px, 8vw, 96px));
}

.vc-offre-detail {
    padding: var(--py) 0;
    background: transparent;
}
.vc-offre-detail__list {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px clamp(28px, 4vw, 56px);
    max-width: 1100px;
    margin: 0 auto;
    padding: 0;
}
.vc-offre-detail__list li {
    display: flex;
    gap: 16px;
    align-items: flex-start;
}
.vc-offre-detail__check {
    flex-shrink: 0;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--navy);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    margin-top: 2px;
}
.vc-offre-detail__list li > div { flex: 1; min-width: 0; }
.vc-offre-detail__list strong {
    display: block;
    font-size: 1.0625rem;
    font-weight: 600;
    color: var(--navy);
    margin-bottom: 6px;
    line-height: 1.3;
}
.vc-offre-detail__list p {
    font-size: .9375rem;
    color: var(--text-muted);
    line-height: 1.55;
    margin: 0;
}
@media (max-width: 768px) {
    .vc-offre-detail__list { grid-template-columns: 1fr; gap: 22px; }
}

/* ════════════════════════════════════════════════════════════════════
   ─── MOBILE FIXES — Round 1 (2026-05-11) ─────────────────────────
   Patch responsive ajouté en fin de fichier pour ne pas toucher
   l'existant. Cible les bugs remontés en test mobile sur staging :
   scroll horizontal, halo qui déborde, titres nowrap, nav burger,
   problem stats alignement, dashboard mockup, process 4 étapes.
   ════════════════════════════════════════════════════════════════════ */

/* ── Bloque le scroll horizontal et le pinch-zoom-out (root cause #1) ── */
@media (max-width: 900px) {
    html, body, body.home {
        overflow-x: clip;
        max-width: 100vw;
    }
}

/* ── Halo jaune contraint en mobile (ne déborde plus) ── */
@media (max-width: 900px) {
    .vc-halo-bg {
        width: min(100vw, 480px);
        height: 320px;
        top: 30%;
    }
    .vc-hero::before {
        width: min(120vw, 600px);
        height: 380px;
        top: -40px;
        left: -10vw;
    }
    .vc-hero::after {
        width: min(120vw, 480px);
        height: 360px;
        bottom: -60px;
        right: -10vw;
    }
}

/* ── Container padding plus généreux sur mobile (pas de contenu collé au bord) ── */
@media (max-width: 768px) {
    .vc-wrap { padding: 0 18px; }
}

/* ── Hero : wrap propre du titre + animation rotating ──
   font-size/line-height du H1 et du sub sont gérés par le bloc Round 3 (L3162+) */
@media (max-width: 768px) {
    .vc-hero-v2__h1 {
        white-space: normal;
    }
    .vc-hero-v2__rotating-word { white-space: normal; }
    .vc-hero-v2__rotating-wrap {
        display: inline;
        overflow: visible;
    }
    .vc-hero-v2__sub {
        padding: 0 6px;
    }
    .vc-hero-v2__badges { gap: 10px; padding: 0 8px; }
    .vc-hero-v2__proof {
        flex-direction: column;
        gap: 8px;
    }
    .vc-hero-v2__proof-item {
        padding: 0;
        border-right: none;
        font-size: .8125rem;
    }
}

/* ── Navigation mobile : grille robuste — logo gauche / burger droite, point ── */
@media (max-width: 768px) {
    .vc-nav { top: 8px; }
    .vc-nav__inner {
        grid-template-columns: auto 1fr auto;
        padding: 0 14px;
        height: 60px;
    }
    .vc-nav__logo {
        transform: none !important;
        justify-self: start;
    }
    .vc-nav.scrolled .vc-nav__logo { transform: none !important; }
    .vc-nav__logo-img { height: 26px; }
    .vc-nav__actions {
        transform: none !important;
        justify-self: end;
        gap: 0;
    }
    .vc-nav.scrolled .vc-nav__actions { transform: none !important; }
    .vc-nav__mobile-btn {
        padding: 10px;
        margin-right: -6px;
    }
    /* Le panneau mobile prend toute la largeur, fond opaque */
    .vc-nav__links.is-open {
        top: 60px;
        padding: 24px 20px;
        background: rgba(255,255,255,.98);
    }
    /* Offres : header = row flex plein largeur, anchor = lien comme les autres, trigger = petit chevron */
    .vc-nav__links.is-open .vc-nav__item-header {
        display: flex; align-items: center; width: 100%;
    }
    .vc-nav__links.is-open .vc-nav__item-anchor {
        flex: 1; width: auto; justify-content: flex-start;
    }
    .vc-nav__links.is-open .vc-nav__dropdown-trigger {
        width: auto; flex-shrink: 0; padding: 10px 14px; justify-content: center;
    }
}

/* ── Logos clients : hauteurs uniformes en mobile (plus de superposition) ── */
@media (max-width: 768px) {
    .vc-logos__img,
    .vc-logos__img[data-logo="othrys"],
    .vc-logos__img[data-logo="biux"],
    .vc-logos__img[data-logo="valode-pistre"],
    .vc-logos__img[data-logo="essca"],
    .vc-logos__img[data-logo="mindsales"],
    .vc-logos__img[data-logo="la-guilde"],
    .vc-logos__img[data-logo="premices"] {
        height: 28px !important;
        width: auto !important;
        max-width: 120px;
    }
    .vc-logos__item { padding: 0 22px; }
    .vc-logos__label {
        font-size: 1.0625rem;
        padding: 0 18px;
        line-height: 1.35;
    }
}

/* ── Problem stats : chiffres et labels centrés en mobile (rendu propre quand 1 colonne) ── */
@media (max-width: 768px) {
    .vc-problem__quote {
        font-size: clamp(1.4rem, 5.5vw, 1.875rem);
        line-height: 1.2;
        padding: 0 4px;
    }
    .vc-problem__stat-num { white-space: normal; }
    .vc-problem__stats--cards .vc-problem__stat,
    .vc-problem__stats--cards .vc-problem__stat-num,
    .vc-problem__stats--cards .vc-problem__stat-label {
        text-align: center;
    }
    .vc-problem__stats--cards .vc-problem__stat {
        align-items: center;
    }
}

/* ── Section offres : "Outil Métier Sur-Mesure" remonte en premier sur mobile ── */
@media (max-width: 768px) {
    .vc-offers__grid {
        display: flex;
        flex-direction: column;
        gap: 16px;
        padding-top: 0;
    }
    .vc-offer-card--highlighted {
        order: -1;
        margin-top: 0;
    }
}

/* ── Dashboard mockup (page d'accueil): adapté au mobile ── */
@media (max-width: 768px) {
    .vc-dash2 .vc-sub {
        white-space: normal;
        font-size: 1rem;
        padding: 0 8px;
        line-height: 1.55;
    }
    .vc-dash2 .vc-h2 {
        padding: 0 4px;
        text-wrap: balance;
    }
    .vc-dash2__scene {
        padding: 18px 14px 0;
        border-radius: 16px;
    }
    .vc-dash2__window {
        width: 100%;
        transform: none;
        border-radius: 10px 10px 0 0;
    }
    .vc-dash2__app {
        height: auto;
        min-height: 380px;
        flex-direction: column;
    }
    .vc-dash2__sidebar {
        width: 100%;
        flex-direction: row;
        overflow-x: auto;
        gap: 6px;
        padding: 8px;
        border-right: none;
        border-bottom: 1px solid #e8eaef;
    }
    .vc-dash2__nav-group { flex-direction: row; gap: 4px; flex-shrink: 0; }
    .vc-dash2__brand { display: none; }
    .vc-dash2__nav-label { display: none; }
    .vc-dash2__kpis { grid-template-columns: repeat(2, 1fr); gap: 6px; }
    .vc-dash2__charts { grid-template-columns: 1fr; gap: 8px; }
}

/* ── ERP demo : layout 3D simplifié et conteneur adapté ── */
@media (max-width: 768px) {
    .vc-erp-demo__device {
        aspect-ratio: 16/11;
        max-width: 100%;
    }
    .vc-erp-ui__sidebar { width: 88px; padding: 8px 6px; }
    .vc-erp-ui__logo-img { width: 52px; }
    .vc-erp-ui__kpis { grid-template-columns: repeat(2, 1fr); }
}

/* ── Process 4 étapes : 1 colonne dès 768px (au lieu de 480px) ── */
@media (max-width: 768px) {
    .vc-process__steps {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    .vc-process__step::after { display: none; }
}

/* ── Titres et sous-titres globaux : padding pour ne pas coller au bord ── */
@media (max-width: 768px) {
    .vc-h2 {
        padding: 0 8px;
        text-wrap: balance;
    }
    .vc-sub {
        padding: 0 8px;
    }
    .vc-head .vc-h2,
    .vc-head .vc-sub {
        padding: 0 4px;
    }
}

/* ── CTA final + cards diverses : margin/padding mobile ── */
@media (max-width: 768px) {
    .vc-cta-final__title { padding: 0 8px; text-wrap: balance; }
    .vc-cta-final__sub { padding: 0 12px; }
    /* Mobile : stack vertical, la featured reste plus haute mais en pleine largeur. */
    .vc-results__stats {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        gap: 14px;
    }
    .vc-results__stat--featured {
        grid-row: auto;
        padding: clamp(24px, 5vw, 32px);
    }
}

/* ── Témoignages : carte unique en mobile (déjà géré mais on confirme) ── */
@media (max-width: 768px) {
    .vc-testimonials__cols { gap: 0; }
}

/* ── Booking widget (chat Anthropic) : taille bouton mobile-friendly ── */
@media (max-width: 768px) {
    .vc-booking-widget {
        bottom: 16px;
        right: 16px;
    }
}

/* ── Footer : padding bottom plus raisonnable en mobile ── */
@media (max-width: 480px) {
    .vc-footer { padding: 64px 0 140px; }
    .vc-footer__watermark { width: 100vw; }
}

/* ════════════════════════════════════════════════════════════════════
   ─── MOBILE FIXES — Round 2 (2026-05-11) ─────────────────────────
   Round 1 a cassé l'animation rotating words du hero. Round 2 corrige
   ça + applique tous les retours user du 2e test mobile.
   ════════════════════════════════════════════════════════════════════ */

/* ── FIX CRITIQUE : restaurer l'animation rotating words ── */
@media (max-width: 768px) {
    .vc-hero-v2__rotating-wrap {
        display: inline-block !important;
        overflow: hidden !important;
        vertical-align: bottom;
    }
    .vc-hero-v2__rotating-word {
        white-space: nowrap !important;
        line-height: 1.05;
    }
    /* Le H1 peut wrap globalement, MAIS le mot rotatif doit rester sur 1 ligne */
    .vc-hero-v2__h1 {
        font-size: clamp(1.5rem, 6.5vw, 2rem);
        line-height: 1.18;
        text-wrap: balance;
    }
    .vc-hero-v2__sub {
        text-wrap: pretty;
        padding: 0 12px;
        max-width: 100%;
    }
    /* Sous-titre du hero : conserver le <br> après "scalable :" pour break propre */
    .vc-hero-v2__sub br { display: inline; }
}

/* ── Logos clients : revenir à des tailles raisonnables (Round 1 trop petit) ── */
@media (max-width: 768px) {
    .vc-logos__img,
    .vc-logos__img[data-logo="othrys"],
    .vc-logos__img[data-logo="biux"],
    .vc-logos__img[data-logo="valode-pistre"],
    .vc-logos__img[data-logo="essca"],
    .vc-logos__img[data-logo="mindsales"],
    .vc-logos__img[data-logo="la-guilde"],
    .vc-logos__img[data-logo="premices"] {
        height: 40px !important;
        max-width: 140px;
    }
    .vc-logos__item { padding: 0 28px; }
    .vc-logos {
        padding: 24px 0 18px;
        margin-top: 24px;
    }
    .vc-logos__label {
        font-size: 1.0625rem;
        margin-bottom: 18px;
    }
}

/* ── Stats numbers : restaurer nowrap + spacing nombre/unité ── */
@media (max-width: 768px) {
    .vc-problem__stat-num,
    .vc-problem__stats--cards .vc-problem__stat-num,
    .vc-results__stat-num {
        white-space: nowrap !important;
    }
    /* L'unité "k €", "h", "j" doit être espacée du chiffre */
    .vc-problem__stat-unit {
        margin-left: 4px;
    }
}

/* ── Problem section : titre sur 2 lignes max + sub avec break après "?" ── */
@media (max-width: 768px) {
    .vc-problem__quote {
        font-size: clamp(1.5rem, 6vw, 2rem);
        text-wrap: balance;
        max-width: 92%;
        margin: 0 auto;
    }
    /* Réduire les marges entre cards pour ne pas avoir l'écran trop long */
    .vc-problem__stats--cards .vc-problem__stat {
        padding: 22px 18px;
    }
}

/* ── Section Offres : titre "Trois offres, un seul objectif" suit le Niveau 1 (vraie taille titre)
   Wrap naturel sur 2 lignes si nécessaire (priorité taille titre > 1 ligne) */

/* ── Dashboard mockup : garder le layout horizontal complet, juste scale-down ── */
@media (max-width: 900px) {
    /* On ANNULE les overrides Round 1 qui passaient en colonne */
    .vc-dash2__app {
        height: 360px !important;
        flex-direction: row !important;
    }
    .vc-dash2__sidebar {
        width: 110px !important;
        flex-direction: column !important;
        overflow: hidden !important;
        border-right: 1px solid #e8eaef !important;
        border-bottom: none !important;
        padding: 10px 6px !important;
    }
    .vc-dash2__nav-group { flex-direction: column !important; }
    .vc-dash2__brand { display: block !important; }
    .vc-dash2__nav-label { display: block !important; }
    .vc-dash2__kpis { grid-template-columns: repeat(5, 1fr) !important; gap: 5px !important; }
    .vc-dash2__charts { grid-template-columns: 1fr 100px !important; }
    /* Window garde sa perspective 3D mais légère */
    .vc-dash2__window {
        width: 100% !important;
        transform: perspective(2400px) rotateX(6deg) rotateY(-6deg) !important;
    }
    .vc-dash2__scene {
        padding: 24px 12px 0 !important;
    }
}
@media (max-width: 560px) {
    /* Sur très petit écran, scale le tout pour que ça rentre lisiblement */
    .vc-dash2__scene {
        padding: 20px 8px 0 !important;
    }
    .vc-dash2__window {
        transform: perspective(2400px) rotateX(4deg) rotateY(-4deg) !important;
    }
    .vc-dash2__app { height: 320px !important; }
    .vc-dash2__sidebar { width: 88px !important; }
    .vc-dash2__nav-item { font-size: 8.5px !important; padding: 4px 5px !important; }
    .vc-dash2__nav-label { font-size: 7px !important; }
    .vc-dash2__kpi { padding: 6px 7px !important; }
    .vc-dash2__kpi-val { font-size: 11px !important; }
    .vc-dash2__kpi-label { font-size: 7.5px !important; }
    .vc-dash2__table-head,
    .vc-dash2__table-row { font-size: 7.5px !important; padding: 4px 6px !important; }
}

/* ── Témoignages : pause au touch / hover ── */
.vc-testimonials__cols:hover .vc-testimonials__track,
.vc-testimonials__cols:active .vc-testimonials__track,
.vc-testimonials__cols.is-paused .vc-testimonials__track {
    animation-play-state: paused;
}

/* ── Nav mobile dropdown : "Nos offres" comme les autres + chevron pour sous-menu ── */
@media (max-width: 768px) {
    /* Sous-dropdown caché par défaut, expand au clic du chevron */
    .vc-nav__links.is-open .vc-nav__dropdown {
        position: static;
        opacity: 1;
        pointer-events: auto;
        max-height: 0;
        overflow: hidden;
        transform: none;
        margin: 0;
        padding: 0;
        border: none;
        background: transparent;
        box-shadow: none;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        transition: max-height .18s ease-out;
    }
    .vc-nav__links.is-open .vc-nav__item--has-dropdown.is-open .vc-nav__dropdown {
        max-height: 220px;
        padding: 4px 0 12px;
    }
}

/* ── CTA "Réserver un appel" en bas du menu mobile ── Bouton pill navy plein avec texte blanc,
   comme les boutons du hero. Force tout en !important pour battre les sélecteurs globaux
   du menu mobile qui imposent width:100%, border-radius:r-md, background:none, color:navy. */
.vc-nav__cta-item { display: none; }
@media (max-width: 768px) {
    .vc-nav__links.is-open .vc-nav__cta-item {
        display: flex !important;
        justify-content: center !important;
        width: 100%;
        margin-top: 20px;
    }
    .vc-nav__links.is-open .vc-nav__cta-btn,
    .vc-nav__cta-item .vc-btn--primary {
        background: var(--navy) !important;
        color: #fff !important;
        border-radius: 9999px !important;
        padding: 20px 44px !important;
        font-size: 1.125rem !important;
        font-weight: 600 !important;
        line-height: 1 !important;
        width: auto !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        white-space: nowrap;
        border: none !important;
    }
    /* CTA du dropdown mobile : pas de changement de couleur au tap, juste un effet
       de pression (scale down) pour confirmer le clic. */
    .vc-nav__links.is-open .vc-nav__cta-btn {
        transition: transform .12s ease, box-shadow .12s ease !important;
    }
    .vc-nav__links.is-open .vc-nav__cta-btn:hover,
    .vc-nav__links.is-open .vc-nav__cta-btn:focus,
    .vc-nav__links.is-open .vc-nav__cta-btn:active {
        background: var(--navy) !important;
        color: #fff !important;
    }
    .vc-nav__links.is-open .vc-nav__cta-btn:active {
        transform: scale(0.96);
        box-shadow: 0 2px 8px rgba(0, 12, 102, .25);
    }
}

/* ── Footer : watermark logo qui chevauche le copy en mobile ── */
@media (max-width: 768px) {
    .vc-footer { padding: 64px 0 200px; position: relative; }
    .vc-footer__watermark {
        bottom: auto;
        top: auto;
        width: 100%;
        max-height: 90px;
        object-fit: contain;
        position: relative;
        margin: 32px auto 0;
        display: block;
        opacity: 0.18;
    }
    .vc-footer__bottom {
        position: static !important;
        margin-top: 28px;
        padding: 24px 16px 0;
        bottom: auto !important;
        border-top: 1px solid var(--gray);
    }
}
@media (max-width: 480px) {
    .vc-footer { padding: 56px 0 24px; }
}

/* ── FAQ : break ligne après "?" sur le CTA support ── */
@media (max-width: 768px) {
    .vc-faq__support br { display: inline; }
    .vc-faq__support a {
        display: inline-block;
        margin-top: 4px;
    }
}

/* ── Page Réserver audit IA : checks alignés à gauche + Calendly moins haut en mobile ── */
@media (max-width: 768px) {
    .vc-book__checks {
        flex-direction: column !important;
        align-items: flex-start !important;
        max-width: 100%;
        padding: 0 12px;
        gap: 12px !important;
    }
    .vc-book__check {
        text-align: left;
        white-space: normal;
    }
    .calendly-inline-widget {
        height: 720px !important;
    }
}
@media (max-width: 480px) {
    .calendly-inline-widget {
        height: 720px !important;
    }
}

/* ════════════════════════════════════════════════════════════════════
   ─── MOBILE FIXES — Round 3 (2026-05-14) ─────────────────────────
   Retours user après Round 2 :
   - Titre hero sur 3 lignes (au lieu de 4) + plus imposant
   - Tous les titres globalement plus gros (cohérence)
   - Logos clients beaucoup plus gros
   - Dashboard coupé → scale complet sur la largeur du téléphone
   ════════════════════════════════════════════════════════════════════ */

/* ── Hero H1 : 3 lignes propres, plus gros, wrap naturel ── */
@media (max-width: 768px) {
    .vc-hero-v2__h1 {
        font-size: clamp(1.875rem, 7vw, 2.5rem) !important;
        line-height: 1.18 !important;
        text-wrap: balance;
        padding: 0 8px;
        max-width: 100%;
    }
    /* On masque les <br> du H1 pour que le texte wrap naturellement sur 3 lignes balanced */
    .vc-hero-v2__h1 br { display: none; }
    /* Sous-titre hero plus gros aussi (cohérent avec le H1 plus gros) */
    .vc-hero-v2__sub {
        font-size: 1.0625rem !important;
        line-height: 1.55;
    }
}

/* ══════════════════════════════════════════════════════════════════
   ÉCHELLE TYPOGRAPHIQUE MOBILE — 3 niveaux, référence = hero
   ══════════════════════════════════════════════════════════════════
   NIVEAU 1 : grand titre de section (h2 visuel)
     clamp(1.875rem, 7vw, 2.5rem) · weight 500 · lh 1.18 · ls -0.03em
     → .vc-h2, .vc-problem__quote, .vc-cta-final__title
       (.vc-hero-v2__h1 a déjà ces valeurs via Round 3 L3162)

   NIVEAU 2 : titre secondaire (carte, footer CTA)
     clamp(1.125rem, 4.5vw, 1.375rem) · weight 500 · lh 1.2 · ls -0.025em
     → .vc-offer-card__title, .vc-footer__cta-title

   NIVEAU 3 : sous-titre / body lead (calé sur hero sub)
     1.0625rem · weight 400 · lh 1.55
     → .vc-sub (toutes variantes)
     Exception : .vc-problem .vc-sub réduit pour tenir 1ʳᵉ phrase sur 1 ligne
   ══════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    /* NIVEAU 1 — Grands titres */
    .vc-h2,
    .vc-problem__quote,
    .vc-cta-final__title {
        font-size: clamp(1.875rem, 7vw, 2.5rem) !important;
        font-weight: 500 !important;
        line-height: 1.18 !important;
        letter-spacing: -0.03em;
        text-wrap: balance;
    }
    /* NIVEAU 2 — Titres secondaires (titres de cartes, footer CTA)
       Contraste clair avec le body text (1.0625rem) pour bien lire comme un titre */
    .vc-offer-card__title,
    .vc-footer__cta-title {
        font-size: clamp(1.375rem, 5.5vw, 1.75rem) !important;
        font-weight: 600 !important;
        line-height: 1.2 !important;
        letter-spacing: -0.025em;
    }
    /* NIVEAU 3 — Sous-titres / body lead (uniformes, sans exception) */
    .vc-sub {
        font-size: 1.0625rem !important;
        line-height: 1.55;
    }
    /* NIVEAU 3 (bis) — Corps de texte courant à la même taille que .vc-sub */
    .vc-offer-card__desc,
    .vc-offer-card__list li,
    .vc-problem__stat-label,
    .vc-results__stat-desc,
    .vc-process__step-text,
    .vc-why__card-text,
    .vc-faq__a-inner,
    .vc-testimonial__text,
    .vc-footer__links a,
    .vc-footer__cta-desc {
        font-size: 1.0625rem !important;
    }
    /* Labels uppercase */
    .vc-label {
        font-size: 0.75rem !important;
        margin-bottom: 12px;
    }
}

/* ── Logos clients mobile : homogénéité optique (visual area ~4500-5500 par logo) ──
   Heights calibrées pour que chaque logo occupe environ la même surface visuelle,
   en compensant l'aspect ratio. */
@media (max-width: 768px) {
    .vc-logos__img {
        max-width: none !important;
        width: auto !important;
    }
    .vc-logos__img[data-logo="mindsales"]     { height: 36px !important; } /* aspect 4.36 → ~157×36 = 5650 */
    .vc-logos__img[data-logo="othrys"]        { height: 44px !important; } /* aspect 2.89 → ~127×44 = 5590 */
    .vc-logos__img[data-logo="biux"]          { height: 50px !important; } /* aspect 1.81 → ~91×50 = 4525 */
    .vc-logos__img[data-logo="essca"]         { height: 56px !important; } /* aspect 1.50 → ~84×56 = 4700 */
    .vc-logos__img[data-logo="premices"]      { height: 58px !important; } /* aspect 1.41 → ~82×58 = 4756 */
    .vc-logos__img[data-logo="la-guilde"]     { height: 58px !important; } /* aspect 1.38 → ~80×58 = 4640 */
    .vc-logos__img[data-logo="valode-pistre"] { height: 68px !important; } /* aspect 1.00 → ~68×68 = 4624 */

    .vc-logos__item { padding: 0 30px; }
    .vc-logos {
        padding: 32px 0 24px;
        margin-top: 16px;
    }
    .vc-logos__label {
        font-size: 1.125rem !important;
        margin-bottom: 22px;
        line-height: 1.35;
    }
    /* Smooth GPU-accelerated animation pour éviter les saccades / jumps au loop */
    .vc-logos__track {
        will-change: transform;
        backface-visibility: hidden;
        -webkit-backface-visibility: hidden;
    }
}

/* ── Dashboard mockup : complet sur la largeur du téléphone, plus de coupure ── */
@media (max-width: 900px) {
    /* On retire la perspective 3D et tout transform → window à plat = pas de coupure */
    .vc-dash2__window {
        transform: none !important;
        width: 100% !important;
    }
    .vc-dash2__scene {
        padding: 20px 10px 0 !important;
        overflow: hidden;
        border-radius: 14px;
    }
    .vc-dash2__app {
        height: auto !important;
        min-height: 280px;
        flex-direction: row !important;
    }
}

/* Sur smartphone, on réduit proportionnellement toutes les valeurs internes
   pour que la sidebar + main + KPIs + table rentrent SANS être tronqués */
@media (max-width: 560px) {
    .vc-dash2__scene { padding: 14px 6px 0 !important; }
    .vc-dash2__chrome { padding: 6px 10px !important; }
    .vc-dash2__dot { width: 7px !important; height: 7px !important; }
    .vc-dash2__urlbar { font-size: 8px !important; padding: 2px 7px !important; max-width: 130px !important; }
    .vc-dash2__app { min-height: 260px; }
    .vc-dash2__sidebar {
        width: 76px !important;
        padding: 8px 5px !important;
        gap: 8px !important;
    }
    .vc-dash2__brand { padding: 1px 3px 5px !important; }
    .vc-dash2__nav-label {
        font-size: 6.5px !important;
        padding: 0 4px !important;
    }
    .vc-dash2__nav-item {
        font-size: 8px !important;
        padding: 3px 4px !important;
        gap: 4px !important;
    }
    .vc-dash2__nav-item svg { width: 8px !important; height: 8px !important; }
    .vc-dash2__main { padding: 8px 9px !important; gap: 6px !important; }
    .vc-dash2__page-title { font-size: 9px !important; }
    .vc-dash2__period-btn { font-size: 7.5px !important; padding: 2px 6px !important; }
    .vc-dash2__kpis {
        grid-template-columns: repeat(5, 1fr) !important;
        gap: 3px !important;
    }
    .vc-dash2__kpi {
        padding: 5px 5px !important;
        border-radius: 5px !important;
    }
    .vc-dash2__kpi-label { font-size: 6.5px !important; margin-bottom: 1px !important; }
    .vc-dash2__kpi-val { font-size: 9px !important; }
    .vc-dash2__kpi-trend { font-size: 6.5px !important; }
    .vc-dash2__section-title { font-size: 8px !important; }
    .vc-dash2__table-head,
    .vc-dash2__table-row {
        font-size: 7px !important;
        padding: 3px 5px !important;
    }
    .vc-dash2__badge { font-size: 6.5px !important; padding: 1px 4px !important; }
    .vc-dash2__charts {
        grid-template-columns: 1fr 80px !important;
        gap: 5px !important;
    }
    .vc-dash2__card { padding: 6px 7px !important; }
    .vc-dash2__card-title { font-size: 7px !important; }
    .vc-dash2__bigval { font-size: 12px !important; }
    .vc-dash2__chart-legend span { font-size: 6.5px !important; }
    .vc-dash2__donut { width: 60px !important; height: 60px !important; }
    .vc-dash2__donut-legend div { font-size: 6.5px !important; }
    .vc-dash2__area { height: 38px !important; }
}

/* ════════════════════════════════════════════════════════════════════
   ─── MOBILE FIXES — Round 4 (2026-05-18) ─────────────────────────
   Nav plein écran + bleu · Offres accordion · Break "situations ?"
   Dashboard miniature desktop · Footer watermark en bas
   ════════════════════════════════════════════════════════════════════ */

/* ── Offres cartes : header/body — display:contents sur desktop (préserve subgrid) ── */
.vc-offer-card__header { display: contents; }
.vc-offer-card__body   { display: contents; }
.vc-offer-card__chevron { display: none; }

/* ── Nav mobile : style Softriver — panel hauteur auto, s'arrête au milieu ── */
@media (max-width: 768px) {
    /* Nav + burger toujours visibles par-dessus le dropdown */
    .vc-nav { z-index: 10000 !important; }
    .vc-nav__inner { z-index: 10000; position: relative; }
    .vc-nav__mobile-btn { position: relative; z-index: 10001; }
    .vc-nav__logo { position: relative; z-index: 10001; }

    .vc-nav__links.is-open {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100vw !important;
        max-width: none !important;
        height: auto !important;
        max-height: none !important;
        bottom: auto !important;
        padding: 88px 40px 40px !important;
        background: #fff !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        z-index: 9998 !important;
        box-sizing: border-box !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 0 !important;
        box-shadow: 0 8px 40px rgba(0,0,0,.10) !important;
        border-radius: 0 0 20px 20px !important;
    }

    /* Tous les items (offres + nav) : même taille, même graisse, centrés */
    .vc-nav__links.is-open > li {
        width: 100%;
        text-align: center;
    }
    .vc-nav__links.is-open > li:not(.vc-nav__item--has-dropdown):not(.vc-nav__cta-item) a,
    .vc-nav__links.is-open .vc-nav__item-anchor {
        color: var(--navy) !important;
        font-size: 1.375rem !important;
        font-weight: 500 !important;
        padding: 11px 0 !important;
        text-align: center !important;
        justify-content: center !important;
        border-radius: 0 !important;
        width: auto !important;
        display: inline-block !important;
        background: none !important;
    }

    /* Header de l'item Offres : "Nos offres" centré au milieu (phantom à gauche équilibre le chevron à droite) */
    .vc-nav__links.is-open .vc-nav__item-header {
        display: flex !important;
        align-items: center;
        justify-content: center;
        gap: 0;
        width: 100%;
    }
    .vc-nav__links.is-open .vc-nav__item-header::before {
        content: '';
        display: block;
        width: 28px;
        flex-shrink: 0;
    }
    /* Petit bouton chevron collé au texte */
    .vc-nav__links.is-open .vc-nav__dropdown-trigger {
        display: inline-flex !important;
        width: 28px !important;
        padding: 4px 0 4px 4px !important;
        flex: 0 0 auto;
        color: var(--navy) !important;
        background: transparent !important;
        border-radius: 0 !important;
        justify-content: flex-start !important;
    }
    .vc-nav__links.is-open .vc-nav__dropdown-trigger .vc-nav__chevron {
        width: 16px;
        height: 16px;
    }

    /* Sous-items offres : style sub-menu centré, plus discret, avec plus d'espace vertical */
    .vc-nav__links.is-open .vc-nav__dropdown a {
        color: var(--text-muted) !important;
        font-size: 1.0625rem !important;
        font-weight: 500 !important;
        padding: 14px 0 !important;
        text-align: center !important;
        justify-content: center !important;
        border-radius: 0 !important;
        width: 100% !important;
        display: block !important;
        background: none !important;
    }
    .vc-nav__links.is-open .vc-nav__dropdown a:hover,
    .vc-nav__links.is-open .vc-nav__dropdown a:active {
        color: var(--navy) !important;
    }
}

/* ── Section 2 : br uniquement sur mobile ── */
.vc-br-mob { display: none; }
@media (max-width: 768px) {
    .vc-br-mob { display: block; }
}

/* ── Offres : cartes ouvertes en permanence sur mobile (comme desktop) ── */

/* ── Dashboard mobile : MÊME rendu que desktop, juste scalé en bloc avec zoom ──
   Pas d'overrides individuels font/padding/gap : zoom gère tout proportionnellement.
   !important sur toutes les props pour battre les multiples règles mobile antérieures
   (Round 1, 2, 3, 4) qui imposaient width: 100% + transform perspective + height auto. */
@media (max-width: 900px) {
    .vc-dash2__scene {
        overflow: hidden !important;
        padding: 24px 16px 0 !important;
        border-radius: 20px !important;
        /* Garde le fond gradient grey-blue desktop pour le visuel du conteneur */
        display: flex !important;
        justify-content: center !important;
        align-items: flex-start !important;
        height: auto !important;
    }
    /* Window : 880px desktop + zoom proportionnel + tilt 3D desktop (perspective/rotate)
       On NE met PAS transform: none — le transform desktop hérite et donne le biais visuel
       que l'utilisateur veut conserver sur mobile aussi. */
    .vc-dash2__window {
        width: 880px !important;
        zoom: 0.42 !important;
        margin: 0 !important;
        border-radius: 14px !important;
        /* Tilt 3D forcé en !important pour battre les rounds antérieurs (transform: none, etc.)
           Valeurs identiques à L1066 (desktop). */
        transform: perspective(2000px) rotateX(10deg) rotateY(-14deg) rotateZ(3deg) !important;
        transform-origin: 50% bottom !important;
    }
    /* Reset toutes les overrides app/sidebar des rounds antérieurs — zoom gère tout */
    .vc-dash2__app {
        height: auto !important;
        flex-direction: row !important;
        min-height: unset !important;
    }
    /* Sidebar : valeurs desktop (override des rounds qui imposaient 88px/cacher brand etc.) */
    .vc-dash2__sidebar {
        width: 155px !important;
        padding: 14px 10px !important;
        gap: 14px !important;
    }
    .vc-dash2__brand     { display: block !important; padding: 2px 4px 8px !important; }
    .vc-dash2__nav-label { display: block !important; }
    .vc-dash2__nav-item  { display: flex !important; }
    /* KPI + charts grid : repasse en disposition desktop (5 cols KPIs / chart + donut 148px) */
    .vc-dash2__kpis      { grid-template-columns: repeat(5, 1fr) !important; gap: 8px !important; }
    .vc-dash2__charts    { grid-template-columns: 1fr 148px !important; gap: 8px !important; }
    /* Léger rétrécissement des titres + chiffres pour aérer la preview mobile zoomée */
    .vc-dash2__page-title { font-size: 10px !important; }
    .vc-dash2__kpi-val    { font-size: 11px !important; }
    .vc-dash2__bigval     { font-size: 15px !important; }
}

/* Écrans étroits (≤440px) */
@media (max-width: 440px) {
    .vc-dash2__window { zoom: 0.39 !important; }
}

/* Écrans très étroits (≤375px) */
@media (max-width: 375px) {
    .vc-dash2__window { zoom: 0.36 !important; }
}

/* ── Footer mobile : structure Biux — watermark logo en flow entre la section contact et les mentions ── */
@media (max-width: 768px) {
    .vc-footer {
        padding: 64px 0 32px !important;
        position: relative !important;
        overflow: hidden !important;
    }
    .vc-footer__watermark {
        position: static !important;
        display: block !important;
        margin: 40px auto 0 !important;
        transform: none !important;
        width: clamp(280px, 90vw, 520px) !important;
        max-height: unset !important;
        height: auto !important;
        opacity: 0.18 !important;
    }
    .vc-footer__bottom {
        position: static !important;
        margin-top: 24px;
        padding: 20px 16px 0;
        bottom: auto !important;
        border-top: none;
    }
}
@media (max-width: 480px) {
    .vc-footer { padding: 56px 0 24px !important; }
}

/* ── Hero mobile : rapprocher les premiers textes du header (moins de vide top) ── */
@media (max-width: 768px) {
    .vc-hero-v2 {
        padding-top: calc(78px + 20px) !important;
    }
}

/* ════════════════════════════════════════════════════════════════════
   ─── PAGE OFFRE — HERO ALLÉGÉ (sans dashboard mockup) ──────────────
   Utilisé sur page-offre-audit-formation-ia.php et
   page-offre-prospection-multicanale.php. Header + 3 stats inline +
   CTA. Padding-top compense la navbar fixe (78px).
   ════════════════════════════════════════════════════════════════════ */
.vc-offre-hero {
    padding: calc(78px + clamp(56px, 8vw, 96px)) 0 clamp(48px, 6vw, 80px);
    background: transparent;
    position: relative;
}
.vc-offre-hero .vc-head { margin-bottom: clamp(36px, 4vw, 56px); }
.vc-offre-hero .vc-h2 {
    font-size: clamp(1.85rem, 3.8vw, 3rem);
    line-height: 1.1;
    letter-spacing: -.025em;
}
.vc-offre-hero .vc-sub {
    max-width: 720px;
    margin: 0 auto;
    font-size: 1.0625rem;
    line-height: 1.6;
}
/* Bloc positionnement : 2 colonnes "Ce qu'on fait" / "Ce qu'on ne fait pas".
   Affirme le scope de l'offre directement dans le hero, sans recourir à des
   stats abstraites. La colonne verte (yes) emporte la décision, la colonne
   atténuée (no) rassure sur ce qu'on ne vend pas. */
.vc-offre-hero__positioning {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(16px, 2.4vw, 28px);
    max-width: 920px;
    margin: 0 auto clamp(32px, 4vw, 48px);
    padding: 0 clamp(20px, 4vw, 32px);
}
.vc-offre-hero__positioning-col {
    padding: clamp(20px, 2.4vw, 28px) clamp(20px, 2.6vw, 32px);
    border-radius: var(--r-lg);
    border: 1px solid rgba(0, 12, 102, .08);
    background: #fff;
    box-shadow: 0 1px 3px rgba(0, 12, 102, .03);
}
.vc-offre-hero__positioning-col--yes {
    border-color: rgba(0, 12, 102, .14);
}
.vc-offre-hero__positioning-col--no {
    background: rgba(0, 12, 102, .025);
}
.vc-offre-hero__positioning-label {
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--navy);
    margin: 0 0 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.vc-offre-hero__positioning-col--no .vc-offre-hero__positioning-label {
    color: var(--text-muted);
}
.vc-offre-hero__positioning-label::before {
    content: '';
    display: inline-block;
    width: 18px; height: 18px;
    border-radius: 50%;
    background: var(--navy) center / 12px no-repeat
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
    flex-shrink: 0;
}
.vc-offre-hero__positioning-col--no .vc-offre-hero__positioning-label::before {
    background: #c4c8d4 center / 10px no-repeat
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
}
.vc-offre-hero__positioning-col ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.vc-offre-hero__positioning-col li {
    font-size: .9375rem;
    line-height: 1.5;
    color: var(--text);
    padding-left: 22px;
    position: relative;
    text-align: left;
}
.vc-offre-hero__positioning-col--yes li::before {
    content: '';
    position: absolute;
    left: 0; top: .35em;
    width: 14px; height: 14px;
    background: center / contain no-repeat
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000c66' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
}
.vc-offre-hero__positioning-col--no li {
    color: var(--text-muted);
    text-decoration: line-through;
    text-decoration-color: rgba(107, 114, 128, .4);
    text-decoration-thickness: 1px;
}
.vc-offre-hero__positioning-col--no li::before {
    content: '';
    position: absolute;
    left: 0; top: .4em;
    width: 12px; height: 12px;
    background: center / contain no-repeat
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c4c8d4' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
}
.vc-offre-hero__cta {
    text-align: center;
    margin-top: clamp(24px, 3vw, 36px);
}
@media (max-width: 768px) {
    .vc-offre-hero {
        padding: calc(78px + 32px) 0 clamp(40px, 6vw, 64px);
    }
    .vc-offre-hero .vc-h2 { font-size: 1.85rem; }
    .vc-offre-hero .vc-sub { font-size: 1rem; }
    .vc-offre-hero__positioning {
        grid-template-columns: 1fr;
        gap: 14px;
        max-width: 480px;
        margin-bottom: 28px;
    }
    .vc-offre-hero__positioning-col { padding: 20px 22px; }
    .vc-offre-hero__positioning-label { font-size: .7rem; margin-bottom: 14px; }
    .vc-offre-hero__positioning-col li { font-size: .9375rem; }
}
