/**
 * Composants UI partagés — BT Med (Clinical Tech V2).
 *
 * Tokens : assets/css/tokens.css.
 * Header  : assets/css/header.css.
 * Pages  : assets/css/page-{slug}.css.
 *
 * Ce fichier rassemble les composants utilisés par ≥3 templates SEO :
 *   - Hero atmosphère (light beam, grain, glow corners)
 *   - Hero specs bandeau (sous le H1, sur fond navy)
 *   - Keyframes d'animation hero (beam-drift, glow1/glow2, hero-title-in, hfade, hero-el-in)
 *
 * Chargé après tokens.css et avant les page-*.css. Un template peut
 * redéfinir un keyframe localement (ex. fiche-produit utilise des glows
 * en translation au lieu de scale) — la dernière déclaration gagne.
 *
 * prefers-reduced-motion : géré globalement par tokens.css qui désactive
 * toutes les animations (transition-duration: 0.01ms !important). Pas
 * besoin d'override par composant.
 */

/* ===========================================================
 * Hero atmosphère — fond animé sur sections sombres
 *
 * Pattern Mediostar : un beam diagonal qui drifte, deux glows
 * radiaux d'angle, un grain SVG qui fixe la lumière. Bornés au
 * hero (cf. DESIGN.md §4 Règle des Glows Bornés).
 * =========================================================== */

.hero__light-beam {
    position: absolute;
    top: -50%;
    left: -20%;
    width: 70%;
    height: 200%;
    z-index: var(--z-pop);
    background: linear-gradient(115deg,
        transparent 35%,
        rgba(77, 143, 255, 0.10) 47%,
        rgba(77, 143, 255, 0.17) 50%,
        rgba(77, 143, 255, 0.10) 53%,
        transparent 65%);
    transform: rotate(-12deg);
    pointer-events: none;
    animation: beam-drift 20s ease-in-out infinite alternate;
}

.hero__grain {
    position: absolute;
    inset: 0;
    z-index: var(--z-overlay);
    opacity: 0.05;
    mix-blend-mode: overlay;
    pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='hg'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23hg)'/%3E%3C/svg%3E");
}

.hero__glow {
    position: absolute;
    z-index: var(--z-pop);
    border-radius: 50%;
    pointer-events: none;
    filter: blur(120px);
}

.hero__glow--top-left {
    top: -200px;
    left: -200px;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(30, 91, 217, 0.25) 0%, transparent 70%);
    animation: glow1 12s ease-in-out infinite alternate;
}

.hero__glow--bottom-right {
    bottom: -300px;
    right: -200px;
    width: 800px;
    height: 800px;
    background: radial-gradient(circle, rgba(77, 143, 255, 0.18) 0%, transparent 70%);
    animation: glow2 15s ease-in-out infinite alternate;
}

/* ===========================================================
 * Hero specs bandeau (sous le H1 du hero, fond navy)
 *
 * Cf. DESIGN.md §5 « Hero Specs Bar ». Eyebrow mono cyan, valeur
 * Inter 600 clamp, séparateurs verticaux 1px, wrap responsive
 * sur mobile.
 * =========================================================== */

.hero__specs {
    display: flex;
    align-items: center;
    gap: clamp(24px, 3vw, 48px);
    padding-top: var(--space-7);
    margin-top: var(--space-5);
    border-top: 1px solid rgba(255, 255, 255, 0.10);
}

.hero-spec {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex-shrink: 0;
}

.hero-spec__label {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.50);
    white-space: nowrap;
}

.hero-spec__value {
    font-size: clamp(20px, 2.2vw, 30px);
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1;
    color: var(--color-white);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}

.hero-spec__unit {
    font-size: 0.5em;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.60);
    margin-left: 4px;
}

.hero-spec__divider {
    width: 1px;
    height: 36px;
    background: rgba(255, 255, 255, 0.12);
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .hero__specs       { flex-wrap: wrap; gap: var(--space-5); }
    .hero-spec__value  { font-size: 20px; }
    .hero-spec__divider { display: none; }
}

/* ===========================================================
 * Keyframes d'animation hero (réutilisés par les 5 templates SEO)
 *
 * Un template peut redéfinir l'un de ces keyframes localement
 * (ex. fiche-produit utilise des glows en translate au lieu de
 * scale). La dernière déclaration en cascade gagne.
 * =========================================================== */

@keyframes beam-drift {
    from { opacity: 0.6; transform: rotate(-12deg) translateX(0); }
    to   { opacity: 1;   transform: rotate(-12deg) translateX(60px); }
}

@keyframes glow1 {
    from { opacity: 0.6; transform: scale(1);   }
    to   { opacity: 1;   transform: scale(1.2); }
}

@keyframes glow2 {
    from { opacity: 0.5; transform: scale(1);    }
    to   { opacity: 0.9; transform: scale(1.15); }
}

@keyframes hero-title-in {
    from { opacity: 0; transform: translateY(32px); clip-path: inset(0 0 100% 0); }
    to   { opacity: 1; transform: translateY(0);    clip-path: inset(0 0 0% 0);   }
}

@keyframes hero-element-in {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0);    }
}

/* Alias court (utilisé par hub-categorie, hub-cat). */
@keyframes hero-el-in {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0);    }
}

@keyframes hfade {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* Why: animer transform: scale + filter:blur force la re-rasterisation du blur à chaque frame. */
@keyframes aura-pulse {
    0%, 100% { opacity: 0.6; }
    50%      { opacity: 1; }
}
@keyframes hero-zoom {
    from { transform: scale(1.05); opacity: 0; }
    to   { transform: scale(1);    opacity: 1; }
}
@keyframes bar-grow {
    from { transform: scaleX(0); }
    to   { transform: scaleX(1); }
}

/* Btn scopé pages produit/sous-cat (15px Inter, padding 14×28, pill). */
.pmed-page .btn,
.scld-page .btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Inter', sans-serif;
    font-size: 15px;
    font-weight: 600;
    border-radius: var(--radius-pill);
    padding: 14px 28px;
    cursor: pointer;
    border: 0;
    white-space: nowrap;
    transition:
        background var(--dur-state) var(--ease-out),
        transform 150ms var(--ease-out),
        box-shadow var(--dur-state) var(--ease-out),
        color var(--dur-state) var(--ease-out),
        border-color var(--dur-state) var(--ease-out);
}
.pmed-page .btn--lg,
.scld-page .btn--lg { padding: 16px 32px; font-size: 16px; }
.pmed-page .btn--primary,
.scld-page .btn--primary { background: var(--color-blue); color: #fff; }
.pmed-page .btn--primary:hover,
.scld-page .btn--primary:hover {
    background: var(--color-blue-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-blue-glow);
}
.pmed-page .btn--ghost,
.scld-page .btn--ghost {
    background: transparent;
    color: #fff;
    border: 1.5px solid rgba(255, 255, 255, 0.32);
}
.pmed-page .btn--ghost:hover,
.scld-page .btn--ghost:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.6);
}

/* Eyebrow scopé pages produit/sous-cat (cyan-tech mono + barre 32×1px). */
.pmed-page .eyebrow,
.scld-page .eyebrow {
    font-family: 'JetBrains Mono', Menlo, Consolas, monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-cyan-tech);
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin: 0 0 18px;
}
.pmed-page .eyebrow::before,
.scld-page .eyebrow::before {
    content: '';
    width: 32px;
    height: 1px;
    background: currentColor;
    flex-shrink: 0;
}
.pmed-page .eyebrow--light,
.scld-page .eyebrow--light {
    font-family: 'Inter', sans-serif;
    letter-spacing: 0.16em;
    color: var(--color-blue);
}

/* ===========================================================
 * Cat Hero — pattern partagé hub + sous-catégorie (DESIGN.md §5)
 * Section pleine largeur sombre avec bg image + grid overlay,
 * pill catégorie / prix en haut, H1 + lead + actions à gauche,
 * keyspecs en grille 2×2 à droite.
 * =========================================================== */

.cat-hero {
    position: relative;
    background: var(--color-navy-deepest);
    color: var(--color-text-on-dark);
    overflow: hidden;
    min-height: 640px;
    display: flex;
    align-items: flex-end;
    padding: clamp(72px, 8vw, 112px) 0 clamp(56px, 6vw, 88px);
}

/* Variante compacte pour pages contenu (contact, légal, RGPD…) */
.cat-hero--page {
    min-height: auto;
    padding: clamp(48px, 6vw, 80px) 0 clamp(32px, 4vw, 56px);
    align-items: flex-start;
}
.cat-hero--page .cat-hero__top { margin-bottom: clamp(24px, 3vw, 40px); }
.cat-hero--page .cat-hero__title { font-size: clamp(32px, 4vw, 52px); margin-bottom: 16px; }
.cat-hero--page .cat-hero__lead { margin-bottom: 0; }
.cat-hero--page .cat-hero__split { grid-template-columns: minmax(0, 1fr) minmax(0, 320px); gap: clamp(32px, 4vw, 64px); align-items: start; }
.cat-hero--page .cat-hero__keyspecs { padding: 16px 0; }
@media (max-width: 900px) {
    .cat-hero--page .cat-hero__split { grid-template-columns: 1fr; }
}
.cat-hero__bg { position: absolute; inset: 0; z-index: var(--z-base); }
.cat-hero__bg-img {
    width: 100%; height: 100%;
    object-fit: cover; object-position: right center;
    opacity: 0.42;
}
.cat-hero__bg-shade {
    position: absolute; inset: 0;
    background: linear-gradient(180deg,
        rgb(var(--rgb-navy-deepest) / 0.72) 0%,
        rgb(var(--rgb-navy-deepest) / 0.45) 60%,
        rgb(var(--rgb-navy-deepest) / 0.92) 100%);
}
.cat-hero__grid-overlay {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgb(var(--rgb-blue-electric) / 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgb(var(--rgb-blue-electric) / 0.05) 1px, transparent 1px);
    background-size: 80px 80px;
    mask-image: radial-gradient(ellipse at 70% 40%, var(--color-navy-deepest) 25%, transparent 70%);
    pointer-events: none;
}
.cat-hero__inner { position: relative; z-index: var(--z-float); width: 100%; }
.cat-hero__top {
    display: flex; justify-content: space-between; gap: 24px;
    margin-bottom: clamp(56px, 7vw, 96px);
    align-items: flex-start;
    flex-wrap: wrap;
}
.cat-hero__pill {
    display: inline-flex; align-items: center; gap: 14px;
    background: rgb(var(--rgb-on-dark) / 0.06);
    border: 1px solid rgb(var(--rgb-on-dark) / 0.12);
    border-radius: var(--radius-pill);
    padding: 8px 18px 8px 8px;
    font-size: 12px;
    color: rgb(var(--rgb-on-dark) / 0.85);
}
.cat-hero__pill-badge {
    background: var(--color-blue);
    color: var(--color-white);
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px; font-weight: 600;
    letter-spacing: 0.14em;
    padding: 4px 10px;
    border-radius: var(--radius-pill);
}
.cat-hero__pill-title { color: var(--color-text-on-dark); font-weight: 600; }
.cat-hero__pill-meta  { color: rgb(var(--rgb-on-dark) / 0.55); }
.cat-hero__price {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: rgb(var(--rgb-on-dark) / 0.55);
    display: flex; align-items: center; gap: 10px;
}
.cat-hero__price b { color: var(--color-cyan-tech); font-weight: 600; }
.cat-hero__title {
    font-family: 'Inter', sans-serif;
    font-size: clamp(40px, 5vw, 68px);
    font-weight: 600;
    line-height: 1.02;
    letter-spacing: -0.035em;
    margin: 0 0 24px;
    text-wrap: balance;
    max-width: 18ch;
    color: var(--color-text-on-dark);
}
.cat-hero__title em {
    font-style: normal;
    color: var(--color-blue-electric);
}
.cat-hero__split {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    gap: clamp(40px, 5vw, 80px);
    align-items: end;
}
.cat-hero__lead {
    font-size: clamp(16px, 1.2vw, 19px);
    color: rgb(var(--rgb-on-dark) / 0.78);
    line-height: 1.55;
    max-width: 52ch;
    margin: 0 0 24px;
}
.cat-hero__actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.cat-hero__keyspecs {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
    border-top: 1px solid rgb(var(--rgb-on-dark) / 0.1);
    border-bottom: 1px solid rgb(var(--rgb-on-dark) / 0.1);
    padding: 22px 0;
}
.cat-hero__keyspec { padding: 0 24px 0 0; border-right: 1px solid rgb(var(--rgb-on-dark) / 0.08); }
.cat-hero__keyspec:nth-child(2n) { border-right: 0; padding-left: 24px; padding-right: 0; }
.cat-hero__keyspec-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px; font-weight: 600;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--color-cyan-tech);
    display: block; margin-bottom: 6px;
}
.cat-hero__keyspec-value {
    font-size: clamp(20px, 1.7vw, 26px); font-weight: 600;
    color: var(--color-text-on-dark); letter-spacing: -0.015em;
    font-variant-numeric: tabular-nums;
    line-height: 1.1;
}
.cat-hero__keyspec-value sup {
    font-size: 0.5em;
    color: rgb(var(--rgb-on-dark) / 0.6);
    margin-left: 2px;
    vertical-align: 0.5em;
    font-weight: 500;
}
@media (max-width: 900px) {
    .cat-hero__split { grid-template-columns: 1fr; }
    .cat-hero__keyspecs { grid-template-columns: 1fr 1fr; }
}

/* ===========================================================
 * Page content — body V3 pour pages institutionnelles
 * (legal, contact, RGPD…). Inter, navy ink, sections espacées,
 * dl/dt/dd alignés en colonnes mono-cyan-on-light.
 * =========================================================== */

.page-content {
    max-width: 65ch;
    margin: 0 auto;
}
.page-content > * + * { margin-top: clamp(40px, 5vw, 72px); }
.page-content > *:first-child { margin-top: 0; }

.page-section { scroll-margin-top: 96px; }
.page-section > * + * { margin-top: 16px; }
.page-section h2 {
    font-family: 'Inter', sans-serif;
    font-size: clamp(22px, 2.4vw, 30px);
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.15;
    color: var(--color-text-primary);
    margin: 0 0 8px;
}
.page-section h3 {
    font-family: 'Inter', sans-serif;
    font-size: clamp(17px, 1.6vw, 20px);
    font-weight: 600;
    letter-spacing: -0.015em;
    color: var(--color-text-primary);
    margin: 0;
}
.page-section p {
    font-size: 15px;
    line-height: 1.7;
    color: var(--color-text-body);
    max-width: 65ch;
}
.page-section p strong { color: var(--color-text-primary); font-weight: 600; }
.page-section a {
    color: var(--color-blue);
    text-decoration: none;
    border-bottom: 1px solid rgba(30, 91, 217, 0.25);
    transition: border-color 200ms;
}
.page-section a:hover { border-bottom-color: var(--color-blue); }

/* Liste à puce bleue, lecture longue */
.page-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.page-list li {
    position: relative;
    padding-left: 18px;
    font-size: 15px;
    line-height: 1.7;
    color: var(--color-text-body);
}
.page-list li::before {
    content: '';
    position: absolute;
    left: 0; top: 11px;
    width: 5px; height: 5px;
    border-radius: 50%;
    background: var(--color-blue);
}
.page-list strong { color: var(--color-text-primary); font-weight: 600; }

/* Spec list — dl avec dt mono cyan / dd navy primary, grille 2 colonnes */
.spec-list {
    display: grid;
    gap: 14px 24px;
    grid-template-columns: minmax(150px, 200px) 1fr;
    border-top: 1px solid var(--color-border-light);
    padding-top: 24px;
}
.spec-list dt {
    font-family: 'JetBrains Mono', Menlo, Consolas, monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    align-self: center;
    margin: 0;
}
.spec-list dd {
    font-size: 15px;
    color: var(--color-text-primary);
    margin: 0;
    align-self: center;
}
.spec-list dd a {
    color: var(--color-blue);
    text-decoration: none;
    border-bottom: 1px solid rgba(30, 91, 217, 0.25);
}
@media (max-width: 600px) {
    .spec-list { grid-template-columns: 1fr; gap: 4px 0; }
    .spec-list dt { font-size: 10px; margin-top: 8px; }
}

/* Note de bas de page (contact, mise à jour, etc.) */
.page-footnote {
    border-top: 1px solid var(--color-border-light);
    padding-top: 24px;
    font-size: 13px;
    color: var(--color-text-muted);
    line-height: 1.6;
}
.page-footnote a {
    color: var(--color-blue);
    text-decoration: none;
    border-bottom: 1px solid rgba(30, 91, 217, 0.25);
}

/* ===========================================================
 * Form V3 — formulaires institutionnels (contact, mise en
 * relation, démo). Inputs bordés, labels mono cyan-on-light
 * navy, focus bleu signature, radio/checkbox customs.
 * =========================================================== */

.v3-form {
    display: flex;
    flex-direction: column;
    gap: 28px;
}
.v3-form__head { display: flex; flex-direction: column; gap: 10px; max-width: 55ch; }
.v3-form__head .eyebrow { color: var(--color-blue); margin: 0; }
.v3-form__head h2 {
    font-family: 'Inter', sans-serif;
    font-size: clamp(24px, 2.6vw, 32px);
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.15;
    color: var(--color-text-primary);
    margin: 0;
    text-wrap: balance;
}
.v3-form__intro {
    font-size: 14px;
    color: var(--color-text-body);
    line-height: 1.65;
    margin: 0;
    max-width: 55ch;
}

/* Grille de champs */
.v3-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px 24px;
}
.v3-form__grid--full { grid-template-columns: 1fr; }
.v3-form__field--full { grid-column: 1 / -1; }
@media (max-width: 600px) {
    .v3-form__grid { grid-template-columns: 1fr; }
}

/* Champ standard */
.v3-form__field { display: flex; flex-direction: column; gap: 8px; }
.v3-form__label {
    font-family: 'JetBrains Mono', Menlo, Consolas, monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin: 0;
}
.v3-form__label .req { color: var(--color-blue); margin-left: 2px; }

.v3-form__input,
.v3-form__textarea,
.v3-form__select {
    width: 100%;
    background: #fff;
    border: 1px solid var(--color-border-medium);
    border-radius: var(--radius-md);
    padding: 12px 14px;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 15px;
    line-height: 1.4;
    color: var(--color-text-primary);
    transition: border-color 200ms var(--ease-out), box-shadow 200ms var(--ease-out);
    -webkit-appearance: none;
    appearance: none;
}
.v3-form__input::placeholder,
.v3-form__textarea::placeholder { color: var(--color-text-muted); }
.v3-form__input:hover,
.v3-form__textarea:hover,
.v3-form__select:hover { border-color: rgba(11, 25, 54, 0.25); }
.v3-form__input:focus,
.v3-form__textarea:focus,
.v3-form__select:focus {
    outline: 0;
    border-color: var(--color-blue);
    box-shadow: 0 0 0 3px rgba(30, 91, 217, 0.12);
}
.v3-form__textarea { resize: vertical; min-height: 120px; }

.v3-form__select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235A6B85' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 38px;
}

/* Radios alignés en ligne */
.v3-form__radios {
    display: flex;
    flex-wrap: wrap;
    gap: 16px 24px;
    align-items: center;
}
.v3-form__radio {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 15px;
    color: var(--color-text-primary);
}
.v3-form__radio input[type="radio"] {
    width: 18px;
    height: 18px;
    margin: 0;
    accent-color: var(--color-blue);
    cursor: pointer;
}

/* Checkbox consentement */
.v3-form__check {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    font-size: 13px;
    line-height: 1.55;
    color: var(--color-text-body);
    cursor: pointer;
}
.v3-form__check input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 2px 0 0;
    accent-color: var(--color-blue);
    flex-shrink: 0;
    cursor: pointer;
}
.v3-form__check a {
    color: var(--color-blue);
    text-decoration: none;
    border-bottom: 1px solid rgba(30, 91, 217, 0.25);
}

/* Helper text sous un champ */
.v3-form__hint {
    font-size: 12px;
    color: var(--color-text-muted);
    margin: 0;
    line-height: 1.5;
}

/* Actions footer */
.v3-form__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 16px 20px;
    align-items: center;
    margin-top: 8px;
}
.v3-form__actions .btn { font-size: 15px; }

.v3-form__submit-note {
    font-size: 12px;
    color: var(--color-text-muted);
    line-height: 1.55;
}

/* Bouton primaire form */
.v3-form button[type="submit"] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 15px;
    font-weight: 600;
    color: #fff;
    background: var(--color-blue);
    padding: 14px 28px;
    border: 0;
    border-radius: var(--radius-pill);
    cursor: pointer;
    white-space: nowrap;
    transition: background 200ms var(--ease-out), transform 150ms var(--ease-out), box-shadow 200ms var(--ease-out);
}
.v3-form button[type="submit"]:hover {
    background: var(--color-blue-hover);
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(30, 91, 217, 0.35);
}

/* ===========================================================
 * Shortcut grid — raccourcis post-erreur (404/410)
 * 4 cards V3 cliquables.
 * =========================================================== */
.bt-shortcuts {
    background: var(--color-cream);
    border-top: 1px solid var(--color-border-light);
    padding: clamp(56px, 7vw, 96px) 0;
}
.bt-shortcuts__head { max-width: 720px; margin: 0 auto clamp(40px, 5vw, 56px); }
.bt-shortcuts__head h2 {
    font-family: 'Inter', sans-serif;
    font-size: clamp(24px, 2.8vw, 34px);
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.15;
    color: var(--color-text-primary);
    margin: 12px 0 0;
    max-width: 24ch;
}
.bt-shortcuts__grid {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
@media (max-width: 900px) { .bt-shortcuts__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .bt-shortcuts__grid { grid-template-columns: 1fr; } }
.bt-shortcuts__grid li a {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 24px;
    background: #fff;
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    text-decoration: none;
    transition: border-color 280ms, transform 280ms var(--ease-out), box-shadow 280ms;
    height: 100%;
}
.bt-shortcuts__grid li a:hover {
    border-color: rgba(30, 91, 217, 0.25);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}
.bt-shortcuts__num {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-blue);
}
.bt-shortcuts__title {
    font-family: 'Inter', sans-serif;
    font-size: clamp(18px, 1.8vw, 20px);
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--color-text-primary);
    margin: 0;
}
.bt-shortcuts__desc {
    font-size: 13px;
    line-height: 1.6;
    color: var(--color-text-body);
    margin: 0;
    flex: 1;
}
.bt-shortcuts__cta {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-blue);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: auto;
    transition: gap 150ms;
}
.bt-shortcuts__grid li a:hover .bt-shortcuts__cta { gap: 10px; }

/* ===========================================================
 * Blog V3 — featured + liste paginée + corps article
 * (composants partagés blog-index, blog-categorie, articles).
 * =========================================================== */

/* Wrapper de page blog (post-hero) */
.bt-blog { padding: clamp(56px, 7vw, 96px) 0; background: var(--color-off-white); }

/* Featured (top page 1, layout split) */
.bt-blog-featured {
    display: grid;
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: clamp(32px, 5vw, 80px);
    align-items: center;
    margin-bottom: clamp(56px, 7vw, 96px);
}
@media (max-width: 900px) { .bt-blog-featured { grid-template-columns: 1fr; } }
.bt-blog-featured__visual {
    aspect-ratio: 16 / 10;
    background: var(--color-cream);
    border-radius: var(--radius-2xl);
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow-figure);
    color: var(--color-text-muted);
    font-size: 13px;
    font-style: italic;
    order: 2;
}
@media (max-width: 900px) { .bt-blog-featured__visual { order: 1; } }
.bt-blog-featured__copy { order: 1; }
@media (max-width: 900px) { .bt-blog-featured__copy { order: 2; } }
.bt-blog-featured__eyebrow {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-blue);
    margin: 0 0 14px;
}
.bt-blog-featured__title {
    font-family: 'Inter', sans-serif;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.1;
    color: var(--color-text-primary);
    margin: 0 0 16px;
    max-width: 22ch;
    text-wrap: balance;
}
.bt-blog-featured__title a { color: inherit; text-decoration: none; }
.bt-blog-featured__title a:hover { color: var(--color-blue); }
.bt-blog-featured__desc {
    font-size: 16px;
    line-height: 1.7;
    color: var(--color-text-body);
    max-width: 55ch;
    margin: 0 0 24px;
}
.bt-blog-featured__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 14px;
    font-size: 13px;
    color: var(--color-text-muted);
    margin: 0 0 20px;
    align-items: center;
}
.bt-blog-featured__meta span[aria-hidden] { color: var(--color-cream-deep); }
.bt-blog-featured__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Inter', sans-serif;
    font-size: 15px;
    font-weight: 600;
    color: var(--color-blue);
    text-decoration: none;
    border-bottom: 1px solid rgba(30, 91, 217, 0.25);
    padding-bottom: 2px;
    transition: gap 150ms, border-color 200ms;
}
.bt-blog-featured__cta:hover { gap: 12px; border-bottom-color: var(--color-blue); }

/* Liste paginée articles */
.bt-blog-list {
    list-style: none;
    padding: 0;
    margin: 0;
    border-top: 1px solid var(--color-border-light);
}
.bt-blog-list li { border-bottom: 1px solid var(--color-border-light); }
.bt-blog-list li a {
    display: grid;
    grid-template-columns: 140px 1fr auto;
    gap: 16px clamp(24px, 4vw, 48px);
    padding: clamp(20px, 2.5vw, 28px) 0;
    text-decoration: none;
    align-items: baseline;
    transition: background 200ms;
}
@media (max-width: 760px) { .bt-blog-list li a { grid-template-columns: 1fr; gap: 8px; } }
.bt-blog-list__cat {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-blue);
    margin: 0;
}
.bt-blog-list__title {
    font-family: 'Inter', sans-serif;
    font-size: clamp(18px, 2vw, 22px);
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.2;
    color: var(--color-text-primary);
    margin: 0 0 8px;
    transition: color 200ms;
}
.bt-blog-list li a:hover .bt-blog-list__title { color: var(--color-blue); }
.bt-blog-list__desc {
    font-size: 14px;
    line-height: 1.65;
    color: var(--color-text-body);
    max-width: 60ch;
    margin: 0;
}
.bt-blog-list__date {
    font-size: 13px;
    color: var(--color-text-muted);
    text-align: right;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}
.bt-blog-list__date small { font-size: 11px; display: block; margin-top: 2px; }
@media (max-width: 760px) {
    .bt-blog-list__date { text-align: left; }
    .bt-blog-list__date small { display: inline; margin-left: 8px; }
}

/* Pagination */
.bt-blog-pagination {
    margin-top: clamp(40px, 5vw, 72px);
    border-top: 1px solid var(--color-border-light);
    padding-top: 28px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
}
.bt-blog-pagination a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-blue);
    text-decoration: none;
    transition: gap 150ms;
}
.bt-blog-pagination a:hover { gap: 12px; }
.bt-blog-pagination__count {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin: 0;
}

/* Cas vide */
.bt-blog-empty { max-width: 55ch; padding: clamp(40px, 5vw, 64px) 0; }
.bt-blog-empty .eyebrow { color: var(--color-blue); margin-bottom: 12px; display: block; }
.bt-blog-empty h2 { font-family: 'Inter', sans-serif; font-size: clamp(22px, 2.4vw, 28px); font-weight: 600; letter-spacing: -0.025em; color: var(--color-text-primary); margin: 0 0 16px; }
.bt-blog-empty p { font-size: 15px; line-height: 1.7; color: var(--color-text-body); margin: 0 0 20px; }

/* ─── BLOG NAV CATÉGORIES (sous le hero) ─── */
.bt-blog-nav {
    background: var(--color-cream);
    border-top: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
}
.bt-blog-nav__inner {
    display: flex;
    flex-wrap: wrap;
    gap: 8px clamp(20px, 3vw, 32px);
    align-items: center;
    padding: 16px 0;
    font-size: 14px;
}
.bt-blog-nav__label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-blue);
}
.bt-blog-nav__link {
    color: var(--color-text-body);
    text-decoration: none;
    transition: color 200ms;
}
.bt-blog-nav__link:hover { color: var(--color-blue); }
.bt-blog-nav__link.is-active {
    color: var(--color-text-primary);
    font-weight: 600;
}

/* ─── ARTICLE BODY V3 (composants article-spécifiques) ─── */
.bt-article {
    max-width: 65ch;
    margin: 0 auto;
}
.bt-article > * + * { margin-top: 24px; }
.bt-article > h2 + *,
.bt-article > h3 + * { margin-top: 16px; }

.bt-article h2 {
    font-family: 'Inter', sans-serif;
    font-size: clamp(24px, 2.6vw, 32px);
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.15;
    color: var(--color-text-primary);
    margin: clamp(40px, 5vw, 72px) 0 0;
    text-wrap: balance;
    scroll-margin-top: 96px;
}
.bt-article h3 {
    font-family: 'Inter', sans-serif;
    font-size: clamp(18px, 2vw, 22px);
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.25;
    color: var(--color-text-primary);
    margin: 32px 0 0;
    scroll-margin-top: 96px;
}
.bt-article p {
    font-size: 16px;
    line-height: 1.75;
    color: var(--color-text-body);
}
.bt-article p strong { color: var(--color-text-primary); font-weight: 600; }
.bt-article a {
    color: var(--color-blue);
    text-decoration: none;
    border-bottom: 1px solid rgba(30, 91, 217, 0.25);
    transition: border-color 200ms;
}
.bt-article a:hover { border-bottom-color: var(--color-blue); }
.bt-article ul, .bt-article ol {
    list-style: none;
    padding: 0;
    margin: 24px 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.bt-article ul li,
.bt-article ol li {
    position: relative;
    padding-left: 22px;
    font-size: 16px;
    line-height: 1.7;
    color: var(--color-text-body);
}
.bt-article ul li::before {
    content: '';
    position: absolute;
    left: 0; top: 12px;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--color-blue);
}
.bt-article ol { counter-reset: items; }
.bt-article ol li {
    counter-increment: items;
    padding-left: 32px;
}
.bt-article ol li::before {
    content: counter(items, decimal-leading-zero);
    position: absolute;
    left: 0; top: 0;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    font-weight: 600;
    color: var(--color-blue);
    font-variant-numeric: tabular-nums;
}

/* Pull-quote dans article */
.bt-article-pullquote {
    border-left: 2px solid var(--color-blue);
    padding: 8px 0 8px 24px;
    margin: clamp(40px, 5vw, 64px) 0;
}
.bt-article-pullquote p {
    font-family: 'Inter', sans-serif;
    font-size: clamp(20px, 2.2vw, 26px);
    font-weight: 500;
    letter-spacing: -0.015em;
    line-height: 1.35;
    color: var(--color-text-primary);
    margin: 0;
    text-wrap: balance;
}

/* Encadré « À retenir » dans article */
.bt-article-callout {
    background: var(--color-cream);
    border-left: 2px solid var(--color-blue);
    padding: 24px clamp(20px, 3vw, 28px);
    border-radius: var(--radius-md);
    margin: clamp(40px, 5vw, 56px) 0;
}
.bt-article-callout__label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-blue);
    margin: 0 0 10px;
}
.bt-article-callout p {
    font-size: 15px;
    line-height: 1.7;
    color: var(--color-text-primary);
    margin: 0;
}

/* Articles liés (fin d'article) */
.bt-related {
    background: var(--color-cream);
    padding: clamp(56px, 7vw, 96px) 0;
}
.bt-related__head { max-width: 720px; margin: 0 auto clamp(32px, 4vw, 48px); }
.bt-related__head h2 {
    font-family: 'Inter', sans-serif;
    font-size: clamp(24px, 2.8vw, 34px);
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.15;
    color: var(--color-text-primary);
    margin: 12px 0 0;
    max-width: 28ch;
}

/* CTA conversion fin d'article */
.bt-article-cta {
    background: var(--color-cream);
    border-top: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
    padding: clamp(48px, 6vw, 80px) 0;
}
.bt-article-cta__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: clamp(28px, 4vw, 48px);
    align-items: end;
}
@media (max-width: 900px) { .bt-article-cta__grid { grid-template-columns: 1fr; align-items: start; } }
.bt-article-cta__copy h2 {
    font-family: 'Inter', sans-serif;
    font-size: clamp(22px, 2.4vw, 28px);
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.2;
    color: var(--color-text-primary);
    margin: 12px 0 0;
    max-width: 24ch;
}
.bt-article-cta__copy p {
    font-size: 15px;
    line-height: 1.65;
    color: var(--color-text-body);
    max-width: 55ch;
    margin: 12px 0 0;
}
.bt-article-cta__actions { display: flex; flex-wrap: wrap; gap: 12px; }

/* ===========================================================
 * Bande Fitzpatrick — pastilles couleur peau I→VI
 * Utilisée dans cat-hero keyspecs + sections phototypes.
 * =========================================================== */

.fitz-strip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    vertical-align: middle;
}
.fitz-strip--inline { margin-left: 10px; }
.fitz-strip__dot {
    width: 13px;
    height: 13px;
    border-radius: 50%;
    box-shadow: inset 0 0 0 1px rgba(11, 25, 54, 0.12), 0 1px 2px rgba(11, 25, 54, 0.08);
}
.fitz-strip__dot--1 { background: var(--color-fitz-1); }
.fitz-strip__dot--2 { background: var(--color-fitz-2); }
.fitz-strip__dot--3 { background: var(--color-fitz-3); }
.fitz-strip__dot--4 { background: var(--color-fitz-4); }
.fitz-strip__dot--5 { background: var(--color-fitz-5); }
.fitz-strip__dot--6 { background: var(--color-fitz-6); }

/* Quote-with-card section : card glassmorphism à droite de la citation
 * (rendu par partials/sections/quote-with-card.php). */
.qwc-card {
    background: rgb(var(--rgb-on-dark) / 0.025);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgb(var(--rgb-on-dark) / 0.06);
    border-radius: var(--radius-2xl);
    padding: var(--space-7) var(--space-6);
}

/* ===========================================================================
 * Système Tone — tone-aware sections (dark | light)
 *
 * Chaque partial de section (partials/sections/*.php) accepte un param `tone`.
 * Ces classes s'appliquent sur le <section> root et flippent automatiquement
 * background + couleur via les RGB tokens en theme-light.
 * =========================================================================== */
.hub-section{padding:clamp(64px,8vw,96px) 0;position:relative;overflow:hidden;}
.hub-section--tone-dark{background:var(--color-navy-deepest);color:var(--color-text-on-dark);}
.hub-section--tone-light{background:var(--color-off-white);color:var(--color-text-primary);}

/* Glows wrapper : visible uniquement en tone-dark. Le partial inclut
 * `<div class="hub-tone-glows">...halos...</div>` conditionnellement. */
.hub-tone-glows{position:absolute;inset:0;pointer-events:none;z-index:0;}
.hub-section--tone-light .hub-tone-glows{display:none;}
.hub-tone-glows__halo{position:absolute;border-radius:50%;filter:blur(120px);}
.hub-tone-glows__halo--tl{top:-200px;left:-200px;width:700px;height:700px;background:radial-gradient(circle,rgb(var(--rgb-blue) / 0.22) 0%,transparent 65%);}
.hub-tone-glows__halo--tl-sm{top:-200px;left:-200px;width:600px;height:600px;background:radial-gradient(circle,rgb(var(--rgb-blue) / 0.22) 0%,transparent 70%);}
.hub-tone-glows__halo--tl-strong{top:-200px;left:-100px;width:700px;height:700px;background:radial-gradient(circle,rgb(var(--rgb-blue) / 0.28) 0%,transparent 65%);}
.hub-tone-glows__halo--br{bottom:-300px;right:-200px;width:700px;height:700px;background:radial-gradient(circle,rgb(var(--rgb-blue-electric) / 0.15) 0%,transparent 70%);}
.hub-tone-glows__halo--br-strong{bottom:-300px;right:-200px;width:800px;height:800px;background:radial-gradient(circle,rgb(var(--rgb-blue-electric) / 0.18) 0%,transparent 65%);}
.hub-tone-glows__halo--center{top:50%;left:50%;transform:translate(-50%,-50%);width:900px;height:900px;background:radial-gradient(circle,rgb(var(--rgb-blue) / 0.12) 0%,transparent 65%);filter:blur(100px);}
.hub-tone-glows__halo--center-strong{top:50%;left:50%;transform:translate(-50%,-50%);width:900px;height:900px;background:radial-gradient(circle,rgb(var(--rgb-blue) / 0.28) 0%,transparent 55%);filter:blur(100px);}
.hub-tone-glows__halo--center-soft{top:50%;left:50%;transform:translate(-50%,-50%);width:450px;height:450px;background:radial-gradient(circle,rgb(var(--rgb-blue-electric) / 0.15) 0%,transparent 60%);filter:blur(60px);}

/* Auxiliaires de section (lead, note) — extraits des inline styles des partials */
.hub-section__lead{font-size:16px;line-height:1.65;color:var(--color-text-body);max-width:720px;margin:0;}
.hub-section__lead--dark{color:rgb(var(--rgb-on-dark) / 0.70);}
.hub-section__note{margin-top:var(--space-7);padding:16px 24px;background:rgb(var(--rgb-blue) / 0.06);border:1px solid rgb(var(--rgb-blue) / 0.18);border-radius:var(--radius-md);display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--color-text-primary);line-height:1.6;}
.hub-section__note--dark{background:rgb(var(--rgb-cyan) / 0.06);border-color:rgb(var(--rgb-cyan) / 0.15);color:rgb(var(--rgb-on-dark) / 0.75);}
.hub-section__note-icon{flex-shrink:0;margin-top:2px;color:var(--color-blue);}
.hub-section__note--dark .hub-section__note-icon{color:var(--color-cyan-tech);}

/* ===========================================================================
 * Partial : interlude.php — bandeau de respiration entre 2 sections
 * =========================================================================== */
.hub-interlude{padding:clamp(28px,3.5vw,40px) 0;}
.hub-interlude__inner{max-width:880px;}
.hub-interlude__line{font-size:clamp(14px,1.1vw,15px);line-height:1.65;max-width:75ch;margin:0;text-wrap:pretty;}
.hub-interlude--tone-light{background:var(--color-cream);border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);}
.hub-interlude--tone-light .hub-eyebrow{margin-bottom:10px;color:var(--color-blue);}
.hub-interlude--tone-light .hub-interlude__line{color:var(--color-text-body);}
.hub-interlude--strong{background:var(--color-off-white);}
.hub-interlude--tone-dark{background:var(--color-navy-deepest);border-top:1px solid rgb(var(--rgb-on-dark) / 0.06);border-bottom:1px solid rgb(var(--rgb-on-dark) / 0.06);}
.hub-interlude--tone-dark .hub-eyebrow{margin-bottom:10px;color:var(--color-cyan-tech);}
.hub-interlude--tone-dark .hub-interlude__line{color:rgb(var(--rgb-on-dark) / 0.78);}

/* ===========================================================================
 * Partial : regulation-table.php — variante --dark (table dans section dark)
 * =========================================================================== */
.hub-reg-table--dark th{color:rgb(var(--rgb-on-dark) / 0.50);border-bottom-color:rgb(var(--rgb-on-dark) / 0.12);}
.hub-reg-table--dark td{border-bottom-color:rgb(var(--rgb-on-dark) / 0.08);}
.hub-reg-table--dark .hub-reg-table__col-label{color:rgb(var(--rgb-on-dark) / 0.55);}
.hub-reg-table--dark .hub-reg-table__col-value{color:var(--color-text-on-dark);}
.hub-reg-table--dark .hub-reg-table__col-detail{color:rgb(var(--rgb-on-dark) / 0.50);}

/* ===========================================================================
 * Partial : quote-with-card.php — citation + carte CTA glass
 * =========================================================================== */
.hub-qwc__eyebrow{font-family:'Inter',system-ui,sans-serif;font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--color-cyan-tech);margin:0 0 var(--space-6);}
.hub-qwc__quote-wrap{position:relative;padding-left:40px;}
.hub-qwc__quote{font-family:'Inter',system-ui,sans-serif;font-size:clamp(18px,2vw,26px);font-weight:600;color:var(--color-text-on-dark);line-height:1.55;margin:0;}
.hub-qwc__author{margin-top:var(--space-7);display:flex;align-items:center;gap:16px;}
.hub-qwc__avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-blue),var(--color-cyan-tech));display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.hub-qwc__avatar span{font-family:'Inter',system-ui,sans-serif;font-size:18px;font-weight:600;color:var(--color-white);}
.hub-qwc__author-name{font-size:14px;font-weight:600;color:var(--color-text-on-dark);margin:0;}
.hub-qwc__author-meta{font-size:12px;color:rgb(var(--rgb-on-dark) / 0.45);margin:4px 0 0;}
.hub-qwc__card-eyebrow{font-family:'Inter',system-ui,sans-serif;font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-cyan-tech);margin:0 0 var(--space-5);}
.hub-qwc__card-h3{font-family:'Inter',system-ui,sans-serif;font-size:22px;font-weight:600;color:var(--color-text-on-dark);letter-spacing:-0.02em;margin:0 0 var(--space-5);}
.hub-qwc__card-desc{font-size:14px;line-height:1.65;color:rgb(var(--rgb-on-dark) / 0.65);margin:0 0 var(--space-6);}
.hub-section--tone-light .hub-qwc__eyebrow,
.hub-section--tone-light .hub-qwc__card-eyebrow{color:var(--color-blue);}
.hub-section--tone-light .hub-qwc__quote{color:var(--color-text-primary);}
.hub-section--tone-light .hub-qwc__author-name{color:var(--color-text-primary);}
.hub-section--tone-light .hub-qwc__author-meta{color:var(--color-text-muted);}
.hub-section--tone-light .hub-qwc__card-h3{color:var(--color-text-primary);}
.hub-section--tone-light .hub-qwc__card-desc{color:var(--color-text-body);}
.hub-section--tone-light .hub-quote-deco{color:rgb(var(--rgb-blue) / 0.18);}

/* ===========================================================================
 * Partial : form-cta-glass.php — pitch + form glassmorphism
 * =========================================================================== */
.hub-form-cta__title{font-family:'Inter',system-ui,sans-serif;font-size:clamp(28px,4vw,52px);font-weight:600;letter-spacing:-0.02em;line-height:1.05;color:var(--color-text-on-dark);margin:0 0 var(--space-5);}
.hub-form-cta__lead{font-size:15px;line-height:1.7;color:rgb(var(--rgb-on-dark) / 0.65);margin:0 0 var(--space-7);}
.hub-form-cta__bullets-eyebrow{font-family:'Inter',system-ui,sans-serif;font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:rgb(var(--rgb-on-dark) / 0.38);margin:0 0 var(--space-4);}
.hub-form-cta__bullets{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;}
.hub-form-cta__bullets li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:rgb(var(--rgb-on-dark) / 0.68);line-height:1.55;}
.hub-form-cta__bullet-dot{width:6px;height:6px;background:var(--color-cyan-tech);border-radius:50%;flex-shrink:0;margin-top:6px;}
.hub-form-cta__form-h3{font-family:'Inter',system-ui,sans-serif;font-size:24px;font-weight:600;color:var(--color-text-on-dark);letter-spacing:-0.02em;margin:0 0 8px;}
.hub-form-cta__form-subtitle{font-size:14px;color:rgb(var(--rgb-on-dark) / 0.48);margin:0 0 var(--space-6);}
.hub-section--tone-light .hub-form-cta__title{color:var(--color-text-primary);}
.hub-section--tone-light .hub-form-cta__lead{color:var(--color-text-body);}
.hub-section--tone-light .hub-form-cta__bullets-eyebrow{color:var(--color-text-muted);}
.hub-section--tone-light .hub-form-cta__bullets li{color:var(--color-text-body);}
.hub-section--tone-light .hub-form-cta__bullet-dot{background:var(--color-blue);}
.hub-section--tone-light .hub-form-cta__form-h3{color:var(--color-text-primary);}
.hub-section--tone-light .hub-form-cta__form-subtitle{color:var(--color-text-muted);}
.hub-section--tone-light .hub-form-card{background:var(--color-white);border-color:rgb(var(--rgb-navy) / 0.08);box-shadow:0 2px 12px rgb(var(--rgb-navy) / 0.04);}
.hub-section--tone-light .hub-form-card::before{display:none;}

/* ===========================================================================
 * Layout hub (utilisé par tous les templates hub-* et fiche-produit)
 * =========================================================================== */
.hub-page{background:var(--color-off-white);}
.hub-container{max-width:1200px;margin:0 auto;padding:0 clamp(16px,5vw,80px);position:relative;z-index: var(--z-raised);}

/* ===========================================================================
 * Typographie hub (utilitaires partagés par tous les partials)
 * =========================================================================== */
.hub-eyebrow{display:inline-flex;align-items:center;font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-5);}
.hub-eyebrow--dark{color:var(--color-text-on-dark-subtle);}
.hub-h1{font-size:clamp(40px,5vw,68px);font-weight:600;letter-spacing:-0.035em;line-height:1.02;color:var(--color-text-on-dark);margin:0;text-wrap:balance;max-width:18ch;}
.hub-h2{font-size:clamp(28px,3vw,44px);font-weight:600;letter-spacing:-0.03em;line-height:1.05;margin:0 0 var(--space-5);}
.hub-h2--dark{color:var(--color-text-on-dark);}
.hub-h2--light{color:var(--color-text-primary);}
.hub-subtitle{font-size:clamp(16px,1.2vw,19px);line-height:1.55;color:rgb(var(--rgb-on-dark) / 0.78);max-width:56ch;margin:0;}
.hub-subtitle--light{color:var(--color-text-body);}

/* ===========================================================================
 * Boutons & liens hub
 * =========================================================================== */
.hub-btn{display:inline-flex;align-items:center;gap:6px;padding:12px 22px;background:var(--color-blue);color:var(--color-white);font-size:14px;font-weight:600;border:none;border-radius:var(--radius-pill);cursor:pointer;text-decoration:none;transition:background 200ms,transform 150ms;white-space:nowrap;}
.hub-btn:hover{background:var(--color-blue-hover);transform:translateY(-1px);}
.hub-btn--ghost{background:transparent;color:rgb(var(--rgb-on-dark) / 0.85);border:1.5px solid rgb(var(--rgb-on-dark) / 0.25);}
.hub-btn--ghost:hover{background:rgb(var(--rgb-on-dark) / 0.08);color:var(--color-text-on-dark);transform:translateY(-1px);}
.hub-btn--full{width:100%;justify-content:center;}
.hub-link-faded{font-size:13px;font-weight:500;color:rgb(var(--rgb-on-dark) / 0.55);text-decoration:none;transition:color 150ms;}
.hub-link-faded:hover,.hub-link-faded:focus-visible{color:var(--color-text-on-dark);}

/* ===========================================================================
 * Partial : regulation-table.php (table 3 colonnes critère/valeur/référence)
 * =========================================================================== */
.hub-reg-table{width:100%;border-collapse:collapse;margin-top:var(--space-7);}
.hub-reg-table th{font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-text-muted);padding:0 16px 12px 0;border-bottom:1px solid rgb(var(--rgb-navy) / 0.12);text-align:left;}
.hub-reg-table td{padding:16px 16px 16px 0;border-bottom:1px solid var(--color-border-light);font-size:14px;vertical-align:top;}
.hub-reg-table__col-label{color:var(--color-text-muted);width:220px;}
.hub-reg-table__col-value{color:var(--color-text-primary);font-weight:600;}
.hub-reg-table__col-detail{color:var(--color-text-muted);font-size:12px;}
@media(max-width:600px){.hub-reg-table__col-label{width:130px;}}

/* ===========================================================================
 * Partial : comparator-table.php (table comparative N×M)
 * =========================================================================== */
.hub-cmp-wrap{overflow-x:auto;margin-top:var(--space-7);}
.hub-cmp{width:100%;border-collapse:collapse;min-width:640px;}
.hub-cmp thead th{font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-text-muted);padding:0 16px 14px 0;border-bottom:2px solid rgb(var(--rgb-navy) / 0.10);text-align:left;}
.hub-cmp thead th:not(:first-child){text-align:center;}
.hub-cmp td{padding:14px 16px 14px 0;border-bottom:1px solid var(--color-border-light);font-size:13px;color:var(--color-text-body);vertical-align:middle;}
.hub-cmp td:first-child{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-text-muted);width:180px;}
.hub-cmp td:not(:first-child){text-align:center;color:var(--color-text-primary);font-weight:500;}
.hub-cmp__row--hero td{background:rgb(var(--rgb-blue) / 0.06);font-weight:600;}
.hub-cmp__row--hero td:first-child{color:var(--color-blue);}
.hub-cmp tr:last-child td{border-bottom:none;}

/* ===========================================================================
 * Partial : card-tech.php (carte technologie)
 * =========================================================================== */
.hub-tech-card{background:rgb(var(--rgb-on-dark) / 0.025);border:1px solid rgb(var(--rgb-on-dark) / 0.06);border-radius:var(--radius-2xl);padding:var(--space-7) var(--space-6);display:flex;flex-direction:column;gap:var(--space-5);position:relative;overflow:hidden;transition:border-color 300ms var(--ease-out),transform 300ms var(--ease-out),box-shadow 300ms var(--ease-out);}
.hub-tech-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgb(var(--rgb-on-dark) / 0.10),transparent);}
.hub-tech-card:hover{border-color:rgb(var(--rgb-blue-electric) / 0.35);transform:translateY(-4px);box-shadow:0 20px 40px rgb(var(--rgb-blue) / 0.18);}
.hub-tech-card__icon{width:48px;height:48px;background:rgb(var(--rgb-blue) / 0.18);border:1px solid rgb(var(--rgb-blue-electric) / 0.25);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--color-blue-electric);}
.hub-tech-card__eyebrow{font-size:10px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--color-cyan-tech);}
.hub-tech-card__title{font-size:clamp(20px,1.8vw,26px);font-weight:600;color:var(--color-text-on-dark);letter-spacing:-0.02em;margin:0;}
.hub-tech-card__desc{font-size:14px;line-height:1.65;color:rgb(var(--rgb-on-dark) / 0.70);margin:0;}
.hub-tech-card__specs{display:flex;flex-direction:column;gap:8px;border-top:1px solid rgb(var(--rgb-on-dark) / 0.06);padding-top:var(--space-5);}
.hub-tech-card__spec{display:flex;justify-content:space-between;align-items:center;font-size:12px;}
.hub-tech-card__spec-label{color:rgb(var(--rgb-on-dark) / 0.45);}
.hub-tech-card__spec-val{color:var(--color-text-on-dark);font-weight:500;}
.hub-tech-card__cta{margin-top:auto;}

/* ===========================================================================
 * Partial : card-machine-feature.php (carte machine en grille)
 * =========================================================================== */
.hub-mcard{background:rgb(var(--rgb-on-dark) / 0.03);border:1px solid rgb(var(--rgb-on-dark) / 0.06);border-radius:var(--radius-2xl);padding:var(--space-7) var(--space-6);position:relative;overflow:hidden;display:flex;flex-direction:column;transition:border-color 300ms var(--ease-out),transform 300ms var(--ease-out),box-shadow 300ms var(--ease-out);}
.hub-mcard::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgb(var(--rgb-on-dark) / 0.08),transparent);}
.hub-mcard:hover{border-color:rgb(var(--rgb-blue-electric) / 0.30);transform:translateY(-3px);box-shadow:0 20px 40px rgb(var(--rgb-blue) / 0.15);}
.hub-mcard--hero{background:linear-gradient(135deg,rgb(var(--rgb-blue) / 0.28) 0%,rgb(var(--rgb-cyan) / 0.06) 100%),rgb(var(--rgb-on-dark) / 0.03);border-color:rgb(var(--rgb-cyan) / 0.30);}
.hub-mcard--hero::before{background:linear-gradient(90deg,transparent,rgb(var(--rgb-cyan) / 0.45),transparent);}
.hub-mcard__num{font-family:'Inter',system-ui,sans-serif;font-size:96px;font-weight:700;color:rgb(var(--rgb-on-dark) / 0.04);line-height:1;position:absolute;top:var(--space-5);right:var(--space-6);pointer-events:none;user-select:none;letter-spacing:-0.045em;font-variant-numeric:tabular-nums;}
.hub-mcard__num--sm{font-size:76px;}
.hub-mcard__badge{display:inline-flex;align-items:center;gap:5px;background:var(--color-cyan-tech);color:var(--color-navy-deepest);font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding:3px 10px;border-radius:var(--radius-pill);margin-bottom:var(--space-5);width:fit-content;}
.hub-mcard__photo{height:180px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-6);}
.hub-mcard--hero .hub-mcard__photo{height:240px;}
.hub-mcard__photo img{max-height:100%;max-width:100%;object-fit:contain;filter:drop-shadow(0 20px 40px rgb(var(--rgb-navy-deepest) / 0.55));transition:opacity 150ms;}
.hub-mcard__photo img:not([src]),.hub-mcard__photo img[src=""]{opacity:0;}
.hub-mcard__eyebrow{font-size:10px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--color-cyan-tech);margin-bottom:10px;}
.hub-mcard__h3--hero{font-family:'Inter',system-ui,sans-serif;font-size:clamp(28px,3vw,38px);font-weight:600;letter-spacing:-0.025em;line-height:1.1;color:var(--color-text-on-dark);margin:0 0 var(--space-4);}
.hub-mcard__h3{font-family:'Inter',system-ui,sans-serif;font-size:clamp(22px,2.4vw,28px);font-weight:600;letter-spacing:-0.025em;line-height:1.15;color:var(--color-text-on-dark);margin:0 0 var(--space-4);}
.hub-mcard__sub{font-size:15px;color:rgb(var(--rgb-on-dark) / 0.65);line-height:1.6;margin:0 0 var(--space-5);}
.hub-mcard__quote{margin:0 0 var(--space-6);font-size:13px;color:rgb(var(--rgb-on-dark) / 0.58);line-height:1.65;}
.hub-mcard__quote::before{content:'\201C\00A0';color:var(--color-cyan-tech);font-style:normal;font-weight:600;margin-right:2px;}
.hub-mcard__quote::after{content:'\00A0\201D';color:var(--color-cyan-tech);font-style:normal;font-weight:600;margin-left:2px;}
.hub-mcard__specs{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:var(--space-5);}
.hub-mcard__spec{display:flex;flex-direction:column;gap:3px;}
.hub-mcard__spec-label{font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgb(var(--rgb-on-dark) / 0.38);}
.hub-mcard__spec-val{font-size:14px;font-weight:500;color:var(--color-text-on-dark);}
.hub-mcard__indic-eyebrow{font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:rgb(var(--rgb-on-dark) / 0.38);margin-bottom:8px;}
.hub-mcard__indic-list{list-style:none;padding:0;margin:0 0 var(--space-6);display:flex;flex-direction:column;gap:6px;}
.hub-mcard__indic-list li{font-size:13px;color:rgb(var(--rgb-on-dark) / 0.68);display:flex;align-items:center;gap:8px;}
.hub-mcard__indic-list li::before{content:'';width:4px;height:4px;background:var(--color-cyan-tech);border-radius:50%;flex-shrink:0;}
.hub-mcard__cta-link{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--color-blue-electric);text-decoration:none;transition:color 150ms,gap 150ms;margin-top:auto;}
.hub-mcard__cta-link:hover{color:var(--color-cyan-tech);gap:8px;}

/* ===========================================================================
 * Partial : card-tco.php (carte coût total de possession)
 * =========================================================================== */
.hub-tco-card{position:relative;overflow:hidden;padding:var(--space-7) var(--space-6);background:linear-gradient(135deg,rgb(var(--rgb-on-dark) / 0.04) 0%,rgb(var(--rgb-on-dark) / 0.01) 100%),var(--color-navy-deep);border:1px solid rgb(var(--rgb-on-dark) / 0.08);border-radius:var(--radius-2xl);display:flex;flex-direction:column;}
.hub-tco-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgb(var(--rgb-on-dark) / 0.20),transparent);z-index: var(--z-raised);}
.hub-tco-card > *{position:relative;z-index: var(--z-raised);}
.hub-tco-card--hero{background:linear-gradient(135deg,rgb(var(--rgb-blue) / 0.28) 0%,rgb(var(--rgb-cyan) / 0.06) 100%),var(--color-navy-deep);border-color:rgb(var(--rgb-cyan) / 0.30);}
.hub-tco-card--hero::before{background:linear-gradient(90deg,transparent,rgb(var(--rgb-cyan) / 0.55),transparent);}
.hub-tco-spec{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;border-bottom:1px solid rgb(var(--rgb-on-dark) / 0.06);font-size:13px;}
.hub-tco-spec:last-of-type{border-bottom:none;}
.hub-tco-spec__label{color:rgb(var(--rgb-on-dark) / 0.45);}
.hub-tco-spec__val{color:var(--color-text-on-dark);font-weight:600;text-align:right;padding-left:12px;}
.hub-tco-highlight{margin-top:var(--space-5);padding:var(--space-5);background:rgb(var(--rgb-cyan) / 0.07);border:1px solid rgb(var(--rgb-cyan) / 0.18);border-radius:var(--radius-lg);text-align:center;}
.hub-tco-highlight__fig{font-family:'Inter',system-ui,sans-serif;font-size:30px;font-weight:700;color:var(--color-text-on-dark);letter-spacing:-0.03em;display:block;margin-bottom:6px;font-variant-numeric:tabular-nums;}
.hub-tco-highlight__pill{display:inline-flex;align-items:center;gap:5px;background:var(--color-cyan-tech);color:var(--color-navy-deepest);font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding:3px 10px;border-radius:var(--radius-pill);}

/* ===========================================================================
 * Partial : quote-with-card.php — décoration guillemet
 * =========================================================================== */
.hub-quote-deco{font-family:'Inter',system-ui,sans-serif;font-size:80px;font-weight:600;line-height:1;color:rgb(var(--rgb-cyan) / 0.14);position:absolute;top:-16px;left:-8px;pointer-events:none;user-select:none;}

/* ===========================================================================
 * Partial : form-cta-glass.php — card glass form + grids 2 colonnes
 * =========================================================================== */
.hub-form-card{background:rgb(var(--rgb-on-dark) / 0.025);border:1px solid rgb(var(--rgb-blue-electric) / 0.25);border-radius:var(--radius-2xl);padding:clamp(28px,3vw,40px);position:relative;overflow:hidden;}
.hub-form-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgb(var(--rgb-blue-electric) / 0.40),transparent);}
.hub-form-card > *{position:relative;z-index: var(--z-raised);}
.hub-s12-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:var(--space-8);align-items:start;}
.hub-s13-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,5vw,80px);align-items:start;}
@media(max-width:1023px){.hub-s12-grid,.hub-s13-grid{grid-template-columns:1fr;}}

/* ===========================================================================
 * Partial : forms/demo-form.php (champs form + consentement RGPD)
 * =========================================================================== */
.hub-field{display:flex;flex-direction:column;gap:6px;}
.hub-field__label{font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:rgb(var(--rgb-on-dark) / 0.40);}
.hub-field--light .hub-field__label,
.hub-field__label--light{color:var(--color-text-muted);}
.hub-input,.hub-select,.hub-textarea{width:100%;background:rgb(var(--rgb-on-dark) / 0.06);border:1px solid rgb(var(--rgb-on-dark) / 0.12);border-radius:var(--radius-lg);padding:13px 16px;font-size:14px;color:var(--color-text-on-dark);font-family:var(--font-display);outline:none;transition:border-color 200ms;-webkit-appearance:none;appearance:none;}
.hub-input::placeholder,.hub-textarea::placeholder{color:rgb(var(--rgb-on-dark) / 0.30);}
.hub-input:focus,.hub-select:focus,.hub-textarea:focus{border-color:rgb(var(--rgb-blue-electric) / 0.55);}
.hub-select option{background:var(--color-navy-deep);color:var(--color-text-on-dark);}
.hub-textarea{resize:vertical;min-height:100px;line-height:1.6;}
.hub-input.hub-input--light{background:var(--color-white);border-color:rgb(var(--rgb-navy) / 0.12);color:var(--color-text-primary);}
.hub-input.hub-input--light::placeholder{color:var(--color-text-muted);}
.hub-input.hub-input--light:focus{border-color:var(--color-blue);}
/* Locked : champ figé (produit imposé sur fiche-produit) — couleur d'accent */
.hub-input.hub-input--locked{cursor:default;color:var(--color-cyan-tech);font-weight:600;border-color:rgb(var(--rgb-cyan) / 0.25);background:rgb(var(--rgb-cyan) / 0.04);}
.hub-input.hub-input--locked:focus{border-color:rgb(var(--rgb-cyan) / 0.25);}

/* Overrides tone-light : form sur fond clair (S11 form-cta-glass light) */
.hub-section--tone-light .hub-field__label{color:var(--color-text-muted);}
.hub-section--tone-light .hub-input,
.hub-section--tone-light .hub-select,
.hub-section--tone-light .hub-textarea{background:var(--color-white);border-color:rgb(var(--rgb-navy) / 0.12);color:var(--color-text-primary);}
.hub-section--tone-light .hub-input::placeholder,
.hub-section--tone-light .hub-textarea::placeholder{color:var(--color-text-muted);}
.hub-section--tone-light .hub-input:focus,
.hub-section--tone-light .hub-select:focus,
.hub-section--tone-light .hub-textarea:focus{border-color:var(--color-blue);}
.hub-section--tone-light .hub-select option{background:var(--color-white);color:var(--color-text-primary);}
.hub-section--tone-light .hub-input.hub-input--locked{color:var(--color-blue);border-color:rgb(var(--rgb-blue) / 0.25);background:rgb(var(--rgb-blue) / 0.04);}
.hub-section--tone-light .hub-consent{color:var(--color-text-body);}
/* Form structure : display + spacing + submit + disclaimer */
.hub-form{display:flex;flex-direction:column;gap:14px;}
.hub-form__submit{margin-top:4px;}
.hub-form__disclaimer{font-size:11px;color:rgb(var(--rgb-on-dark) / 0.5);line-height:1.6;text-align:center;margin:0;}
.hub-section--tone-light .hub-form__disclaimer{color:var(--color-text-muted);}
.hub-form-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:600px){.hub-form-row2{grid-template-columns:1fr;}}
.hub-consent{display:flex;align-items:flex-start;gap:10px;font-size:12px;line-height:1.5;color:rgb(var(--rgb-on-dark) / 0.7);cursor:pointer;margin-top:4px;}
.hub-consent input[type="checkbox"]{margin-top:3px;flex-shrink:0;accent-color:var(--color-blue);}
.hub-consent a{color:inherit;text-decoration:underline;}
.hub-consent a:hover{color:var(--color-blue-electric);}

/* ===========================================================================
 * Pattern C — grid bleu lumineux (utilisé par form-cta-glass et sections sombres)
 * =========================================================================== */
.hub-pattern-c{position:absolute;inset:0;pointer-events:none;z-index: var(--z-base);overflow:hidden;}
.hub-pattern-c::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgb(var(--rgb-blue-electric) / 0.18) 1px,transparent 1px);background-size:44px 44px;opacity:0.35;}
.hub-pattern-c--v5::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 50% at 15% 50%,rgb(var(--rgb-blue) / 0.32) 0%,transparent 55%),radial-gradient(ellipse 45% 65% at 85% 25%,rgb(var(--rgb-blue-electric) / 0.20) 0%,transparent 55%),radial-gradient(ellipse 40% 40% at 50% 95%,rgb(var(--rgb-cyan) / 0.10) 0%,transparent 60%);filter:blur(80px);}

/* ===========================================================================
 * Partial : tech-grid.php (grille 3 cards Technologie)
 * =========================================================================== */
.hub-tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-top:var(--space-7);}
@media(max-width:1023px){.hub-tech-grid{grid-template-columns:1fr 1fr;gap:var(--space-5);}}
@media(max-width:639px){.hub-tech-grid{grid-template-columns:1fr;}}

/* ===========================================================================
 * Partial : phototypes-table.php (table phototypes × technologies)
 * Base : couleurs tone-dark. Overrides pour tone-light en dessous.
 * =========================================================================== */
.hub-pt-table-wrap{overflow-x:auto;overflow-y:hidden;margin-top:var(--space-7);}
.hub-pt-table{width:100%;border-collapse:collapse;min-width:520px;}
.hub-pt-table th{font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgb(var(--rgb-on-dark) / 0.50);padding:0 12px 16px;text-align:center;border-bottom:1px solid rgb(var(--rgb-on-dark) / 0.08);}
.hub-pt-table th:first-child{text-align:left;padding-left:0;}
.hub-pt-table td{padding:14px 12px;border-bottom:1px solid rgb(var(--rgb-on-dark) / 0.05);font-size:15px;text-align:center;color:var(--color-text-on-dark);}
.hub-pt-table td:first-child{font-size:13px;font-weight:500;text-align:left;padding-left:0;color:rgb(var(--rgb-on-dark) / 0.85);}
.hub-pt-table tr:last-child td{border-bottom:none;}
.hub-pt-legend{display:flex;gap:24px;margin-top:16px;flex-wrap:wrap;}
.hub-pt-legend__item{font-size:11px;color:rgb(var(--rgb-on-dark) / 0.50);display:flex;align-items:center;gap:6px;}
/* Overrides tone-light */
.hub-section--tone-light .hub-pt-table th{color:var(--color-text-muted);border-bottom-color:rgb(var(--rgb-navy) / 0.10);}
.hub-section--tone-light .hub-pt-table td{color:var(--color-text-primary);border-bottom-color:var(--color-border-light);}
.hub-section--tone-light .hub-pt-table td:first-child{color:var(--color-text-body);}
.hub-section--tone-light .hub-pt-legend__item{color:var(--color-text-muted);}

/* ===========================================================================
 * Partial : spacer.php — bande d'aération avant footer si section sombre
 * Blanc pur (statique, ne flippe pas) → contraste franc dans les 2 thèmes :
 *   dark  : spacer blanc vs footer navy
 *   light : spacer blanc vs footer bleu pastel
 * =========================================================================== */
.hub-spacer{background:var(--color-white);padding:clamp(72px,9vw,112px) 0;}

/* ===========================================================================
 * Layout sous-cat hub (.scld-page) — typo de base + wrap
 * Les sections (.intro, .arb, .products, .tech, .compliance, .obj) sont des
 * classes de LAYOUT — leur bg/color est géré par .hub-section--tone-*.
 * =========================================================================== */
.scld-page{background:var(--color-off-white);--section-py:var(--section-default);--accent:var(--color-blue);--accent-hover:var(--color-blue-hover);--accent-soft:rgb(var(--c-accent) / 0.14);}
.scld-page .wrap{max-width:1320px;margin:0 auto;padding:0 clamp(20px,4vw,56px);}
.scld-page .h2{font-family:'Inter',sans-serif;font-size:clamp(28px,2.6vw,40px);font-weight:600;letter-spacing:-0.025em;line-height:1.12;text-wrap:balance;margin:0 0 16px;}
.scld-page .h2--light{color:var(--color-text-primary);}
.scld-page .h2--dark{color:var(--color-text-on-dark);}
.scld-page .lead-light{color:var(--color-text-body);font-size:clamp(15px,1.15vw,17px);margin:0;line-height:1.7;}
.scld-page .lead-dark{color:rgb(var(--rgb-on-dark) / 0.70);font-size:clamp(15px,1.15vw,17px);margin:0;line-height:1.7;}

/* ===========================================================================
 * Partial : intro-with-raisons.php
 * =========================================================================== */
.intro{padding:var(--section-py) 0;}
.intro__inner{max-width:780px;margin:0 auto;}
.intro__h2{font-family:'Inter',sans-serif;font-size:clamp(28px,3vw,44px);font-weight:600;letter-spacing:-0.03em;line-height:1.08;margin:0 0 36px;text-wrap:balance;color:var(--color-text-primary);}
.intro__h2 em{font-style:normal;color:var(--color-blue);}
.intro__copy p{font-size:17px;line-height:1.75;color:var(--color-text-body);margin:0 0 22px;}
.intro__copy p strong{color:var(--color-text-primary);font-weight:600;}
.intro__raisons{margin-top:56px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);}
.intro__raison{padding:28px 24px 28px 0;border-right:1px solid var(--color-border-light);}
.intro__raison:last-child{border-right:0;padding-right:0;}
.intro__raison:not(:first-child){padding-left:24px;}
.intro__raison-icon{width:36px;height:36px;border-radius:var(--radius-md);background:rgb(var(--rgb-blue) / 0.14);color:var(--color-blue);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.intro__raison b{display:block;font-size:14px;font-weight:600;color:var(--color-text-primary);letter-spacing:-0.005em;margin-bottom:6px;line-height:1.35;}
.intro__raison span{font-size:13px;color:var(--color-text-body);line-height:1.55;}
@media(max-width:760px){.intro__raisons{grid-template-columns:1fr 1fr;}.intro__raison:nth-child(2n){border-right:0;}.intro__raison:nth-child(-n+2){border-bottom:1px solid var(--color-border-light);}}
/* Tone-dark overrides */
.hub-section--tone-dark .intro__h2{color:var(--color-text-on-dark);}
.hub-section--tone-dark .intro__h2 em{color:var(--color-cyan-tech);}
.hub-section--tone-dark .intro__copy p{color:rgb(var(--rgb-on-dark) / 0.78);}
.hub-section--tone-dark .intro__copy p strong{color:var(--color-text-on-dark);}
.hub-section--tone-dark .intro__raisons{border-top-color:rgb(var(--rgb-on-dark) / 0.10);border-bottom-color:rgb(var(--rgb-on-dark) / 0.10);}
.hub-section--tone-dark .intro__raison{border-right-color:rgb(var(--rgb-on-dark) / 0.10);}
.hub-section--tone-dark .intro__raison b{color:var(--color-text-on-dark);}
.hub-section--tone-dark .intro__raison span{color:rgb(var(--rgb-on-dark) / 0.70);}

/* ===========================================================================
 * Partial : arbitrage-numbered.php
 * =========================================================================== */
.arb{padding:var(--section-py) 0;position:relative;}
.arb--cream{background:var(--color-cream);}
.arb__head{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:48px;align-items:end;margin-bottom:56px;}
.arb__head-meta{display:flex;flex-direction:column;gap:16px;padding-bottom:8px;}
.arb__head-meta-row{display:flex;gap:12px;align-items:baseline;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--color-text-muted);letter-spacing:0.06em;border-top:1px solid var(--color-border-light);padding-top:14px;}
.arb__head-meta-row b{color:var(--color-text-primary);font-weight:600;font-size:13px;font-variant-numeric:tabular-nums;}
@media(max-width:900px){.arb__head{grid-template-columns:1fr;}}
.arb__grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.arb__card{background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:36px 32px 32px;display:flex;flex-direction:column;transition:border-color 280ms,transform 280ms var(--ease-out),box-shadow 280ms;position:relative;overflow:hidden;}
.arb__card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--color-blue);transition:width 350ms var(--ease-out);}
.arb__card:hover{border-color:rgb(var(--rgb-blue) / 0.28);transform:translateY(-3px);box-shadow:0 16px 40px rgb(var(--rgb-navy) / 0.08);}
.arb__card:hover::before{width:100%;}
.arb__card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:20px;}
.arb__card-num{font-family:'JetBrains Mono',monospace;font-size:56px;font-weight:600;color:var(--color-blue);letter-spacing:-0.02em;line-height:0.85;font-variant-numeric:tabular-nums;opacity:0.18;transition:opacity 300ms;}
.arb__card:hover .arb__card-num{opacity:0.45;}
.arb__card-tag{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-blue);background:rgb(var(--rgb-blue) / 0.14);padding:6px 12px;border-radius:var(--radius-pill);white-space:nowrap;}
.arb__card h3{font-family:'Inter',sans-serif;font-size:clamp(20px,1.6vw,24px);font-weight:600;letter-spacing:-0.02em;color:var(--color-text-primary);margin:0 0 14px;line-height:1.22;text-wrap:balance;}
.arb__card > p{font-size:14px;color:var(--color-text-body);line-height:1.65;margin:0 0 24px;flex:1;}
.arb__card-meta{display:grid;grid-template-columns:auto 1fr;gap:10px 16px;padding-top:18px;border-top:1px solid var(--color-border-light);font-size:13px;}
.arb__card-meta dt{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-text-muted);margin:0;align-self:center;}
.arb__card-meta dd{margin:0;font-weight:500;color:var(--color-text-primary);}
.arb__card-meta dd.is-reco{color:var(--color-blue);font-weight:600;}
@media(max-width:760px){.arb__grid{grid-template-columns:1fr;}}
/* Tone-dark overrides */
.hub-section--tone-dark .arb__card{background:rgb(var(--rgb-on-dark) / 0.04);border-color:rgb(var(--rgb-on-dark) / 0.08);}
.hub-section--tone-dark .arb__card:hover{border-color:rgb(var(--rgb-blue-electric) / 0.30);box-shadow:0 16px 40px rgb(var(--rgb-blue) / 0.15);}
.hub-section--tone-dark .arb__card-num{color:var(--color-cyan-tech);opacity:0.35;}
.hub-section--tone-dark .arb__card:hover .arb__card-num{opacity:0.65;}
.hub-section--tone-dark .arb__card h3{color:var(--color-text-on-dark);}
.hub-section--tone-dark .arb__card > p{color:rgb(var(--rgb-on-dark) / 0.70);}
.hub-section--tone-dark .arb__card-tag{background:rgb(var(--rgb-cyan) / 0.14);color:var(--color-cyan-tech);}
.hub-section--tone-dark .arb__card-meta{border-top-color:rgb(var(--rgb-on-dark) / 0.10);}
.hub-section--tone-dark .arb__card-meta dt{color:rgb(var(--rgb-on-dark) / 0.50);}
.hub-section--tone-dark .arb__card-meta dd{color:var(--color-text-on-dark);}
.hub-section--tone-dark .arb__card-meta dd.is-reco{color:var(--color-cyan-tech);}
.hub-section--tone-dark .arb__head-meta-row{border-top-color:rgb(var(--rgb-on-dark) / 0.10);color:rgb(var(--rgb-on-dark) / 0.55);}
.hub-section--tone-dark .arb__head-meta-row b{color:var(--color-text-on-dark);}

/* ===========================================================================
 * Partial : products-grid.php
 * =========================================================================== */
.products{padding:var(--section-py) 0;position:relative;overflow:hidden;}
.products__head{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);gap:32px;align-items:end;margin-bottom:64px;position:relative;z-index:var(--z-raised);}
.products__head h2{font-family:'Inter',sans-serif;font-size:clamp(28px,2.6vw,40px);font-weight:600;letter-spacing:-0.025em;line-height:1.12;margin:14px 0 0;color:var(--color-text-on-dark);text-wrap:balance;}
.products__head-meta{font-family:'JetBrains Mono',monospace;font-size:11px;color:rgb(var(--rgb-on-dark) / 0.55);letter-spacing:0.06em;justify-self:end;display:flex;gap:16px;flex-wrap:wrap;}
.products__head-meta b{color:var(--color-cyan-tech);font-weight:600;}
.products__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;z-index:var(--z-raised);}
.product-card{background:rgb(var(--rgb-on-dark) / 0.04);border:1px solid rgb(var(--rgb-on-dark) / 0.08);border-radius:var(--radius-xl);padding:32px 28px;display:flex;flex-direction:column;transition:border-color 280ms,transform 280ms var(--ease-out),background 280ms;position:relative;overflow:hidden;}
.product-card:hover{border-color:rgb(var(--rgb-blue) / 0.4);transform:translateY(-3px);background:rgb(var(--rgb-on-dark) / 0.06);}
.product-card--featured{background:linear-gradient(160deg,rgb(var(--rgb-blue) / 0.16) 0%,rgb(var(--rgb-on-dark) / 0.04) 60%);border-color:rgb(var(--rgb-blue-electric) / 0.30);}
.product-card__chip{position:absolute;top:18px;right:18px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;background:var(--color-blue);color:var(--color-white);padding:5px 10px;border-radius:var(--radius-pill);display:inline-flex;align-items:center;gap:6px;z-index:var(--z-pop);}
.product-card__chip::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--color-white);box-shadow:0 0 0 3px rgb(var(--rgb-on-dark) / 0.30);animation:scld-chip-blink 1.6s ease-in-out infinite;}
.product-card__chip--soft{background:rgb(var(--rgb-on-dark) / 0.08);color:rgb(var(--rgb-on-dark) / 0.65);border:1px solid rgb(var(--rgb-on-dark) / 0.15);}
.product-card__chip--soft::before{background:var(--color-text-muted);box-shadow:none;animation:none;}
@keyframes scld-chip-blink{0%,100%{opacity:1;}50%{opacity:0.45;}}
.product-card__photo{height:180px;margin-bottom:28px;position:relative;display:flex;align-items:center;justify-content:center;}
.product-card__photo-glow{position:absolute;inset:10%;background:radial-gradient(circle,rgb(var(--rgb-blue) / 0.5) 0%,transparent 65%);filter:blur(30px);}
.product-card__photo img{position:relative;max-height:180px;width:auto;filter:drop-shadow(0 20px 30px rgb(var(--rgb-navy-deepest) / 0.45));}
.product-card__mono{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-cyan-tech);margin:0 0 8px;}
.product-card h3{font-family:'Inter',sans-serif;font-size:clamp(26px,2.2vw,32px);font-weight:600;letter-spacing:-0.03em;color:var(--color-text-on-dark);margin:0 0 12px;line-height:1.05;}
.product-card__lead{font-size:13px;line-height:1.6;color:rgb(var(--rgb-on-dark) / 0.65);margin:0 0 20px;flex:1;}
.product-card__specs{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px;padding:18px 0;border-top:1px solid rgb(var(--rgb-on-dark) / 0.08);border-bottom:1px solid rgb(var(--rgb-on-dark) / 0.08);margin-bottom:22px;}
.product-card__spec span{display:block;font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgb(var(--rgb-on-dark) / 0.45);margin-bottom:4px;}
.product-card__spec b{display:block;font-size:14px;font-weight:600;color:var(--color-text-on-dark);font-variant-numeric:tabular-nums;letter-spacing:-0.005em;}
.product-card__invest{display:flex;align-items:baseline;gap:6px;margin-bottom:20px;}
.product-card__invest-label{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgb(var(--rgb-on-dark) / 0.45);}
.product-card__invest-value{font-size:14px;font-weight:600;color:var(--color-text-on-dark);font-variant-numeric:tabular-nums;}
.product-card__cta{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-text-on-dark);background:rgb(var(--rgb-on-dark) / 0.06);border:1px solid rgb(var(--rgb-on-dark) / 0.15);padding:12px 18px;border-radius:var(--radius-pill);transition:background 200ms,border-color 200ms,gap 200ms;align-self:flex-start;}
.product-card__cta:hover{background:var(--color-blue);border-color:var(--color-blue);gap:12px;}
.product-card--featured .product-card__cta{background:var(--color-blue);border-color:var(--color-blue);}
.product-card--featured .product-card__cta:hover{background:var(--color-blue-hover);border-color:var(--color-blue-hover);}
.product-card--soon{opacity:0.62;}
.product-card--soon:hover{transform:none;}
@media(max-width:1000px){.products__grid{grid-template-columns:1fr;}.products__head{grid-template-columns:1fr;}.products__head-meta{justify-self:start;}}
/* Tone-light overrides : .product-card sur fond clair */
.hub-section--tone-light .products__head h2{color:var(--color-text-primary);}
.hub-section--tone-light .products__head-meta{color:var(--color-text-muted);}
.hub-section--tone-light .products__head-meta b{color:var(--color-blue);}
.hub-section--tone-light .product-card{background:var(--color-white);border-color:rgb(var(--rgb-navy) / 0.08);box-shadow:0 2px 12px rgb(var(--rgb-navy) / 0.04);}
.hub-section--tone-light .product-card:hover{border-color:rgb(var(--rgb-blue) / 0.30);background:var(--color-white);box-shadow:0 20px 40px rgb(var(--rgb-navy) / 0.08);}
.hub-section--tone-light .product-card--featured{background:linear-gradient(160deg,rgb(var(--rgb-blue) / 0.06) 0%,var(--color-white) 60%);border-color:rgb(var(--rgb-cyan) / 0.30);}
.hub-section--tone-light .product-card h3{color:var(--color-text-primary);}
.hub-section--tone-light .product-card__lead{color:var(--color-text-body);}
.hub-section--tone-light .product-card__mono{color:var(--color-blue);}
.hub-section--tone-light .product-card__specs{border-top-color:var(--color-border-light);border-bottom-color:var(--color-border-light);}
.hub-section--tone-light .product-card__spec span{color:var(--color-text-muted);}
.hub-section--tone-light .product-card__spec b{color:var(--color-text-primary);}
.hub-section--tone-light .product-card__invest-label{color:var(--color-text-muted);}
.hub-section--tone-light .product-card__invest-value{color:var(--color-text-primary);}
.hub-section--tone-light .product-card__cta{background:rgb(var(--rgb-navy) / 0.04);border-color:rgb(var(--rgb-navy) / 0.12);color:var(--color-text-primary);}
.hub-section--tone-light .product-card__cta:hover{background:var(--color-blue);border-color:var(--color-blue);color:var(--color-white);}

/* ===========================================================================
 * Partial : split-illustration-copy.php (.tech)
 * =========================================================================== */
.tech{padding:var(--section-py) 0;}
.tech__head{text-align:center;max-width:64ch;margin:0 auto 64px;}
.tech__head .eyebrow{justify-content:center;}
.tech__visual{position:relative;background:var(--color-navy-deepest);border-radius:var(--radius-xl);padding:clamp(40px,5vw,72px);overflow:hidden;color:var(--color-text-on-dark);}
.tech__visual::before{content:'';position:absolute;top:-200px;right:-100px;width:600px;height:600px;background:radial-gradient(circle,rgb(var(--rgb-blue) / 0.22) 0%,transparent 65%);filter:blur(80px);pointer-events:none;}
.tech__split{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:clamp(40px,5vw,72px);align-items:center;position:relative;z-index:var(--z-raised);}
.tech__diagram{position:relative;aspect-ratio:1.1/1;background:radial-gradient(circle at 75% 35%,rgb(var(--rgb-cyan) / 0.08) 0%,transparent 60%),linear-gradient(180deg,rgb(var(--rgb-on-dark) / 0.04) 0%,rgb(var(--rgb-on-dark) / 0.01) 100%);border-radius:var(--radius-lg);border:1px solid rgb(var(--rgb-on-dark) / 0.08);overflow:hidden;}
.tech__copy h2{font-family:'Inter',sans-serif;font-size:clamp(26px,2.4vw,36px);font-weight:600;letter-spacing:-0.025em;line-height:1.1;color:var(--color-text-on-dark);margin:0 0 24px;text-wrap:balance;}
.tech__copy h2 em{font-style:normal;color:var(--color-cyan-tech);}
.tech__copy p{font-size:15px;line-height:1.7;color:rgb(var(--rgb-on-dark) / 0.72);margin:0 0 20px;}
.tech__params{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px;}
.tech__param{background:rgb(var(--rgb-on-dark) / 0.04);border:1px solid rgb(var(--rgb-on-dark) / 0.08);border-radius:var(--radius-md);padding:14px;}
.tech__param span{font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-cyan-tech);display:block;margin-bottom:4px;}
.tech__param b{font-size:16px;font-weight:600;color:var(--color-text-on-dark);font-variant-numeric:tabular-nums;letter-spacing:-0.01em;}
@media(max-width:900px){.tech__split{grid-template-columns:1fr;}.tech__diagram{aspect-ratio:16/10;max-width:480px;margin:0 auto;}}

/* ===========================================================================
 * Partial : compliance-grid.php
 * =========================================================================== */
.compliance{padding:var(--section-py) 0;}
.compliance--cream{background:var(--color-cream);}
.compliance__head{max-width:60ch;margin:0 auto 56px;text-align:center;}
.compliance__head .eyebrow{justify-content:center;}
.compliance__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.cmpl-card{background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:28px;display:flex;flex-direction:column;gap:14px;transition:border-color 280ms,transform 280ms var(--ease-out);}
.cmpl-card:hover{border-color:rgb(var(--rgb-blue) / 0.28);transform:translateY(-2px);}
.cmpl-card__icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:rgb(var(--rgb-blue) / 0.14);border-radius:var(--radius-md);}
.cmpl-card__icon svg{width:28px;height:28px;color:var(--color-blue);}
.cmpl-card__num{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;color:var(--color-blue);}
.cmpl-card h3{font-family:'Inter',sans-serif;font-size:16px;font-weight:600;letter-spacing:-0.01em;margin:0;color:var(--color-text-primary);}
.cmpl-card p{font-size:13px;color:var(--color-text-body);line-height:1.6;margin:0;flex:1;}
.cmpl-card__ref{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--color-text-muted);letter-spacing:0.06em;padding-top:12px;border-top:1px solid var(--color-border-light);}
@media(max-width:900px){.compliance__grid{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.compliance__grid{grid-template-columns:1fr;}}
/* Tone-dark overrides */
.hub-section--tone-dark .cmpl-card{background:rgb(var(--rgb-on-dark) / 0.04);border-color:rgb(var(--rgb-on-dark) / 0.08);}
.hub-section--tone-dark .cmpl-card:hover{border-color:rgb(var(--rgb-blue-electric) / 0.30);}
.hub-section--tone-dark .cmpl-card__icon{background:rgb(var(--rgb-cyan) / 0.14);}
.hub-section--tone-dark .cmpl-card__icon svg{color:var(--color-cyan-tech);}
.hub-section--tone-dark .cmpl-card__num{color:var(--color-cyan-tech);}
.hub-section--tone-dark .cmpl-card h3{color:var(--color-text-on-dark);}
.hub-section--tone-dark .cmpl-card p{color:rgb(var(--rgb-on-dark) / 0.70);}
.hub-section--tone-dark .cmpl-card__ref{color:rgb(var(--rgb-on-dark) / 0.50);border-top-color:rgb(var(--rgb-on-dark) / 0.10);}

/* ===========================================================================
 * Partial : objections-list.php
 * =========================================================================== */
.obj{padding:var(--section-py) 0;}
.obj__head{max-width:64ch;margin:0 auto 56px;text-align:center;}
.obj__head .eyebrow{justify-content:center;}
.obj__list{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--color-border-medium);}
.obj__item{border-bottom:1px solid var(--color-border-medium);padding:32px 32px 32px 0;}
.obj__item:nth-child(odd){border-right:1px solid var(--color-border-medium);padding-right:48px;}
.obj__item:nth-child(even){padding-left:48px;}
.obj__item-q{display:flex;gap:16px;align-items:flex-start;margin-bottom:14px;}
.obj__item-num{flex-shrink:0;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;letter-spacing:0.14em;color:var(--color-blue);margin-top:4px;}
.obj__item-q p{font-size:18px;font-weight:600;color:var(--color-text-primary);letter-spacing:-0.012em;line-height:1.35;margin:0;}
.obj__item-a{padding-left:36px;font-size:14px;line-height:1.7;color:var(--color-text-body);margin:0;}
@media(max-width:760px){.obj__list{grid-template-columns:1fr;}.obj__item,.obj__item:nth-child(odd),.obj__item:nth-child(even){padding:28px 0;border-right:0;}}
/* Tone-dark overrides */
.hub-section--tone-dark .obj__list{border-top-color:rgb(var(--rgb-on-dark) / 0.15);}
.hub-section--tone-dark .obj__item{border-bottom-color:rgb(var(--rgb-on-dark) / 0.10);}
.hub-section--tone-dark .obj__item:nth-child(odd){border-right-color:rgb(var(--rgb-on-dark) / 0.10);}
.hub-section--tone-dark .obj__item-num{color:var(--color-cyan-tech);}
.hub-section--tone-dark .obj__item-q p{color:var(--color-text-on-dark);}
.hub-section--tone-dark .obj__item-a{color:rgb(var(--rgb-on-dark) / 0.70);}

/* ===========================================================================
 * Partial : faq.php — variante 2 colonnes head/list (vs faq-accordion.php)
 * =========================================================================== */
.faq{padding:var(--section-py) 0;}
.faq__inner{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.6fr);gap:clamp(40px,5vw,80px);}
.faq__head{position:sticky;top:100px;height:fit-content;align-self:start;}
.faq__head h2{font-family:'Inter',sans-serif;font-size:clamp(26px,2.4vw,36px);font-weight:600;letter-spacing:-0.025em;line-height:1.1;color:var(--color-text-primary);margin:14px 0 0;text-wrap:balance;}
.faq__contact{margin-top:28px;padding:24px;background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);}
.faq__contact b{display:block;font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px;}
.faq__contact p{font-size:13px;color:var(--color-text-body);margin:0 0 14px;line-height:1.55;}
.faq__contact-tel{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:600;color:var(--color-blue);display:block;letter-spacing:0.02em;}
.faq__list{display:flex;flex-direction:column;gap:0;}
.faq__item{border-bottom:1px solid var(--color-border-medium);}
.faq__item:first-child{border-top:1px solid var(--color-border-medium);}
.faq__item details{padding:24px 0;}
.faq__item summary{list-style:none;cursor:pointer;display:flex;align-items:flex-start;gap:16px;font-size:clamp(15px,1.2vw,17px);font-weight:600;color:var(--color-text-primary);letter-spacing:-0.01em;line-height:1.4;transition:color 200ms;}
.faq__item summary::-webkit-details-marker{display:none;}
.faq__item summary::before{content:'';flex-shrink:0;width:22px;height:22px;margin-top:3px;background:rgb(var(--rgb-blue) / 0.14);border-radius:50%;background-image:linear-gradient(var(--color-blue),var(--color-blue)),linear-gradient(var(--color-blue),var(--color-blue));background-size:10px 2px,2px 10px;background-position:center,center;background-repeat:no-repeat;transition:transform 250ms var(--ease-out),background-size 250ms;}
.faq__item details[open] summary::before{background-size:10px 2px,2px 0;transform:rotate(180deg);}
.faq__item summary:hover,.faq__item details[open] summary{color:var(--color-blue);}
.faq__item-body{padding:14px 0 4px 38px;font-size:15px;color:var(--color-text-body);line-height:1.7;}
.faq__item-body p{margin:0 0 10px;}
.faq__item-body p:last-child{margin-bottom:0;}
@media(max-width:900px){.faq__inner{grid-template-columns:1fr;}.faq__head{position:static;}}
/* Tone-dark overrides */
.hub-section--tone-dark .faq__head h2{color:var(--color-text-on-dark);}
.hub-section--tone-dark .faq__contact{background:rgb(var(--rgb-on-dark) / 0.06);border-color:rgb(var(--rgb-on-dark) / 0.10);}
.hub-section--tone-dark .faq__contact b{color:var(--color-text-on-dark);}
.hub-section--tone-dark .faq__contact p{color:rgb(var(--rgb-on-dark) / 0.70);}
.hub-section--tone-dark .faq__contact-tel{color:var(--color-cyan-tech);}
.hub-section--tone-dark .faq__item{border-bottom-color:rgb(var(--rgb-on-dark) / 0.10);}
.hub-section--tone-dark .faq__item:first-child{border-top-color:rgb(var(--rgb-on-dark) / 0.10);}
.hub-section--tone-dark .faq__item summary{color:var(--color-text-on-dark);}
.hub-section--tone-dark .faq__item summary::before{background:rgb(var(--rgb-cyan) / 0.14);background-image:linear-gradient(var(--color-cyan-tech),var(--color-cyan-tech)),linear-gradient(var(--color-cyan-tech),var(--color-cyan-tech));}
.hub-section--tone-dark .faq__item summary:hover,.hub-section--tone-dark .faq__item details[open] summary{color:var(--color-cyan-tech);}
.hub-section--tone-dark .faq__item-body{color:rgb(var(--rgb-on-dark) / 0.70);}

/* ===========================================================================
 * Partial : machines-grid.php — 2 rows asymétriques + bandeau actions
 * =========================================================================== */
.hub-machines-row1{display:grid;grid-template-columns:1.4fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6);}
.hub-machines-row2{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-6);}
.hub-machines-actions{margin-top:var(--space-7);display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center;}
@media(max-width:1023px){.hub-machines-row1,.hub-machines-row2{grid-template-columns:1fr;}}

/* ===========================================================================
 * Partial : tco-grid.php — 3 cards TCO + disclaimer + CTA
 * =========================================================================== */
.hub-tco-grid{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:var(--space-5);margin-top:var(--space-7);}
.hub-tco-disclaimer{margin-top:var(--space-7);padding:16px 20px;font-size:12px;line-height:1.75;color:rgb(var(--rgb-on-dark) / 0.42);}
.hub-tco-cta-row{margin-top:var(--space-7);text-align:center;}
@media(max-width:1023px){.hub-tco-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.hub-tco-grid{grid-template-columns:1fr;}}

/* ===========================================================================
 * Partial : engagements-grid.php — 2 rows asymétriques + bandeau spotlight
 * =========================================================================== */
.hub-eng-row1{display:grid;grid-template-columns:1.4fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6);}
.hub-eng-row2{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-6);}
.hub-eng-band{
    display:grid;grid-template-columns:1fr auto;gap:var(--space-7);align-items:center;
    margin-top:var(--space-6);
    background:rgb(var(--rgb-blue) / 0.08);
    border:1px solid rgb(var(--rgb-blue) / 0.30);
    border-radius:var(--radius-lg);
    padding:var(--space-6) var(--space-7);
}
.hub-eng-band__num{font-size:10px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--color-cyan-tech);margin:0 0 12px;}
.hub-eng-band__h3{font-family:'Inter',system-ui,sans-serif;font-size:22px;font-weight:600;color:var(--color-text-on-dark);margin:0 0 10px;letter-spacing:-0.02em;}
.hub-eng-band__desc{font-size:14px;color:rgb(var(--rgb-on-dark) / 0.60);margin:0;line-height:1.6;}
.hub-eng-band__cta{white-space:nowrap;align-self:center;}
@media(max-width:1023px){.hub-eng-row1,.hub-eng-row2{grid-template-columns:1fr;}}
@media(max-width:767px){.hub-eng-band{grid-template-columns:1fr;}}

/* ===========================================================================
 * Partial : faq-accordion.php — FAQ accordion + footer CTA
 * =========================================================================== */
.hub-faq{max-width:800px;margin:0 auto;}
.hub-faq details{background:var(--color-white);border-radius:var(--radius-lg);margin-bottom:8px;box-shadow:var(--shadow-sm);overflow:hidden;}
.hub-faq summary{padding:20px 28px;font-family:'Inter',system-ui,sans-serif;font-size:clamp(15px,1.6vw,17px);font-weight:600;line-height:1.35;color:var(--color-text-primary);cursor:pointer;display:flex;justify-content:space-between;align-items:center;list-style:none;user-select:none;gap:16px;}
.hub-faq summary::-webkit-details-marker{display:none;}
.hub-faq summary svg{flex-shrink:0;transition:transform 300ms;color:var(--color-text-muted);}
.hub-faq details[open] summary svg{transform:rotate(180deg);}
.hub-faq__answer{padding:0 28px 20px;font-size:14px;line-height:1.75;color:var(--color-text-body);}
.hub-faq__footer{text-align:center;margin-top:var(--space-7);font-family:'Inter',system-ui,sans-serif;font-size:15px;color:var(--color-text-body);}
.hub-faq__footer-cta{color:var(--color-blue);font-weight:600;text-decoration:none;}
.hub-section--tone-dark .hub-faq details{background:rgb(var(--rgb-on-dark) / 0.04);box-shadow:none;border:1px solid rgb(var(--rgb-on-dark) / 0.08);}
.hub-section--tone-dark .hub-faq summary{color:var(--color-text-on-dark);}
.hub-section--tone-dark .hub-faq__answer{color:rgb(var(--rgb-on-dark) / 0.70);}
.hub-section--tone-dark .hub-faq__footer{color:rgb(var(--rgb-on-dark) / 0.65);}
.hub-section--tone-dark .hub-faq__footer-cta{color:var(--color-cyan-tech);}

/* ===========================================================================
 * Layout fiche-produit (.pmed-page) — typo, boutons, authband
 * Sections (.p-hero, .presentation, .indications, .schema, .fiche, .testim, .roi)
 * sont des classes de LAYOUT — leur bg/color est géré par .hub-section--tone-*.
 * =========================================================================== */
.pmed-page{background:var(--color-off-white);--section-py:var(--section-default);--accent:var(--color-blue);--accent-hover:var(--color-blue-hover);--accent-soft:rgb(var(--c-accent) / 0.14);}
.pmed-page .wrap{max-width:1320px;margin:0 auto;padding:0 clamp(20px,4vw,56px);}
.pmed-page .h2{font-family:'Inter',sans-serif;font-size:clamp(28px,2.6vw,40px);font-weight:600;letter-spacing:-0.025em;line-height:1.12;text-wrap:balance;margin:0 0 16px;}
.pmed-page .h2--light{color:var(--color-text-primary);}
.pmed-page .h2--dark{color:var(--color-text-on-dark);}
.pmed-page .lead-light{color:var(--color-text-body);font-size:clamp(15px,1.15vw,17px);margin:0;line-height:1.7;}
.pmed-page .lead-dark{color:rgb(var(--rgb-on-dark) / 0.66);font-size:clamp(15px,1.15vw,17px);margin:0;line-height:1.7;}
.pmed-page .btn--outline{background:transparent;color:var(--color-text-primary);border:1px solid var(--color-border-medium);}
.pmed-page .btn--outline:hover{border-color:var(--color-blue);color:var(--color-blue);}

/* Authband (S01b) — bandeau autorisation MEDIC/ESTH/dual */
.pmed-page__authband{background:var(--color-cream);border-block:1px solid var(--color-border-light);padding:14px 0;}
.pmed-page__authband--medic{background:rgb(var(--c-accent) / 0.06);border-color:rgb(var(--c-accent) / 0.18);}
.pmed-page__authband--esth{background:rgb(var(--rgb-cyan) / 0.05);border-color:rgb(var(--rgb-cyan) / 0.20);}
.pmed-page__authband--dual{background:var(--color-cream);border-color:var(--color-border-medium);}
.pmed-page__authband-inner{display:flex;align-items:center;justify-content:space-between;gap:clamp(16px,2vw,32px);flex-wrap:wrap;}
.pmed-page__authband-stamp{display:inline-flex;align-items:center;gap:14px;}
.pmed-page__authband-eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;padding:4px 10px;border-radius:var(--radius-sm);background:rgb(var(--rgb-navy) / 0.08);color:var(--color-text-primary);}
.pmed-page__authband--medic .pmed-page__authband-eyebrow{background:var(--color-blue);color:var(--color-white);}
.pmed-page__authband--esth .pmed-page__authband-eyebrow{background:var(--color-cyan-tech);color:var(--color-navy-deepest);}
.pmed-page__authband-aud{font-family:'Inter',sans-serif;font-size:14px;font-weight:500;color:var(--color-text-primary);}
.pmed-page__authband-cross{font-family:'Inter',sans-serif;font-size:13px;line-height:1.4;color:var(--color-text-body);text-decoration:none;transition:color 200ms;max-width:580px;}
.pmed-page__authband-cross strong{color:var(--color-blue);font-weight:600;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;}
.pmed-page__authband-cross:hover{color:var(--color-text-primary);}
.pmed-page__authband-cross:hover strong{color:var(--color-blue-hover);}
.pmed-page__authband-cross--none{color:var(--color-text-muted);font-style:italic;}
@media(max-width:768px){.pmed-page__authband-inner{flex-direction:column;align-items:flex-start;}.pmed-page__authband-cross{font-size:12px;}}

/* ===========================================================================
 * Partial : product-hero.php (S01 fiche produit)
 * =========================================================================== */
.pmed-page .p-hero{position:relative;background:var(--color-navy-deepest);color:var(--color-text-on-dark);overflow:hidden;min-height:max(620px,calc(100svh - 72px));display:flex;align-items:center;padding:clamp(56px,6vw,88px) 0 clamp(44px,5vw,72px);}
.pmed-page .p-hero__bg{position:absolute;inset:0;z-index:var(--z-base);}
.pmed-page .p-hero__bg-img{width:100%;height:100%;object-fit:cover;object-position:right center;opacity:0.5;}
.pmed-page .p-hero__bg-shade{position:absolute;inset:0;background:linear-gradient(105deg,rgb(var(--rgb-navy-deepest) / 0.96) 0%,rgb(var(--rgb-navy-deepest) / 0.78) 45%,rgb(var(--rgb-navy-deepest) / 0.32) 80%,rgb(var(--rgb-navy-deepest) / 0.10) 100%);}
.pmed-page .p-hero__grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgb(var(--rgb-blue-electric) / 0.05) 1px,transparent 1px),linear-gradient(90deg,rgb(var(--rgb-blue-electric) / 0.05) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse at center,#000 30%,transparent 70%);pointer-events:none;}
.pmed-page .p-hero__inner{position:relative;z-index:var(--z-float);width:100%;}
.pmed-page .p-hero__split{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:clamp(40px,5vw,80px);align-items:center;}
.pmed-page .p-hero__copy{min-width:0;}
.pmed-page .p-hero__brandline{display:inline-flex;align-items:center;gap:14px;background:rgb(var(--rgb-on-dark) / 0.06);border:1px solid rgb(var(--rgb-on-dark) / 0.12);border-radius:var(--radius-pill);padding:8px 16px 8px 8px;margin-bottom:22px;font-size:12px;color:rgb(var(--rgb-on-dark) / 0.85);}
.pmed-page .p-hero__brandline-badge{background:var(--color-blue);color:var(--color-white);font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;padding:4px 10px;border-radius:var(--radius-pill);}
.pmed-page .p-hero__brandline b{color:var(--color-text-on-dark);font-weight:600;}
.pmed-page .p-hero__brandline span{color:rgb(var(--rgb-on-dark) / 0.55);}
.pmed-page .p-hero__name{font-family:'Inter',sans-serif;font-size:clamp(56px,6.8vw,92px);font-weight:700;line-height:0.95;letter-spacing:-0.045em;color:var(--color-text-on-dark);margin:0 0 14px;}
.pmed-page .p-hero__name-dot{background:linear-gradient(120deg,var(--color-blue-electric) 0%,var(--color-cyan-tech) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.pmed-page .p-hero__title{font-family:'Inter',sans-serif;font-size:clamp(22px,2.4vw,34px);font-weight:500;line-height:1.2;letter-spacing:-0.02em;margin:0 0 18px;text-wrap:balance;color:rgb(var(--rgb-on-dark) / 0.92);max-width:22ch;}
.pmed-page .p-hero__title em{font-style:normal;background:linear-gradient(120deg,var(--color-blue-electric) 0%,var(--color-cyan-tech) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.pmed-page .p-hero__lead{font-size:clamp(15px,1.1vw,17px);color:rgb(var(--rgb-on-dark) / 0.72);max-width:52ch;margin:0 0 24px;line-height:1.55;}
.pmed-page .p-hero__actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:28px;}
.pmed-page .p-hero__keyspecs{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding-top:28px;border-top:1px solid rgb(var(--rgb-on-dark) / 0.1);}
.pmed-page .p-hero__keyspec{padding-right:16px;border-right:1px solid rgb(var(--rgb-on-dark) / 0.08);}
.pmed-page .p-hero__keyspec:last-child{border-right:0;}
.pmed-page .p-hero__keyspec-label{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-cyan-tech);display:block;margin-bottom:6px;}
.pmed-page .p-hero__keyspec-value{font-size:clamp(18px,1.5vw,22px);font-weight:600;color:var(--color-text-on-dark);letter-spacing:-0.015em;font-variant-numeric:tabular-nums;line-height:1.1;}
.pmed-page .p-hero__keyspec-value sup{font-size:0.55em;color:rgb(var(--rgb-on-dark) / 0.6);margin-left:2px;vertical-align:0.5em;font-weight:500;}
.pmed-page .p-hero__product{position:relative;display:flex;align-items:center;justify-content:center;min-height:540px;}
.pmed-page .p-hero__product-glow{position:absolute;inset:-10%;background:radial-gradient(circle at center,rgb(var(--rgb-blue) / 0.5) 0%,rgb(var(--rgb-blue) / 0.15) 35%,transparent 65%);filter:blur(60px);z-index:var(--z-base);animation:aura-pulse 4.5s ease-in-out infinite;}
.pmed-page .p-hero__product img{position:relative;z-index:var(--z-pop);max-width:520px;width:100%;filter:drop-shadow(0 30px 60px rgb(0 0 0 / 0.55));animation:hero-zoom 1500ms var(--ease-out);}
.pmed-page .p-hero__tag{position:absolute;z-index:var(--z-overlay);background:rgb(var(--rgb-navy) / 0.85);border:1px solid rgb(var(--rgb-blue-electric) / 0.3);border-radius:8px;padding:10px 14px;font-size:11px;display:flex;flex-direction:column;gap:2px;white-space:nowrap;}
.pmed-page .p-hero__tag b{font-family:'JetBrains Mono',monospace;color:var(--color-cyan-tech);font-size:10px;letter-spacing:0.12em;font-weight:600;}
.pmed-page .p-hero__tag span{color:rgb(var(--rgb-on-dark) / 0.85);font-weight:500;}
.pmed-page .p-hero__tag::before{content:'';position:absolute;width:8px;height:8px;background:var(--color-cyan-tech);border-radius:50%;box-shadow:0 0 0 4px rgb(var(--rgb-cyan) / 0.18),0 0 12px var(--color-cyan-tech);}
.pmed-page .p-hero__tag--1{top:10%;left:-4%;}
.pmed-page .p-hero__tag--1::before{right:-32px;top:50%;transform:translateY(-50%);}
.pmed-page .p-hero__tag--2{bottom:18%;right:-2%;}
.pmed-page .p-hero__tag--2::before{left:-32px;top:50%;transform:translateY(-50%);}
.pmed-page .p-hero__tag--3{top:48%;right:-8%;}
.pmed-page .p-hero__tag--3::before{left:-32px;top:50%;transform:translateY(-50%);}
@media(max-width:1024px){.pmed-page .p-hero__split{grid-template-columns:1fr;}.pmed-page .p-hero__product{min-height:380px;}.pmed-page .p-hero__keyspecs{grid-template-columns:repeat(2,1fr);gap:20px 0;}.pmed-page .p-hero__keyspec:nth-child(2){border-right:0;}}

/* ===========================================================================
 * Partial : statsbar.php (variante 'page' — fiche-produit S02)
 * =========================================================================== */
.pmed-page .statsbar{background:var(--color-white);border-bottom:1px solid var(--color-border-light);padding:clamp(24px,3vw,40px) 0;}
.pmed-page .statsbar-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;}
.pmed-page .statsbar-item{text-align:left;padding:0 28px;position:relative;display:flex;flex-direction:column;gap:8px;}
.pmed-page .statsbar-item:first-child{padding-left:0;}
.pmed-page .statsbar-item:last-child{padding-right:0;}
.pmed-page .statsbar-item:not(:last-child)::after{content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:56px;background:var(--color-border-light);}
.pmed-page .statsbar-eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-blue);}
.pmed-page .statsbar-num{font-size:clamp(26px,2.2vw,34px);font-weight:700;letter-spacing:-0.03em;line-height:1;color:var(--color-text-primary);font-variant-numeric:tabular-nums;}
.pmed-page .statsbar-num small{font-size:0.55em;color:var(--color-text-body);font-weight:500;margin-left:0;vertical-align:baseline;}
.pmed-page .statsbar-label{font-size:12px;font-weight:500;color:var(--color-text-body);line-height:1.45;}
@media(max-width:980px){.pmed-page .statsbar-grid{grid-template-columns:repeat(2,1fr);gap:28px 0;}.pmed-page .statsbar-item{padding:0 16px;}.pmed-page .statsbar-item:first-child,.pmed-page .statsbar-item:nth-child(odd){padding-left:0;}.pmed-page .statsbar-item:nth-child(even){padding-right:0;}.pmed-page .statsbar-item:not(:last-child)::after{display:none;}}

/* ===========================================================================
 * Partial : product-presentation.php (S03 fiche produit)
 * =========================================================================== */
.pmed-page .presentation{padding:var(--section-py) 0;}
.pmed-page .pres-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:clamp(48px,6vw,96px);align-items:center;}
.pmed-page .pres-photo{position:relative;border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:4/5;background:var(--color-cream);box-shadow:var(--shadow-md);}
.pmed-page .pres-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.pmed-page .pres-photo__caption{position:absolute;left:24px;bottom:24px;background:rgb(var(--rgb-navy) / 0.92);color:var(--color-text-on-dark);border-radius:var(--radius-md);padding:14px 18px;max-width:280px;}
.pmed-page .pres-photo__caption b{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-cyan-tech);margin-bottom:4px;}
.pmed-page .pres-photo__caption span{font-size:13px;line-height:1.4;color:rgb(var(--rgb-on-dark) / 0.85);}
.pmed-page .pres-copy{max-width:56ch;}
.pmed-page .pres-copy h2{font-family:'Inter',sans-serif;font-size:clamp(28px,2.8vw,40px);font-weight:600;letter-spacing:-0.03em;line-height:1.1;margin:0 0 24px;color:var(--color-text-primary);text-wrap:balance;}
.pmed-page .pres-copy h2 em{font-style:normal;color:var(--color-blue);}
.pmed-page .pres-copy p{font-size:16px;color:var(--color-text-body);line-height:1.7;margin:0 0 16px;}
.pmed-page .pres-copy p strong{color:var(--color-text-primary);font-weight:600;}
.pmed-page .pres-quickspecs{margin-top:32px;display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding-top:28px;border-top:1px solid var(--color-border-medium);}
.pmed-page .pres-quickspec{padding-right:16px;border-right:1px solid var(--color-border-light);}
.pmed-page .pres-quickspec:last-child{border-right:0;}
.pmed-page .pres-quickspec-icon{width:28px;height:28px;margin-bottom:12px;color:var(--color-blue);display:flex;align-items:center;justify-content:center;}
.pmed-page .pres-quickspec b{font-size:clamp(18px,1.5vw,24px);font-weight:700;letter-spacing:-0.02em;color:var(--color-text-primary);display:block;line-height:1.1;font-variant-numeric:tabular-nums;margin-bottom:4px;}
.pmed-page .pres-quickspec span{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-text-muted);}
@media(max-width:900px){.pmed-page .pres-grid{grid-template-columns:1fr;}.pmed-page .pres-photo{aspect-ratio:16/10;max-width:560px;}}

/* ===========================================================================
 * S04 indications (via centered-cards-grid.php — card-indication)
 * =========================================================================== */
.pmed-page .indications{padding:var(--section-py) 0;position:relative;}
.pmed-page .ind__head{text-align:center;max-width:64ch;margin:0 auto 64px;}
.pmed-page .ind__head .eyebrow{justify-content:center;}
.pmed-page .ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.pmed-page .ind-card{background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:32px;display:flex;flex-direction:column;gap:16px;position:relative;transition:border-color 280ms,transform 280ms var(--ease-out),box-shadow 280ms;overflow:hidden;}
.pmed-page .ind-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-blue);transform:scaleX(0);transform-origin:left;transition:transform 320ms var(--ease-out);}
.pmed-page .ind-card:hover{border-color:rgb(var(--rgb-blue) / 0.28);transform:translateY(-3px);box-shadow:0 16px 40px rgb(var(--rgb-navy) / 0.08);}
.pmed-page .ind-card:hover::before{transform:scaleX(1);}
.pmed-page .ind-card__num{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-blue);}
.pmed-page .ind-card__icon{width:56px;height:56px;background:rgb(var(--rgb-blue) / 0.14);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:4px;color:var(--color-blue);}
.pmed-page .ind-card h3{font-family:'Inter',sans-serif;font-size:19px;font-weight:600;letter-spacing:-0.015em;line-height:1.25;color:var(--color-text-primary);margin:0;}
.pmed-page .ind-card > p{font-size:14px;color:var(--color-text-body);line-height:1.65;margin:0;}
.pmed-page .ind-card__list{list-style:none;padding:16px 0 0;margin:8px 0 0;display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--color-text-body);border-top:1px solid var(--color-border-light);}
.pmed-page .ind-card__list li{display:flex;align-items:flex-start;gap:10px;}
.pmed-page .ind-card__list li::before{content:'';flex-shrink:0;width:6px;height:6px;margin-top:9px;background:var(--color-blue);border-radius:50%;}
@media(max-width:900px){.pmed-page .ind-grid{grid-template-columns:1fr;}}

/* ===========================================================================
 * Partial : visual-with-legend.php (S05 schema fiche-produit)
 * =========================================================================== */
.pmed-page .schema{padding:var(--section-py) 0;position:relative;overflow:hidden;}
.pmed-page .schema__head{text-align:center;max-width:60ch;margin:0 auto 56px;position:relative;z-index:var(--z-raised);}
.pmed-page .schema__head .eyebrow{justify-content:center;}
.pmed-page .schema__visual{position:relative;z-index:var(--z-raised);max-width:1100px;margin:0 auto;}
.pmed-page .schema__img-wrap{position:relative;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;}
.pmed-page .schema__img-glow{position:absolute;inset:5%;background:radial-gradient(ellipse at center,rgb(var(--rgb-blue) / 0.4) 0%,transparent 60%);filter:blur(40px);}
.pmed-page .schema__img-wrap img{position:relative;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 20px 40px rgb(var(--rgb-navy-deepest) / 0.45));}
.pmed-page .schema__legend{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:40px;padding:32px;background:rgb(var(--rgb-on-dark) / 0.04);border:1px solid rgb(var(--rgb-on-dark) / 0.08);border-radius:var(--radius-xl);}
.pmed-page .schema__legend-item{display:flex;gap:18px;align-items:flex-start;}
.pmed-page .schema__legend-num{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--color-blue);color:var(--color-white);font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;letter-spacing:0.04em;}
.pmed-page .schema__legend-body b{display:block;font-size:16px;color:var(--color-text-on-dark);font-weight:600;margin-bottom:4px;letter-spacing:-0.01em;}
.pmed-page .schema__legend-body span{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--color-cyan-tech);letter-spacing:0.08em;display:block;margin-bottom:8px;}
.pmed-page .schema__legend-body p{font-size:14px;color:rgb(var(--rgb-on-dark) / 0.66);line-height:1.6;margin:0;}
@media(max-width:760px){.pmed-page .schema__legend{grid-template-columns:1fr;gap:24px;padding:24px;}}

/* ===========================================================================
 * Partial : spec-grid.php (S06 fiche technique fiche-produit)
 * =========================================================================== */
.pmed-page .fiche{padding:var(--section-py) 0;}
.pmed-page .fiche__head{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:56px;margin-bottom:64px;align-items:end;}
.pmed-page .fiche__head h2{font-family:'Inter',sans-serif;font-size:clamp(28px,2.8vw,40px);font-weight:600;letter-spacing:-0.025em;line-height:1.1;margin:14px 0 16px;color:var(--color-text-primary);text-wrap:balance;}
.pmed-page .fiche__head-actions{display:flex;gap:12px;flex-wrap:wrap;align-self:flex-end;justify-content:flex-end;}
.pmed-page .fiche__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--color-border-light);border-radius:var(--radius-xl);overflow:hidden;background:var(--color-white);}
.pmed-page .fiche__group{padding:32px;border-bottom:1px solid var(--color-border-light);}
.pmed-page .fiche__group:nth-child(odd){border-right:1px solid var(--color-border-light);}
.pmed-page .fiche__group:nth-last-child(-n+2){border-bottom:0;}
.pmed-page .fiche__group-title{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--color-text-muted);margin:0 0 20px;padding-bottom:16px;border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between;}
.pmed-page .fiche__group-title-num{color:var(--color-blue);font-weight:600;}
.pmed-page .fiche__row{display:grid;grid-template-columns:24px 1fr auto;gap:14px;align-items:center;padding:10px 0;font-size:14px;border-bottom:1px dashed var(--color-border-light);}
.pmed-page .fiche__row:last-child{border-bottom:0;}
.pmed-page .fiche__row-icon{color:var(--color-blue);opacity:0.7;display:inline-flex;}
.pmed-page .fiche__row-label{color:var(--color-text-body);font-weight:500;}
.pmed-page .fiche__row-value{font-weight:600;color:var(--color-text-primary);font-variant-numeric:tabular-nums;text-align:right;font-size:14px;}
.pmed-page .fiche__row-value small{font-family:'JetBrains Mono',monospace;font-weight:500;color:var(--color-text-muted);margin-left:4px;font-size:11px;}
@media(max-width:900px){.pmed-page .fiche__head{grid-template-columns:1fr;gap:24px;}.pmed-page .fiche__head-actions{justify-content:flex-start;}.pmed-page .fiche__grid{grid-template-columns:1fr;}.pmed-page .fiche__group:nth-child(odd){border-right:0;}.pmed-page .fiche__group:nth-last-child(2){border-bottom:1px solid var(--color-border-light);}}

/* ===========================================================================
 * S07 testimonials variant fiche-produit (via testimonials-grid.php — card-testimonial-quote)
 * =========================================================================== */
.pmed-page .testim{padding:var(--section-py) 0;position:relative;overflow:hidden;}
.pmed-page .testim__head{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:32px;align-items:end;margin-bottom:56px;position:relative;z-index:var(--z-raised);}
.pmed-page .testim__head h2{color:var(--color-text-on-dark);}
.pmed-page .testim__head-meta{display:flex;align-items:center;gap:14px;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgb(var(--rgb-on-dark) / 0.55);letter-spacing:0.06em;justify-self:end;}
.pmed-page .testim__head-meta b{color:var(--color-text-on-dark);font-weight:600;font-size:14px;letter-spacing:-0.01em;}
.pmed-page .testim__row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;z-index:var(--z-raised);}
.pmed-page .testim__card{background:rgb(var(--rgb-on-dark) / 0.04);border:1px solid rgb(var(--rgb-on-dark) / 0.08);border-radius:var(--radius-xl);padding:28px;display:flex;flex-direction:column;transition:border-color 280ms,transform 280ms var(--ease-out),background 280ms;position:relative;}
.pmed-page .testim__card:hover{border-color:rgb(var(--rgb-blue) / 0.4);transform:translateY(-3px);background:rgb(var(--rgb-on-dark) / 0.06);}
.pmed-page .testim__quote-mark{font-size:64px;line-height:0.6;color:var(--color-blue);font-family:Georgia,serif;margin-bottom:8px;opacity:0.9;}
.pmed-page .testim__quote{font-size:16px;line-height:1.55;color:rgb(var(--rgb-on-dark) / 0.85);margin:0 0 24px;flex:1;font-weight:400;letter-spacing:-0.005em;}
.pmed-page .testim__person{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid rgb(var(--rgb-on-dark) / 0.08);}
.pmed-page .testim__avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-blue) 0%,var(--color-blue-electric) 100%);border:2px solid rgb(var(--rgb-blue-electric) / 0.25);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;color:var(--color-text-on-dark);letter-spacing:0.05em;}
.pmed-page .testim__person-info b{display:block;font-size:14px;font-weight:600;color:var(--color-text-on-dark);letter-spacing:-0.005em;}
.pmed-page .testim__person-info span{display:block;font-size:12px;color:rgb(var(--rgb-on-dark) / 0.55);margin-top:2px;}
.pmed-page .testim__person-info span.flag{display:inline;margin-right:4px;}
@media(max-width:900px){.pmed-page .testim__row{grid-template-columns:1fr;}.pmed-page .testim__head{grid-template-columns:1fr;}.pmed-page .testim__head-meta{justify-self:start;}}

/* ===========================================================================
 * Partial : roi-bar-chart.php (S08 fiche produit)
 * =========================================================================== */
.pmed-page .roi{padding:var(--section-py) 0;}
.pmed-page .roi__inner{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:clamp(48px,6vw,96px);align-items:center;}
.pmed-page .roi__big{font-size:clamp(72px,8vw,120px);font-weight:700;letter-spacing:-0.045em;line-height:0.9;color:var(--color-blue);font-variant-numeric:tabular-nums;margin:0 0 20px;display:block;}
.pmed-page .roi__big sup{font-size:0.32em;color:rgb(var(--rgb-blue) / 0.65);font-weight:600;margin-left:6px;vertical-align:0.65em;}
.pmed-page .roi__caption{font-size:clamp(18px,1.4vw,22px);font-weight:500;letter-spacing:-0.012em;line-height:1.35;color:var(--color-text-primary);max-width:30ch;margin:0 0 20px;text-wrap:balance;}
.pmed-page .roi__source{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-text-muted);}
.pmed-page .roi__chart{display:flex;flex-direction:column;gap:18px;background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-sm);}
.pmed-page .roi__chart-label{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:10px;}
.pmed-page .roi__bar{display:grid;grid-template-columns:60px 1fr 92px;gap:14px;align-items:center;font-size:13px;}
.pmed-page .roi__bar-y{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;color:var(--color-text-muted);letter-spacing:0.05em;}
.pmed-page .roi__bar-fill{height:22px;border-radius:6px;background:linear-gradient(90deg,var(--color-blue) 0%,rgb(var(--rgb-blue) / 0.6) 100%);transform-origin:left center;animation:bar-grow 1200ms var(--ease-out) backwards;}
.pmed-page .roi__bar-fill--accent{background:linear-gradient(90deg,var(--color-cyan-tech) 0%,var(--color-blue) 100%);}
.pmed-page .roi__bar-val{font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text-primary);text-align:right;font-size:14px;}
@media(max-width:900px){.pmed-page .roi__inner{grid-template-columns:1fr;}}

/* Reduced motion fiche-produit */
@media(prefers-reduced-motion:reduce){
    .pmed-page .p-hero__product-glow,
    .pmed-page .p-hero__product img,
    .pmed-page .roi__bar-fill{animation:none !important;}
}

/* ===========================================================================
 * Pages marques + mise-en-relation (Phase 2.4)
 * Classes globales sans scope parent — utilisables par tous les templates.
 * =========================================================================== */

/* Eyebrow accent variants → migrés vers tokens.css (.eyebrow--accent, .eyebrow--accent-strong) */

/* ===========================================================================
 * Template : marques-detail — sections bt-marque-*
 * =========================================================================== */

/* About — storytelling marque */
.bt-marque-about{background:var(--color-off-white);padding:var(--section-default) 0;}
.bt-marque-about__grid{display:grid;grid-template-columns:minmax(0,0.9fr) minmax(0,1.4fr);gap:clamp(40px,5vw,80px);align-items:start;}
.bt-marque-about__h2{font-family:'Inter',sans-serif;font-size:clamp(28px,3.2vw,44px);font-weight:600;letter-spacing:-0.03em;line-height:1.1;color:var(--color-text-primary);margin:12px 0 0;text-wrap:balance;max-width:22ch;}
.bt-marque-about__copy p{font-size:15px;line-height:1.7;color:var(--color-text-body);margin:0 0 16px;max-width:60ch;}
.bt-marque-about__copy strong{color:var(--color-text-primary);font-weight:600;}
@media(max-width:900px){.bt-marque-about__grid{grid-template-columns:1fr;}}

/* Specs — fiche d'identité */
.bt-marque-specs{background:var(--color-cream);padding:var(--section-default) 0;}
.bt-marque-specs__inner{max-width:760px;}
.bt-marque-specs__h2{font-family:'Inter',sans-serif;font-size:clamp(22px,2.4vw,30px);font-weight:600;letter-spacing:-0.025em;line-height:1.15;color:var(--color-text-primary);margin:12px 0 32px;}

/* Products — produits référencés */
.bt-marque-products{background:var(--color-off-white);padding:var(--section-default) 0;}
.bt-marque-products__header{margin:0 0 clamp(32px,4vw,48px);}
.bt-marque-products__h2{font-family:'Inter',sans-serif;font-size:clamp(24px,2.8vw,34px);font-weight:600;letter-spacing:-0.025em;line-height:1.15;color:var(--color-text-primary);margin:12px 0 0;max-width:24ch;}
.bt-marque-products__grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.bt-marque-products__grid li a{display:flex;flex-direction:column;gap:14px;padding:clamp(24px,3vw,36px);background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);text-decoration:none;transition:border-color 280ms,transform 280ms var(--ease-out),box-shadow 280ms;height:100%;}
.bt-marque-products__grid li a:hover{border-color:rgb(var(--rgb-blue) / 0.25);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.bt-marque-products__cat{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-blue);}
.bt-marque-products__grid h3{font-family:'Inter',sans-serif;font-size:clamp(20px,2.2vw,26px);font-weight:700;letter-spacing:-0.025em;color:var(--color-text-primary);margin:0;line-height:1.15;}
.bt-marque-products__grid p{font-size:14px;line-height:1.65;color:var(--color-text-body);margin:0;flex:1;}
.bt-marque-products__cta{font-size:14px;font-weight:600;color:var(--color-blue);margin-top:auto;display:inline-flex;align-items:center;gap:6px;transition:gap 150ms;}
.bt-marque-products__grid li a:hover .bt-marque-products__cta{gap:10px;}
@media(max-width:768px){.bt-marque-products__grid{grid-template-columns:1fr;}}

/* Proof strip — 4 garanties */
.bt-marque-proof{background:var(--color-cream);padding:clamp(40px,5vw,64px) 0;border-bottom:1px solid var(--color-border-light);}
.bt-marque-proof__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.bt-marque-proof__item{padding:8px clamp(16px,2vw,28px);border-right:1px solid var(--color-border-light);}
.bt-marque-proof__item:last-child{border-right:0;}
.bt-marque-proof__title{font-family:'Inter',sans-serif;font-size:clamp(18px,1.8vw,22px);font-weight:600;letter-spacing:-0.02em;color:var(--color-text-primary);margin:0 0 8px;line-height:1.2;}
.bt-marque-proof__desc{font-size:13px;line-height:1.55;color:var(--color-text-body);margin:0;}
@media(max-width:900px){.bt-marque-proof__grid{grid-template-columns:1fr 1fr;row-gap:24px;}.bt-marque-proof__item:nth-child(2n){border-right:0;}.bt-marque-proof__item:nth-child(-n+2){border-bottom:1px solid var(--color-border-light);padding-bottom:24px;}}
@media(max-width:560px){.bt-marque-proof__grid{grid-template-columns:1fr;}.bt-marque-proof__item{border-right:0;border-bottom:1px solid var(--color-border-light);padding:16px 0;}.bt-marque-proof__item:last-child{border-bottom:0;}}

/* Decision tree — 3 cards orientation */
.bt-marque-decision{background:var(--color-off-white);padding:var(--section-default) 0;}
.bt-marque-decision__head{max-width:880px;margin:0 auto clamp(40px,5vw,64px);}
.bt-marque-decision__h2{font-family:'Inter',sans-serif;font-size:clamp(28px,3vw,44px);font-weight:600;letter-spacing:-0.025em;line-height:1.12;color:var(--color-text-primary);margin:12px 0 0;max-width:22ch;text-wrap:balance;}
.bt-marque-decision__h2 em{font-style:normal;color:var(--color-blue);}
.bt-marque-decision__lead{font-size:clamp(15px,1.2vw,17px);line-height:1.65;color:var(--color-text-body);max-width:60ch;margin:16px 0 0;}
.bt-marque-decision__grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.bt-marque-decision__card{background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:32px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;transition:border-color 280ms,transform 280ms var(--ease-out),box-shadow 280ms;}
.bt-marque-decision__card:hover{border-color:rgb(var(--rgb-blue) / 0.25);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.bt-marque-decision__num{font-family:'Inter',sans-serif;font-size:13px;font-weight:700;color:rgb(var(--rgb-navy) / 0.30);font-variant-numeric:tabular-nums;margin:0 0 -8px;}
.bt-marque-decision__role{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-blue);margin:0;}
.bt-marque-decision__title{font-family:'Inter',sans-serif;font-size:clamp(20px,2vw,24px);font-weight:600;letter-spacing:-0.025em;line-height:1.2;color:var(--color-text-primary);margin:0;}
.bt-marque-decision__desc{font-size:14px;line-height:1.65;color:var(--color-text-body);margin:0;flex:1;}
.bt-marque-decision__cta{font-size:14px;font-weight:600;color:var(--color-blue);text-decoration:none;display:inline-flex;align-items:center;gap:6px;margin-top:8px;transition:gap 150ms;}
.bt-marque-decision__card:hover .bt-marque-decision__cta{gap:10px;}
@media(max-width:900px){.bt-marque-decision__grid{grid-template-columns:1fr;}}

/* Storytelling — fond navy, glow blue, identité forte */
.bt-marque-story{background:var(--color-navy-deepest);color:var(--color-text-on-dark);padding:var(--section-default) 0;position:relative;overflow:hidden;}
.bt-marque-story::before{content:'';position:absolute;top:-200px;left:-200px;width:600px;height:600px;background:radial-gradient(circle,rgb(var(--rgb-blue) / 0.20) 0%,transparent 70%);filter:blur(100px);pointer-events:none;}
.bt-marque-story::after{content:'';position:absolute;bottom:-300px;right:-200px;width:800px;height:800px;background:radial-gradient(circle,rgb(var(--rgb-blue-electric) / 0.12) 0%,transparent 70%);filter:blur(100px);pointer-events:none;}
.bt-marque-story__grid{display:grid;grid-template-columns:minmax(0,0.9fr) minmax(0,1.4fr);gap:clamp(40px,5vw,80px);align-items:start;position:relative;z-index:1;}
.bt-marque-story__h2{font-family:'Inter',sans-serif;font-size:clamp(28px,3.2vw,44px);font-weight:600;letter-spacing:-0.03em;line-height:1.1;color:var(--color-text-on-dark);margin:12px 0 0;text-wrap:balance;}
.bt-marque-story__h2 em{font-style:normal;color:var(--color-blue-electric);}
.bt-marque-story__copy p{font-size:15px;line-height:1.7;color:rgb(var(--rgb-on-dark) / 0.78);margin:0 0 16px;max-width:60ch;}
.bt-marque-story__copy strong{color:var(--color-text-on-dark);font-weight:600;}
@media(max-width:900px){.bt-marque-story__grid{grid-template-columns:1fr;}}

/* Testimonials — variante marques (via testimonials-grid + card-testimonial-chip) */
.bt-marque-testim{background:var(--color-cream);padding:var(--section-default) 0;}
.bt-marque-testim__head{max-width:880px;margin:0 auto clamp(40px,5vw,64px);}
.bt-marque-testim__h2{font-family:'Inter',sans-serif;font-size:clamp(24px,2.8vw,34px);font-weight:600;letter-spacing:-0.025em;line-height:1.15;color:var(--color-text-primary);margin:12px 0 0;max-width:24ch;text-wrap:balance;}
.bt-marque-testim__h2 em{font-style:normal;color:var(--color-blue);}
.bt-marque-testim__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.bt-marque-testim__card{background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:24px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-sm);}
.bt-marque-testim__chip{display:inline-flex;align-items:center;padding:3px 9px;border-radius:var(--radius-pill);font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;align-self:flex-start;}
.bt-marque-testim__card--esth .bt-marque-testim__chip{background:rgb(var(--rgb-blue) / 0.08);color:var(--color-blue);}
.bt-marque-testim__card--med .bt-marque-testim__chip{background:rgb(var(--rgb-cyan) / 0.10);color:#006984;}
.bt-marque-testim__quote{font-family:'Inter',sans-serif;font-size:14px;line-height:1.7;color:var(--color-text-body);margin:0;flex:1;}
.bt-marque-testim__person{display:flex;align-items:center;gap:12px;padding-top:12px;border-top:1px solid var(--color-border-light);}
.bt-marque-testim__avatar{width:40px;height:40px;border-radius:50%;background:var(--color-blue);color:var(--color-white);font-family:'Inter',sans-serif;font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;}
.bt-marque-testim__person span:last-child{font-size:12px;color:var(--color-text-muted);line-height:1.4;}
.bt-marque-testim__person b{color:var(--color-text-primary);font-weight:600;font-size:13px;}
@media(max-width:900px){.bt-marque-testim__grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.bt-marque-testim__grid{grid-template-columns:1fr;}}

/* Regulatory */
.bt-marque-reg{background:var(--color-off-white);padding:var(--section-default) 0;}
.bt-marque-reg__inner{max-width:760px;}
.bt-marque-reg__h2{font-family:'Inter',sans-serif;font-size:clamp(24px,2.8vw,34px);font-weight:600;letter-spacing:-0.025em;line-height:1.15;color:var(--color-text-primary);margin:12px 0 24px;max-width:24ch;text-wrap:balance;}
.bt-marque-reg__copy{font-size:15px;line-height:1.7;color:var(--color-text-body);max-width:65ch;margin:0 0 16px;}
.bt-marque-reg__links{font-size:14px;color:var(--color-text-muted);margin:24px 0 0;}
.bt-marque-reg__links a{color:var(--color-blue);text-decoration:none;border-bottom:1px solid rgb(var(--rgb-blue) / 0.25);}
.bt-marque-reg__links a:hover{border-bottom-color:var(--color-blue);}

/* ===========================================================================
 * Template : marques-index — grille de toutes les marques
 * =========================================================================== */
.bt-marques{background:var(--color-off-white);padding:var(--section-default) 0;}
.bt-marques__grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.bt-marques__grid li a{display:flex;flex-direction:column;gap:14px;padding:28px;background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);text-decoration:none;transition:border-color 280ms,transform 280ms var(--ease-out),box-shadow 280ms;height:100%;}
.bt-marques__grid li a:hover{border-color:rgb(var(--rgb-blue) / 0.25);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.bt-marques__flag{font-size:28px;line-height:1;}
.bt-marques__cat{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-blue);}
.bt-marques__name{font-family:'Inter',sans-serif;font-size:clamp(24px,2.6vw,30px);font-weight:700;letter-spacing:-0.03em;color:var(--color-text-primary);margin:0;line-height:1.1;}
.bt-marques__tag{font-size:14px;line-height:1.6;color:var(--color-text-body);margin:0;flex:1;}
.bt-marques__meta{display:grid;grid-template-columns:130px 1fr;gap:6px 14px;padding:14px 0;border-top:1px solid var(--color-border-light);margin:0;font-size:13px;}
.bt-marques__meta dt{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-text-muted);align-self:center;margin:0;}
.bt-marques__meta dd{color:var(--color-text-primary);font-weight:500;margin:0;align-self:center;font-variant-numeric:tabular-nums;}
.bt-marques__cta{font-size:14px;font-weight:600;color:var(--color-blue);margin-top:auto;transition:gap 150ms;display:inline-flex;align-items:center;gap:6px;}
.bt-marques__grid li a:hover .bt-marques__cta{gap:10px;}
@media(max-width:900px){.bt-marques__grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.bt-marques__grid{grid-template-columns:1fr;}}

/* ===========================================================================
 * Template : mise-en-relation-confrere — process 3 étapes
 * =========================================================================== */
.mre-process{background:var(--color-cream);padding:clamp(64px,8vw,112px) 0;}
.mre-process__head{max-width:720px;margin:0 auto clamp(40px,5vw,64px);text-align:center;}
.mre-process__head .eyebrow{justify-content:center;color:var(--color-blue);}
.mre-process__title{font-family:'Inter',sans-serif;font-size:clamp(28px,3vw,44px);font-weight:600;letter-spacing:-0.025em;line-height:1.12;color:var(--color-text-primary);margin:12px 0 0;text-wrap:balance;}
.mre-process__title em{font-style:normal;color:var(--color-blue);}
.mre-process__steps{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.mre-step{background:var(--color-white);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;transition:border-color 280ms,transform 280ms var(--ease-out),box-shadow 280ms;}
.mre-step:hover{border-color:rgb(var(--rgb-blue) / 0.25);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.mre-step__num{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--color-blue);font-variant-numeric:tabular-nums;}
.mre-step__title{font-family:'Inter',sans-serif;font-size:clamp(18px,1.8vw,22px);font-weight:600;letter-spacing:-0.02em;line-height:1.2;color:var(--color-text-primary);margin:0;}
.mre-step__desc{font-size:14px;line-height:1.65;color:var(--color-text-body);margin:0;}
.mre-process__footnote{max-width:65ch;margin:clamp(32px,4vw,48px) auto 0;text-align:center;font-size:13px;color:var(--color-text-muted);line-height:1.65;}
@media(max-width:900px){.mre-process__steps{grid-template-columns:1fr;}}

/* ===========================================================================
 * Overrides tone-light pour composants dark-default.
 * Composants conçus en V3 pour fond sombre (hub-tech-card, hub-mcard,
 * hub-eng-band) deviennent invisibles quand leur section parent passe en
 * tone-light : couleurs blanches sur fond off-white. Ces overrides
 * réinjectent un système navy/blue/text-* lisible.
 * =========================================================================== */
.hub-section--tone-light .hub-tech-card{background:var(--color-white);border-color:rgb(var(--rgb-navy) / 0.08);box-shadow:0 2px 12px rgb(var(--rgb-navy) / 0.04);}
.hub-section--tone-light .hub-tech-card::before{background:linear-gradient(90deg,transparent,rgb(var(--rgb-navy) / 0.10),transparent);}
.hub-section--tone-light .hub-tech-card:hover{border-color:rgb(var(--rgb-blue-electric) / 0.35);box-shadow:0 20px 40px rgb(var(--rgb-navy) / 0.10);}
.hub-section--tone-light .hub-tech-card__icon{background:rgb(var(--rgb-blue) / 0.08);border-color:rgb(var(--rgb-blue) / 0.15);color:var(--color-blue);}
.hub-section--tone-light .hub-tech-card__eyebrow{color:var(--color-blue);}
.hub-section--tone-light .hub-tech-card__title{color:var(--color-text-primary);}
.hub-section--tone-light .hub-tech-card__desc{color:var(--color-text-body);}
.hub-section--tone-light .hub-tech-card__specs{border-top-color:var(--color-border-light);}
.hub-section--tone-light .hub-tech-card__spec-label{color:var(--color-text-muted);}
.hub-section--tone-light .hub-tech-card__spec-val{color:var(--color-text-primary);}

.hub-section--tone-light .hub-mcard{background:var(--color-white);border-color:rgb(var(--rgb-navy) / 0.08);box-shadow:0 2px 12px rgb(var(--rgb-navy) / 0.04);}
.hub-section--tone-light .hub-mcard::before{background:linear-gradient(90deg,transparent,rgb(var(--rgb-navy) / 0.10),transparent);}
.hub-section--tone-light .hub-mcard:hover{border-color:rgb(var(--rgb-blue-electric) / 0.30);box-shadow:0 20px 40px rgb(var(--rgb-navy) / 0.10);}
.hub-section--tone-light .hub-mcard--hero{background:linear-gradient(135deg,rgb(var(--rgb-blue) / 0.06) 0%,rgb(var(--rgb-cyan) / 0.03) 100%),var(--color-white);border-color:rgb(var(--rgb-blue) / 0.25);}
.hub-section--tone-light .hub-mcard--hero::before{background:linear-gradient(90deg,transparent,rgb(var(--rgb-blue) / 0.30),transparent);}
.hub-section--tone-light .hub-mcard__num{color:rgb(var(--rgb-navy) / 0.05);}
.hub-section--tone-light .hub-mcard__badge{background:var(--color-blue);color:var(--color-white);}
.hub-section--tone-light .hub-mcard__eyebrow{color:var(--color-blue);}
.hub-section--tone-light .hub-mcard__h3,
.hub-section--tone-light .hub-mcard__h3--hero{color:var(--color-text-primary);}
.hub-section--tone-light .hub-mcard__sub{color:var(--color-text-body);}
.hub-section--tone-light .hub-mcard__quote{color:var(--color-text-muted);}
.hub-section--tone-light .hub-mcard__quote::before,
.hub-section--tone-light .hub-mcard__quote::after{color:var(--color-blue);}
.hub-section--tone-light .hub-mcard__spec-label{color:var(--color-text-muted);}
.hub-section--tone-light .hub-mcard__spec-val{color:var(--color-text-primary);}
.hub-section--tone-light .hub-mcard__indic-eyebrow{color:var(--color-text-muted);}
.hub-section--tone-light .hub-mcard__indic-list li{color:var(--color-text-body);}
.hub-section--tone-light .hub-mcard__indic-list li::before{background:var(--color-blue);}
.hub-section--tone-light .hub-mcard__cta-link{color:var(--color-blue);}
.hub-section--tone-light .hub-mcard__cta-link:hover{color:var(--color-blue-electric);}

.hub-section--tone-light .hub-eng-band{background:rgb(var(--rgb-blue) / 0.04);border-color:rgb(var(--rgb-blue) / 0.18);}
.hub-section--tone-light .hub-eng-band__num{color:var(--color-blue);}
.hub-section--tone-light .hub-eng-band__h3{color:var(--color-text-primary);}
.hub-section--tone-light .hub-eng-band__desc{color:var(--color-text-body);}
