/* ============================================================
   WEBI MAIN CSS — v7.0
   Design system dark/light, zéro framework, zéro plugin
   ============================================================ */

/* ── Variables Dark (défaut) ─────────────────────────────── */
:root {
    --bg-primary:    #060608;
    --bg-secondary:  #0e0e12;
    --bg-card:       #13131a;
    --bg-card-hover: #1a1a24;
    --accent:        #C6FF00;
    --accent-dark:   #a8d900;
    --accent-glow:   rgba(198, 255, 0, 0.15);
    --text-primary:  #ffffff;
    --text-secondary:#9999BB;
    --text-muted:    #666680;
    --border:        rgba(255,255,255,0.08);
    --border-accent: rgba(198,255,0,0.3);
    --shadow:        0 4px 24px rgba(0,0,0,0.4);
    --shadow-accent: 0 4px 32px rgba(198,255,0,0.15);
    --radius-sm:     6px;
    --radius-md:     12px;
    --radius-lg:     20px;
    --radius-xl:     32px;
    --font-title:    'Syne', sans-serif;
    --font-body:     'DM Sans', sans-serif;
    --transition:    0.25s cubic-bezier(0.4, 0, 0.2, 1);
    --container:     1200px;
    --header-h:      72px;
}

/* ── Variables Light ─────────────────────────────────────── */
[data-theme="light"] {
    --bg-primary:    #F0EEE6;
    --bg-secondary:  #E8E6DE;
    --bg-card:       #ffffff;
    --bg-card-hover: #f5f5f0;
    --accent:        #3D7A00;
    --accent-dark:   #2d5c00;
    --accent-glow:   rgba(61,122,0,0.12);
    --text-primary:  #1a1a1a;
    --text-secondary:#555566;
    --text-muted:    #888899;
    --border:        rgba(0,0,0,0.08);
    --border-accent: rgba(61,122,0,0.3);
    --shadow:        0 4px 24px rgba(0,0,0,0.08);
    --shadow-accent: 0 4px 32px rgba(61,122,0,0.12);
}

/* ── Reset & Base ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--text-primary);
    background-color: var(--bg-primary);
    transition: background-color var(--transition), color var(--transition);
    overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--accent); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--accent-dark); }

/* ── Typographie ─────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-title);
    font-weight: 700;
    line-height: 1.2;
    color: var(--text-primary);
}

h1 { font-size: clamp(2.2rem, 5vw, 4rem); }
h2 { font-size: clamp(1.8rem, 4vw, 2.8rem); }
h3 { font-size: clamp(1.3rem, 3vw, 1.8rem); }
h4 { font-size: 1.2rem; }

p { color: var(--text-secondary); margin-bottom: 1rem; }

/* ── Layout ──────────────────────────────────────────────── */
.webi-container {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 24px;
}

.webi-main {
    min-height: 100vh;
    padding-top: var(--header-h);
}

.webi-section {
    padding: 96px 0;
}

.webi-section--sm {
    padding: 64px 0;
}

/* ── Header ──────────────────────────────────────────────── */
.webi-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    height: var(--header-h);
    z-index: 1000;
    background: var(--bg-primary);
    border-bottom: 1px solid var(--border);
    transition: background var(--transition), border-color var(--transition);
}

.webi-header.scrolled {
    background: rgba(6, 6, 8, 0.95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

[data-theme="light"] .webi-header.scrolled {
    background: rgba(240, 238, 230, 0.95);
}

.webi-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 24px;
}

/* Logo */
.webi-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-title);
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--text-primary);
    text-decoration: none;
}

.webi-logo span {
    color: var(--accent);
}

/* Nav desktop */
.webi-nav {
    display: flex;
    align-items: center;
    gap: 8px;
}

.webi-nav__link {
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--text-secondary);
    padding: 8px 14px;
    border-radius: var(--radius-sm);
    transition: color var(--transition), background var(--transition);
    text-decoration: none;
}

.webi-nav__link:hover,
.webi-nav__link.active {
    color: var(--text-primary);
    background: var(--border);
}

/* Actions header */
.webi-header__actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* Toggle dark/light */
.webi-theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all var(--transition);
    font-size: 1.1rem;
}

.webi-theme-toggle:hover {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--accent-glow);
}

/* Burger mobile */
.webi-burger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 40px;
    height: 40px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: transparent;
    cursor: pointer;
    padding: 8px;
}

.webi-burger span {
    display: block;
    height: 2px;
    background: var(--text-primary);
    border-radius: 2px;
    transition: all var(--transition);
}

.webi-burger.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.webi-burger.active span:nth-child(2) { opacity: 0; }
.webi-burger.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* Menu mobile */
.webi-nav-mobile {
    display: none;
    position: fixed;
    top: var(--header-h);
    left: 0; right: 0;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
    padding: 24px;
    flex-direction: column;
    gap: 4px;
    z-index: 999;
}

.webi-nav-mobile.open { display: flex; }

.webi-nav-mobile__link {
    font-size: 1rem;
    font-weight: 500;
    color: var(--text-secondary);
    padding: 12px 16px;
    border-radius: var(--radius-sm);
    text-decoration: none;
    transition: all var(--transition);
}

.webi-nav-mobile__link:hover {
    color: var(--text-primary);
    background: var(--border);
}

/* ── Boutons ──────────────────────────────────────────────── */
.webi-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: all var(--transition);
    text-decoration: none;
    white-space: nowrap;
}

.webi-btn--primary {
    background: var(--accent);
    color: #060608;
}

.webi-btn--primary:hover {
    background: var(--accent-dark);
    color: #060608;
    transform: translateY(-1px);
    box-shadow: var(--shadow-accent);
}

.webi-btn--secondary {
    background: transparent;
    color: var(--text-primary);
    border: 1px solid var(--border);
}

.webi-btn--secondary:hover {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--accent-glow);
}

.webi-btn--lg {
    padding: 16px 32px;
    font-size: 1rem;
    border-radius: var(--radius-md);
}

.webi-btn--sm {
    padding: 8px 16px;
    font-size: 0.85rem;
}

/* ── Cards ───────────────────────────────────────────────── */
.webi-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 32px;
    transition: all var(--transition);
}

.webi-card:hover {
    background: var(--bg-card-hover);
    border-color: var(--border-accent);
    transform: translateY(-4px);
    box-shadow: var(--shadow);
}

.webi-card--accent {
    border-color: var(--accent);
    background: var(--accent-glow);
}

/* ── Badges ──────────────────────────────────────────────── */
.webi-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: 100px;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.webi-badge--accent {
    background: var(--accent-glow);
    color: var(--accent);
    border: 1px solid var(--border-accent);
}

.webi-badge--muted {
    background: var(--border);
    color: var(--text-muted);
}

/* ── Grilles ─────────────────────────────────────────────── */
.webi-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.webi-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.webi-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }

/* ── Accent line (titre décoratif) ───────────────────────── */
.webi-section__label {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.webi-section__label::before {
    content: '';
    display: block;
    width: 32px;
    height: 2px;
    background: var(--accent);
    border-radius: 2px;
}

.webi-section__label span {
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--accent);
}

/* ── Footer ──────────────────────────────────────────────── */
.webi-footer {
    background: var(--bg-secondary);
    border-top: 1px solid var(--border);
    padding: 64px 0 32px;
}

.webi-footer__grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 48px;
    margin-bottom: 48px;
}

.webi-footer__brand p {
    font-size: 0.9rem;
    color: var(--text-muted);
    margin-top: 12px;
    max-width: 280px;
}

.webi-footer__col h4 {
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 16px;
}

.webi-footer__col a {
    display: block;
    font-size: 0.9rem;
    color: var(--text-secondary);
    padding: 4px 0;
    text-decoration: none;
    transition: color var(--transition);
}

.webi-footer__col a:hover { color: var(--accent); }

.webi-footer__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 24px;
    border-top: 1px solid var(--border);
    font-size: 0.85rem;
    color: var(--text-muted);
}

/* ── Bandeau cookies RGPD ────────────────────────────────── */
.webi-cookie-banner {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 9999;
    background: var(--bg-card);
    border-top: 1px solid var(--border);
    padding: 20px 24px;
    display: none;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    box-shadow: 0 -4px 24px rgba(0,0,0,0.3);
}

.webi-cookie-banner.visible { display: flex; }

.webi-cookie-banner__text {
    font-size: 0.88rem;
    color: var(--text-secondary);
    max-width: 700px;
}

.webi-cookie-banner__text a {
    color: var(--accent);
    text-decoration: underline;
}

.webi-cookie-banner__actions {
    display: flex;
    gap: 12px;
    flex-shrink: 0;
}

/* ── Formulaires ─────────────────────────────────────────── */
.webi-form__group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 20px;
}

.webi-form__label {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.webi-form__input,
.webi-form__select,
.webi-form__textarea {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px 16px;
    font-family: var(--font-body);
    font-size: 0.95rem;
    color: var(--text-primary);
    transition: border-color var(--transition);
    width: 100%;
}

.webi-form__input:focus,
.webi-form__select:focus,
.webi-form__textarea:focus {
    outline: none;
    border-color: var(--accent);
}

.webi-form__textarea { resize: vertical; min-height: 120px; }

/* ── Utilitaires ─────────────────────────────────────────── */
.text-center  { text-align: center; }
.text-accent  { color: var(--accent); }
.text-muted   { color: var(--text-muted); }
.mt-0  { margin-top: 0; }
.mb-0  { margin-bottom: 0; }
.mb-8  { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }
.mb-32 { margin-bottom: 32px; }
.mb-48 { margin-bottom: 48px; }
.mb-64 { margin-bottom: 64px; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
    .webi-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .webi-footer__grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}

@media (max-width: 768px) {
    .webi-nav { display: none; }
    .webi-burger { display: flex; }
    .webi-grid-2,
    .webi-grid-3,
    .webi-grid-4 { grid-template-columns: 1fr; }
    .webi-section { padding: 64px 0; }
    .webi-footer__grid { grid-template-columns: 1fr; gap: 24px; }
    .webi-footer__bottom { flex-direction: column; gap: 12px; text-align: center; }
    .webi-cookie-banner { flex-direction: column; align-items: flex-start; }
    .webi-cookie-banner__actions { width: 100%; }
    .webi-cookie-banner__actions .webi-btn { flex: 1; justify-content: center; }
}

@media (max-width: 480px) {
    .webi-container { padding: 0 16px; }
    .webi-header__inner { padding: 0 16px; }
    h1 { font-size: 1.9rem; }
    h2 { font-size: 1.6rem; }
}

/* Nav link CTA (Audit gratuit) */
.webi-nav__link--cta {
    background: var(--accent-glow);
    color: var(--accent) !important;
    border: 1px solid var(--border-accent);
    border-radius: var(--radius-sm);
}

.webi-nav__link--cta:hover {
    background: var(--accent);
    color: #060608 !important;
    border-color: var(--accent);
}
/* ── Hero ────────────────────────────────────────────────── */
.hero { padding-top: calc(var(--header-h) + 64px); padding-bottom: 80px; }

.hero-content__badges {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 24px;
}

.hero-content__title { margin-bottom: 20px; }

.hero-content__subtitle {
    font-size: 1.05rem;
    color: var(--text-secondary);
    max-width: 600px;
    margin-bottom: 28px;
    line-height: 1.7;
}

.hero-content__targets {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 32px;
}

.hero-target {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 8px 14px;
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--text-secondary);
}

.hero-target__icon { font-size: 1rem; }

.hero-content__actions {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 24px;
}

.hero-content__trust {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.hero-content__trust span {
    font-size: 0.82rem;
    color: var(--text-muted);
}

.hero-social-proof {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

/* ── Statistiques ────────────────────────────────────────── */
.statistiques { background: var(--bg-secondary); }

.statistiques__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

.stat-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: border-color var(--transition);
}

.stat-card--plugin {
    border-color: var(--border-accent);
    grid-column: span 1;
}

.stat-card:hover { border-color: var(--border-accent); }

.stat-card__visual {
    display: flex;
    align-items: baseline;
    gap: 4px;
}

.stat-card__num {
    font-family: var(--font-title);
    font-size: 2.8rem;
    font-weight: 800;
    color: var(--accent);
    line-height: 1;
    transition: color 0.1s ease;
}

.stat-card__unit {
    font-family: var(--font-title);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-muted);
}

.stat-card__info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.stat-card__info strong {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--text-primary);
}

.stat-card__info span {
    font-size: 0.78rem;
    color: var(--text-muted);
    line-height: 1.4;
}

/* Barre plugin rouge→vert */
.stat-card__scale {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
}

.stat-scale__label {
    font-size: 0.7rem;
    white-space: nowrap;
}

.stat-scale__bar {
    flex: 1;
    height: 6px;
    background: var(--border);
    border-radius: 3px;
    overflow: hidden;
}

.stat-scale__fill {
    height: 100%;
    background: #FF4444;
    border-radius: 3px;
    transition: width 0.1s ease, background-color 0.1s ease;
}

/* ── Références ──────────────────────────────────────────── */
.references { background: var(--bg-secondary); border-top: 1px solid var(--border); }

.references__label {
    text-align: center;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--text-muted);
    margin-bottom: 28px;
}

.references__logos {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 32px;
    flex-wrap: wrap;
}

.reference-logo {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    opacity: 0.5;
    transition: opacity var(--transition);
    cursor: default;
}

.reference-logo:hover { opacity: 1; }

.reference-logo__placeholder {
    width: 56px;
    height: 56px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-title);
    font-size: 1rem;
    font-weight: 800;
    color: var(--text-muted);
}

.reference-logo span {
    font-size: 0.75rem;
    color: var(--text-muted);
}

/* ── Tools ───────────────────────────────────────────────── */
.tools-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.tool-card {
    display: flex;
    flex-direction: column;
    gap: 14px;
    text-decoration: none;
}

.tool-card__header {
    display: flex;
    align-items: flex-start;
    gap: 14px;
}

.tool-card__icon { font-size: 1.8rem; flex-shrink: 0; }

.tool-card__header > div {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.tool-card__nom { font-size: 1.1rem; margin: 0; }
.tool-card__agent { font-size: 0.72rem; }
.tool-card__desc { font-size: 0.85rem; flex: 1; margin: 0; color: var(--text-secondary); line-height: 1.6; }

.tool-card__kpi {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-muted);
    margin-top: auto;
    padding-top: 12px;
    border-top: 1px solid var(--border);
}

/* ── Pricing ─────────────────────────────────────────────── */
.abonnements-pricing { background: var(--bg-primary); }

.pricing-container {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    align-items: start;
}

.pricing-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 28px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    transition: all var(--transition);
    position: relative;
}

.pricing-card:hover {
    border-color: var(--border-accent);
    transform: translateY(-4px);
    box-shadow: var(--shadow);
}

.pricing-card--featured {
    border-color: var(--accent);
    background: var(--accent-glow);
    transform: translateY(-8px);
}

.pricing-card--featured:hover { transform: translateY(-12px); }

.pricing-badge { text-align: center; }

.pricing-header-card__nom {
    font-size: 1.2rem;
    margin: 0 0 6px;
}

.pricing-header-card__tagline {
    font-size: 0.82rem;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.4;
}

.pricing-price-container {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.pricing-price-container__barre {
    font-size: 0.88rem;
    color: var(--text-muted);
    text-decoration: line-through;
}

.pricing-price-container__prix {
    font-family: var(--font-title);
    font-size: 2rem;
    font-weight: 800;
    color: var(--text-primary);
    line-height: 1;
}

.pricing-price-container__hebergement {
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-top: 4px;
}

.pricing-features {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}

.pricing-feature {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 0.83rem;
    line-height: 1.4;
}

.pricing-feature--inclus { color: var(--text-primary); }
.pricing-feature--exclu  { color: var(--text-muted); }

.pricing-feature__icon { flex-shrink: 0; font-size: 0.85rem; margin-top: 1px; }
.pricing-feature--inclus .pricing-feature__icon { color: var(--accent); }
.pricing-feature--exclu  .pricing-feature__icon { color: var(--text-muted); }

.pricing-brief {
    text-align: center;
    border-top: 1px solid var(--border);
    padding-top: 16px;
}

.pricing-brief__link {
    font-size: 0.8rem;
    color: var(--text-muted);
    text-decoration: none;
    transition: color var(--transition);
}

.pricing-brief__link:hover { color: var(--accent); }

/* ── Benefits ────────────────────────────────────────────── */
.benefits { background: var(--bg-secondary); }

.benefits-case-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.benefits-case__icon  { font-size: 2rem; display: block; margin-bottom: 12px; }
.benefits-case__titre { font-size: 0.95rem; margin: 0 0 8px; }
.benefits-case__desc  { font-size: 0.85rem; margin: 0; line-height: 1.6; }

/* ── Use cases ───────────────────────────────────────────── */
.use-case-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.use-case { display: flex; flex-direction: column; gap: 12px; }
.use-case__icon  { font-size: 2rem; }
.use-case__titre { font-size: 1rem; margin: 0; }
.use-case__desc  { font-size: 0.85rem; margin: 0; flex: 1; line-height: 1.6; }

.use-case__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
    flex-wrap: wrap;
}

.use-case__link {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--accent);
    text-decoration: none;
}

/* ── Testimonials ────────────────────────────────────────── */
.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.testimonial { display: flex; flex-direction: column; gap: 14px; }
.testimonial__stars { font-size: 0.88rem; }
.testimonial__texte { font-size: 0.88rem; font-style: italic; flex: 1; margin: 0; line-height: 1.6; }

.testimonial__auteur {
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-top: 1px solid var(--border);
    padding-top: 12px;
}

.testimonial__auteur strong { font-size: 0.88rem; }
.testimonial__auteur span   { font-size: 0.78rem; }

/* ── CTA Section ─────────────────────────────────────────── */
.cta-section { background: var(--bg-secondary); }
.cta-section__inner { max-width: 640px; margin: 0 auto; }

/* ── FAQ ─────────────────────────────────────────────────── */
.faq { background: var(--bg-primary); }

.faq__item { border-bottom: 1px solid var(--border); }

.faq__question {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 0;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-primary);
    transition: color var(--transition);
}

.faq__question:hover { color: var(--accent); }

.faq__icon {
    font-size: 1.4rem;
    font-weight: 300;
    color: var(--accent);
    flex-shrink: 0;
}

.faq__answer { padding: 0 0 20px; }
.faq__answer p { font-size: 0.9rem; line-height: 1.7; margin: 0; }

/* ── CGPT CTA ────────────────────────────────────────────── */
.cgpt-cta-section { background: var(--bg-secondary); }

.cgpt-cta__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 48px;
    background: var(--bg-card);
    border: 1px solid var(--border-accent);
    border-radius: var(--radius-xl);
    padding: 48px;
}

.cgpt-cta__text h3 { font-size: 1.5rem; margin-bottom: 10px; }
.cgpt-cta__text p  { font-size: 0.9rem; margin: 0; }

.cgpt-cta__actions {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    flex-shrink: 0;
    min-width: 200px;
}
.faq-footer { background: var(--bg-secondary); }

.faq-footer__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    padding: 40px 48px;
    flex-wrap: wrap;
}

.faq-footer__text h3 { font-size: 1.3rem; margin-bottom: 8px; }
.faq-footer__text p  { font-size: 0.9rem; margin: 0; }

.faq-footer__actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 10px;
    flex-shrink: 0;
}

.faq-form__mention {
    font-size: 0.78rem;
    color: var(--text-muted);
}

@media (max-width: 768px) {
    .faq-footer__inner { flex-direction: column; padding: 32px 24px; }
    .faq-footer__actions { align-items: flex-start; width: 100%; }
    .faq-footer__actions .webi-btn { width: 100%; justify-content: center; }
}
/* ── Responsive global ───────────────────────────────────── */
@media (max-width: 1100px) {
    .pricing-container   { grid-template-columns: repeat(2, 1fr); }
    .pricing-card--featured { transform: none; }
    .statistiques__grid  { grid-template-columns: repeat(2, 1fr); }
    .tools-grid          { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .hero { padding-top: calc(var(--header-h) + 40px); padding-bottom: 48px; }
    .hero-content__actions { flex-direction: column; }
    .hero-content__actions .webi-btn { width: 100%; justify-content: center; }
    .pricing-container   { grid-template-columns: 1fr; }
    .tools-grid          { grid-template-columns: 1fr; }
    .benefits-case-grid  { grid-template-columns: 1fr; }
    .use-case-grid       { grid-template-columns: 1fr; }
    .testimonials-grid   { grid-template-columns: 1fr; }
    .statistiques__grid  { grid-template-columns: 1fr 1fr; }
    .cgpt-cta__inner     { flex-direction: column; text-align: center; padding: 32px 24px; }
    .cgpt-cta__actions   { width: 100%; }
}

@media (max-width: 480px) {
    .statistiques__grid  { grid-template-columns: 1fr; }
    .references__logos   { gap: 20px; }
    .hero-content__trust { gap: 12px; }
}