/* === Tokens === */
:root {
    --color-primary: #0d0f14;
    --color-accent: #50b417;
    --color-accent-pressed: #3d9212;
    --color-bg: #0b0d10;
    --color-bg-elevated: #14171c;
    --color-gradient-light: #9ada01;
    --color-gradient-mid: #97d906;
    --color-text: #ffffff;
    --color-text-muted: #c0c0c0;
    --color-rg-banner: #dc2626;

    --font-display: "Archivo Black", "Hero New", system-ui, sans-serif;
    --font-body: "Outfit", "Hero New", system-ui, sans-serif;

    /* TYPO-03 desktop */
    --fs-h1: 80px;
    --fs-h2: 48px;
    --fs-h3: 30px;
    --fs-h4: 22px;
    --fs-h5: 16px;
    --fs-h6: 13px;
    --fs-body: 15px;
    --fs-small: 13px;
    --fs-micro: 11px;
    --lh-tight: 0.95;
    --lh-normal: 1.45;
    --lh-loose: 1.65;
    --ls-tight: -0.04em;
    --ls-normal: 0;
    --ls-wide: 0.08em;
    --fw-regular: 400;
    --fw-medium: 700;
    --fw-bold: 900;

    /* SPACE-03 */
    --space-2xs: 2px;
    --space-xs: 6px;
    --space-sm: 10px;
    --space-md: 14px;
    --space-lg: 20px;
    --space-xl: 28px;
    --space-2xl: 48px;
    --space-3xl: 72px;

    /* CONT */
    --container-site: 1380px;
    --container-readable: 720px;
    --container-padding-mobile: 16px;
    --container-padding-tablet: 24px;
    --container-padding-desktop: 40px;

    /* BP-05 reference (used in @media) */

    /* GEO-07 */
    --radius-xs: 4px;
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-pill: 9999px;
    --radius-circle: 50%;
    --border-thin: 1px;
    --border-medium: 2px;
    --border-thick: 3px;
    --shadow-lg: 0 8px 24px rgba(0,0,0,0.10);

    /* MOTION-05 */
    --dur-fast: 250ms;
    --dur-base: 400ms;
    --dur-slow: 700ms;
    --ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --ease-in-out: cubic-bezier(0.645, 0.045, 0.355, 1);

    --header-h: 80px;
}

@media (max-width: 720px) {
    :root {
        --fs-h1: 44px;
        --fs-h2: 32px;
        --fs-h3: 24px;
        --fs-h4: 18px;
        --fs-h5: 14px;
        --fs-h6: 12px;
        --fs-body: 14px;
        --fs-small: 12px;
        --fs-micro: 10px;
        --header-h: 64px;
    }
}

/* === Reset & base === */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: clip; }
body {
    background: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-body);
    font-size: var(--fs-body);
    line-height: var(--lh-normal);
    -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; height: auto; }
a { color: var(--color-accent); text-decoration: none; transition: color var(--dur-fast) var(--ease-out); }
a:hover { color: var(--color-accent-pressed); }
button { font-family: inherit; }
h1, h2, h3, h4, h5, h6 { margin: 0; }
p { margin: 0 0 var(--space-md); }
ul, ol { margin: 0; padding: 0; }

main { padding-top: var(--header-h); }

/* === Accessibility === */
.skip-link {
    background: var(--color-accent);
    color: var(--color-bg);
    font-weight: var(--fw-bold);
    left: var(--space-md);
    padding: var(--space-sm) var(--space-md);
    position: fixed;
    top: -200px;
    z-index: 1000;
    transition: top var(--dur-fast);
}
.skip-link:focus { top: var(--space-md); }
.sr-only {
    position: absolute !important; width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}

/* === Author byline (BYLINE-03) === */
.garde-corps-large {
    border-bottom: 1px solid rgba(255,255,255,0.05);
    border-top: 1px solid rgba(255,255,255,0.05);
    margin: var(--space-2xl) auto var(--space-xl);
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-sm);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.garde-corps-large-inner {
    align-items: center;
    display: flex;
    gap: var(--space-sm);
}
.garde-corps-large-portrait {
    border-radius: var(--radius-circle);
    height: 28px;
    object-fit: cover;
    width: 28px;
}
.garde-corps-large-meta {
    color: var(--color-text-muted);
    font-size: var(--fs-small);
}
.garde-corps-large-name {
    color: var(--color-accent);
    font-weight: var(--fw-medium);
}
.garde-corps-large-name:hover { text-decoration: underline; }

/* === Author card (AUTH-08) — minimal === */
.reliquaire-brut {
    align-items: center;
    background: var(--color-bg-elevated);
    border: 1px dashed rgba(255,255,255,0.12);
    border-radius: var(--radius-md);
    display: inline-flex;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
}
.reliquaire-brut-portrait {
    border-radius: var(--radius-circle);
    height: 56px;
    object-fit: cover;
    width: 56px;
}
.reliquaire-brut-text { display: flex; flex-direction: column; }
.reliquaire-brut-name {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h5);
    font-weight: var(--fw-bold);
}
.reliquaire-brut-role {
    color: var(--color-text-muted);
    font-size: var(--fs-micro);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
}

/* === Breadcrumbs (BREAD-04 numbered) === */
.gradin-lumineux {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-md);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.gradin-lumineux-list {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    list-style: none;
}
.gradin-lumineux-num {
    color: var(--color-accent);
    font-family: var(--font-display);
    font-size: var(--fs-h6);
    font-weight: var(--fw-bold);
    margin-right: var(--space-2xs);
}
.gradin-lumineux-text {
    color: var(--color-text-muted);
    font-size: var(--fs-small);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
}
.gradin-lumineux-text--current { color: var(--color-text); }
.gradin-lumineux-sep {
    color: rgba(192,192,192,0.7);
    margin-inline: var(--space-sm);
}

/* === Cookie banner (COOK-08 bordered top bar) === */
.pavois-robuste {
    background: var(--color-bg);
    border-bottom: 2px solid var(--color-accent);
    height: 56px;
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    transform: translateY(-110%);
    transition: transform var(--dur-base) var(--ease-out);
    z-index: 200;
}
.pavois-robuste.is-visible { transform: translateY(0); }
.pavois-robuste-inner {
    align-items: center;
    display: flex;
    gap: var(--space-md);
    height: 100%;
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-inline: var(--container-padding-desktop);
}
.pavois-robuste-icon {
    color: var(--color-accent);
    flex-shrink: 0;
}
.pavois-robuste-message {
    color: var(--color-text-muted);
    flex: 1;
    font-size: var(--fs-small);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pavois-robuste-actions {
    display: inline-flex;
    flex-shrink: 0;
    gap: var(--space-xs);
}
.pavois-robuste-btn {
    background: transparent;
    border: 1px solid var(--color-text-muted);
    border-radius: var(--radius-xs);
    color: var(--color-text);
    cursor: pointer;
    font-family: var(--font-display);
    font-size: var(--fs-micro);
    font-weight: var(--fw-bold);
    height: 32px;
    letter-spacing: var(--ls-wide);
    padding-inline: var(--space-md);
    text-transform: uppercase;
    transition: background var(--dur-fast), color var(--dur-fast);
}
.pavois-robuste-btn--accept {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: var(--color-bg);
}
.pavois-robuste-btn--accept:hover { background: var(--color-accent-pressed); border-color: var(--color-accent-pressed); color: var(--color-bg); }
.pavois-robuste-btn--decline:hover { background: var(--color-bg-elevated); color: var(--color-text); }
@media (max-width: 700px) {
    .pavois-robuste { height: auto; padding-block: var(--space-sm); }
    .pavois-robuste-inner { flex-wrap: wrap; padding-block: 0; }
    .pavois-robuste-message { white-space: normal; overflow: visible; text-overflow: clip; flex: 1 1 100%; order: 2; }
    .pavois-robuste-icon { order: 1; }
    .pavois-robuste-actions { flex: 1 1 100%; order: 3; }
    .pavois-robuste-btn { flex: 1; }
}

/* === CTA block (CTA-10 pull-quote) === */
.support-dense {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-xl);
    padding-inline: var(--container-padding-desktop);
    text-align: center;
    width: 100%;
}
.support-dense-statement {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    font-style: italic;
    letter-spacing: var(--ls-tight);
    line-height: var(--lh-tight);
    margin: 0 auto var(--space-lg);
    max-width: 900px;
    position: relative;
    text-transform: uppercase;
}
.support-dense-statement::before {
    color: var(--color-accent);
    content: "\201C";
    font-size: 1.4em;
    left: -0.4em;
    line-height: 1;
    opacity: 0.6;
    position: absolute;
    top: -0.2em;
}
.support-dense-statement p { margin: 0; }
.support-dense-sub {
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    line-height: var(--lh-loose);
    margin: 0 auto var(--space-lg);
    max-width: 580px;
}
.support-dense-link {
    color: var(--color-accent);
    display: inline-block;
    font-family: var(--font-display);
    font-size: var(--fs-h5);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wide);
    text-decoration: underline;
    text-transform: uppercase;
}
.support-dense-link:hover { color: var(--color-accent-pressed); }

/* === Data table (TABLE-07 two-tone columns) === */
.verriere-mince {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-2xl);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.verriere-mince-scroll { overflow-x: auto; }
.verriere-mince-table {
    border-collapse: collapse;
    width: 100%;
}
.verriere-mince-table thead {
    background: var(--color-primary);
}
.verriere-mince-table th {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-small);
    letter-spacing: var(--ls-wide);
    padding: var(--space-md);
    text-align: left;
    text-transform: uppercase;
}
.verriere-mince-table td {
    border-bottom: 1px solid rgba(255,255,255,0.06);
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    padding: var(--space-md);
}
.verriere-mince-table td:nth-child(even) { background: rgba(255,255,255,0.03); }
.verriere-mince-table tr:hover td { color: var(--color-text); }

/* === Error block (ERR-04 full-bleed) === */
.credence-austere {
    align-items: center;
    background: linear-gradient(180deg, rgba(11,13,16,0.45), rgba(0,0,0,0.85)), url('/source/vision.webp') center/cover no-repeat;
    color: #ffffff;
    display: flex;
    justify-content: center;
    min-height: 100vh;
    padding-block: var(--space-xl);
    padding-inline: var(--container-padding-desktop);
    text-align: center;
}
.credence-austere-content {
    backdrop-filter: blur(2px);
    max-width: 720px;
}
.credence-austere-title {
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    letter-spacing: var(--ls-tight);
    line-height: var(--lh-tight);
    margin-bottom: var(--space-lg);
    text-transform: uppercase;
}
.credence-austere-text {
    color: rgba(255,255,255,0.85);
    font-size: var(--fs-h5);
    line-height: var(--lh-loose);
    margin-bottom: var(--space-xl);
}
.credence-austere-btn {
    background: var(--color-accent);
    border: 1px solid var(--color-accent);
    border-radius: var(--radius-xs);
    color: var(--color-bg);
    display: inline-block;
    font-family: var(--font-display);
    font-size: var(--fs-small);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wide);
    padding: var(--space-md) var(--space-xl);
    text-transform: uppercase;
    transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.credence-austere-btn:hover { background: var(--color-accent-pressed); color: var(--color-bg); transform: scale(1.03); }

/* === FAQ (FAQ-01 classic accordion) === */
.ciboire-mince {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-2xl);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.ciboire-mince-heading {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h2);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-tight);
    line-height: var(--lh-tight);
    margin-bottom: var(--space-xl);
    text-transform: uppercase;
}
.ciboire-mince-list { list-style: none; padding: 0; }
.ciboire-mince-item {
    border-bottom: 1px solid rgba(255,255,255,0.1);
    padding-block: var(--space-md);
}
.ciboire-mince-question {
    align-items: center;
    background: transparent;
    border: 0;
    color: var(--color-text);
    cursor: pointer;
    display: flex;
    font-family: var(--font-body);
    font-size: var(--fs-h5);
    font-weight: var(--fw-bold);
    justify-content: space-between;
    padding: 0;
    text-align: left;
    transition: color var(--dur-fast) var(--ease-out);
    width: 100%;
}
.ciboire-mince-question:hover { color: var(--color-accent); }
.ciboire-mince-icon {
    color: var(--color-accent);
    font-size: 24px;
    line-height: 1;
    transition: transform var(--dur-base) var(--ease-out);
}
.ciboire-mince-question[aria-expanded="true"] .ciboire-mince-icon { transform: rotate(45deg); }
.ciboire-mince-answer {
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    line-height: var(--lh-loose);
    padding-top: var(--space-sm);
}
.ciboire-mince-answer[hidden] { display: none; }
.ciboire-mince-answer p { margin: 0; }

/* === Footer (FOOT-09 wide single-strip industrial) === */
.enceinte-bas {
    background: var(--color-primary);
    margin-top: var(--space-3xl);
    padding-block: var(--space-md);
    width: 100%;
}
.enceinte-bas-inner {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-lg);
    justify-content: space-between;
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-inline: var(--container-padding-desktop);
}
.enceinte-bas-logo { display: inline-flex; flex-shrink: 0; }
.enceinte-bas-logo-img { height: 36px; width: auto; }
.enceinte-bas-main-nav, .enceinte-bas-legal-nav { display: flex; flex-wrap: wrap; gap: var(--space-md); list-style: none; }
.enceinte-bas-legal-nav { gap: var(--space-sm); }
.enceinte-bas-main-nav a {
    color: var(--color-text-muted);
    font-family: var(--font-body);
    font-size: var(--fs-small);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
}
.enceinte-bas-legal-nav a {
    color: var(--color-text-muted);
    font-size: var(--fs-micro);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
}
.enceinte-bas-main-nav a:hover, .enceinte-bas-legal-nav a:hover { color: var(--color-text); }
.enceinte-bas-copy {
    color: var(--color-text-muted);
    font-size: var(--fs-micro);
}
@media (max-width: 1040px) {
    .enceinte-bas-inner { gap: var(--space-md); justify-content: flex-start; }
    .enceinte-bas-logo, .enceinte-bas-copy { flex: 1 1 100%; }
}

/* === Header (HEAD-04 sticky transparent) === */
.support-secret {
    background: var(--color-bg);
    border-bottom: 1px solid rgba(255,255,255,0.08);
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    transition: background var(--dur-base) var(--ease-out), padding var(--dur-base) var(--ease-out);
    z-index: 100;
}
body[data-current="/"] .support-secret {
    background: transparent;
    border-bottom-color: transparent;
}
body[data-current="/"] .support-secret.is-scrolled {
    background: rgba(11,13,16,0.92);
    backdrop-filter: blur(10px);
    border-bottom-color: rgba(255,255,255,0.08);
}
.support-secret.is-shrunk { padding-block: var(--space-xs); }
.support-secret.is-shrunk .support-secret-logo-img { height: 56px; }
.support-secret-inner {
    align-items: center;
    display: flex;
    gap: var(--space-lg);
    height: var(--header-h);
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-inline: var(--container-padding-desktop);
}
.support-secret-logo {
    align-items: center;
    display: inline-flex;
    flex-shrink: 0;
}
.support-secret-logo-img {
    flex-shrink: 0;
    height: 88px;
    transition: height var(--dur-base) var(--ease-out);
    width: auto;
}
.support-secret-nav { display: flex; flex: 1; justify-content: flex-end; }
.support-secret-nav-list {
    align-items: center;
    display: flex;
    flex-wrap: nowrap;
    gap: var(--space-sm);
    list-style: none;
}
.support-secret-link {
    color: var(--color-text-muted);
    font-family: var(--font-body);
    font-size: var(--fs-small);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wide);
    padding: var(--space-xs) var(--space-sm);
    text-transform: uppercase;
    transition: color var(--dur-fast) var(--ease-out);
}
.support-secret-link:hover, .support-secret-link[aria-current="page"] { color: var(--color-text); }
body[data-current="/"] .support-secret:not(.is-scrolled) .support-secret-link { color: rgba(255,255,255,0.85); }
body[data-current="/"] .support-secret:not(.is-scrolled) .support-secret-link:hover,
body[data-current="/"] .support-secret:not(.is-scrolled) .support-secret-link[aria-current="page"] { color: #ffffff; }

/* NAV-02 More dropdown */
.support-secret-nav-item--more { position: relative; }
.support-secret-more-toggle {
    align-items: center;
    background: transparent;
    border: 0;
    color: inherit;
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    gap: var(--space-2xs);
    padding: var(--space-xs) var(--space-sm);
}
.support-secret-more-chevron { transition: transform var(--dur-fast) var(--ease-out); }
.support-secret-more-toggle[aria-expanded="true"] .support-secret-more-chevron { transform: rotate(180deg); }
.support-secret-more-menu {
    background: var(--color-bg-elevated);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    list-style: none;
    margin: 0;
    min-width: 220px;
    padding: var(--space-xs) 0;
    position: absolute;
    right: 0;
    top: 100%;
    z-index: 110;
}
.support-secret-more-menu[hidden] { display: none; }
.support-secret-more-link {
    color: var(--color-text);
    display: block;
    font-family: var(--font-body);
    font-size: var(--fs-small);
    letter-spacing: var(--ls-wide);
    padding: var(--space-xs) var(--space-md);
    text-transform: uppercase;
    white-space: nowrap;
}
.support-secret-more-link:hover, .support-secret-more-link:focus {
    background: rgba(255,255,255,0.06);
    color: var(--color-accent);
}

/* Burger */
.support-secret-toggle {
    background: transparent;
    border: 0;
    color: var(--color-text);
    cursor: pointer;
    display: none;
    height: 44px;
    margin-left: auto !important;
    padding: 0;
    width: 44px;
}
.support-secret-toggle svg { display: block; margin: auto; }

/* Mobile drawer */
.support-secret-mobile {
    background: var(--color-bg);
    border-top: 1px solid rgba(255,255,255,0.08);
    display: none;
    left: 0;
    list-style: none;
    padding: var(--space-md) var(--container-padding-mobile);
    position: absolute;
    right: 0;
    top: 100%;
}
.support-secret-mobile.is-open { display: block; }
.support-secret-mobile li { border-bottom: 1px solid rgba(255,255,255,0.06); }
.support-secret-mobile li:last-child { border-bottom: 0; }
.support-secret-mobile a {
    color: var(--color-text);
    display: block;
    font-family: var(--font-body);
    font-size: var(--fs-h6);
    letter-spacing: var(--ls-wide);
    padding: var(--space-md) 0;
    text-transform: uppercase;
}
.support-secret-mobile a[aria-current="page"] { color: var(--color-accent); }

@media (max-width: 1040px) {
    .support-secret-nav { display: none; }
    .support-secret-toggle { display: flex; align-items: center; justify-content: center; }
}
@media (max-width: 720px) {
    .support-secret-logo-img { height: 60px; }
    .support-secret.is-shrunk .support-secret-logo-img { height: 48px; }
    .support-secret-inner { padding-inline: var(--container-padding-mobile); }
}

/* === Hero (HERO-05 bordered editorial) === */
.peristyle-bas {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-xl);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.peristyle-bas-frame {
    background: rgba(11,13,16,0.7);
    background-image: linear-gradient(180deg, rgba(11,13,16,0.55), rgba(11,13,16,0.92)), url('/source/vision.webp');
    background-size: cover;
    background-position: center;
    box-shadow: 0 0 0 1px var(--color-text), 0 0 0 8px transparent, 0 0 0 12px var(--color-text);
    margin: 8px;
    padding: var(--space-2xl);
    text-align: center;
}
.peristyle-bas-content { margin-inline: auto; max-width: 880px; }
.peristyle-bas-eyebrow {
    color: var(--color-accent);
    font-family: var(--font-body);
    font-size: var(--fs-small);
    font-style: italic;
    letter-spacing: var(--ls-wide);
    margin-bottom: var(--space-md);
    text-transform: uppercase;
}
.peristyle-bas-title {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-tight);
    line-height: var(--lh-tight);
    margin-bottom: var(--space-lg);
    text-transform: uppercase;
}
.peristyle-bas-divider {
    background: var(--color-accent);
    border: 0;
    height: 1px;
    margin: var(--space-lg) auto;
    width: 80px;
}
.peristyle-bas-subtitle {
    color: rgba(255,255,255,0.85);
    font-family: var(--font-body);
    font-size: var(--fs-h5);
    line-height: var(--lh-normal);
    margin: 0 auto var(--space-xl);
    max-width: 640px;
}
.peristyle-bas-cta {
    background: var(--color-accent);
    border: 1px solid var(--color-accent);
    border-radius: var(--radius-xs);
    color: var(--color-bg);
    display: inline-block;
    font-family: var(--font-display);
    font-size: var(--fs-small);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wide);
    padding: var(--space-md) var(--space-xl);
    text-transform: uppercase;
    transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.peristyle-bas-cta:hover { background: var(--color-accent-pressed); color: var(--color-bg); transform: scale(1.03); }

/* === Items grid (GRID-04 icon-decorated cards) === */
.chasse-vif {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-2xl);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.chasse-vif-heading {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h2);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-tight);
    line-height: var(--lh-tight);
    margin-bottom: var(--space-xl);
    text-transform: uppercase;
}
.chasse-vif-list {
    display: grid;
    gap: var(--space-md);
    grid-template-columns: repeat(3, minmax(0,1fr));
    list-style: none;
}
.chasse-vif-card {
    background: var(--color-bg-elevated);
    border: 1px dashed rgba(255,255,255,0.15);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
}
.chasse-vif-num {
    align-items: center;
    background: var(--color-accent);
    border-radius: var(--radius-circle);
    color: var(--color-bg);
    display: inline-flex;
    font-family: var(--font-display);
    font-size: var(--fs-h4);
    font-weight: var(--fw-bold);
    height: 56px;
    justify-content: center;
    margin-bottom: var(--space-md);
    width: 56px;
}
.chasse-vif-title {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h4);
    font-weight: var(--fw-bold);
    margin-bottom: var(--space-sm);
}
.chasse-vif-text {
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    line-height: var(--lh-normal);
    margin: 0;
}
@media (max-width: 1040px) { .chasse-vif-list { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 720px) { .chasse-vif-list { grid-template-columns: 1fr; } }

/* === Legal section (LEGAL-07 magazine editorial) === */
.receptacle-mince {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-2xl);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.receptacle-mince-eyebrow {
    color: var(--color-accent);
    font-family: var(--font-body);
    font-size: var(--fs-micro);
    letter-spacing: var(--ls-wide);
    margin-bottom: var(--space-md);
    text-transform: uppercase;
}
.receptacle-mince-title {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-tight);
    line-height: var(--lh-tight);
    margin-bottom: var(--space-lg);
    text-transform: uppercase;
}
.receptacle-mince-intro {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h4);
    font-style: italic;
    line-height: var(--lh-normal);
    margin-bottom: var(--space-2xl);
}
.receptacle-mince-updated {
    color: var(--color-text-muted);
    font-size: var(--fs-micro);
    letter-spacing: var(--ls-wide);
    margin-bottom: var(--space-xl);
    text-transform: uppercase;
}
.receptacle-mince-section { margin-block: var(--space-2xl); }
.receptacle-mince-section h3 {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h3);
    font-style: italic;
    margin-bottom: var(--space-md);
}
.receptacle-mince-divider {
    background: var(--color-accent);
    border: 0;
    height: 1px;
    margin-bottom: var(--space-md);
    margin-left: 0;
    width: 80px;
}
.receptacle-mince-section p {
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    line-height: var(--lh-loose);
    margin-bottom: var(--space-md);
}
.receptacle-mince-section p:first-of-type::first-letter {
    color: var(--color-accent);
    float: left;
    font-family: var(--font-display);
    font-size: 3em;
    line-height: 1;
    padding-right: var(--space-sm);
    padding-top: 0.05em;
}
.receptacle-mince-contacts h2 {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h3);
    letter-spacing: var(--ls-tight);
    margin-bottom: var(--space-md);
    text-transform: uppercase;
}
.receptacle-mince-contacts ul {
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    line-height: var(--lh-loose);
    list-style: disc;
    padding-left: var(--space-lg);
}
.receptacle-mince-disclaimer {
    border-left: 2px solid var(--color-accent);
    color: var(--color-text-muted);
    font-size: var(--fs-small);
    font-style: italic;
    line-height: var(--lh-loose);
    margin-top: var(--space-2xl);
    padding-left: var(--space-md);
}

/* === Page header (PHEAD-06 subtle editorial) === */
.prie-dieu-austere {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-2xl);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.prie-dieu-austere-title {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-tight);
    line-height: var(--lh-tight);
    margin-bottom: var(--space-lg);
    text-transform: uppercase;
}
.prie-dieu-austere-rule {
    background: rgba(255,255,255,0.2);
    border: 0;
    height: 1px;
    margin: var(--space-md) 0;
    width: 40px;
}
.prie-dieu-austere-desc {
    color: var(--color-text-muted);
    font-family: var(--font-body);
    font-size: var(--fs-h5);
    font-style: italic;
    line-height: var(--lh-normal);
    max-width: 640px;
}

/* === Prose (PROSE-05 wide tech doc) === */
.cellule-grand {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-xl);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.cellule-grand h2 {
    color: var(--color-text);
    font-family: var(--font-body);
    font-size: var(--fs-h3);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wide);
    margin-top: var(--space-2xl);
    margin-bottom: var(--space-md);
    padding-top: var(--space-sm);
    position: relative;
    text-transform: uppercase;
}
.cellule-grand h2::before {
    background: var(--color-accent);
    content: "";
    display: block;
    height: 2px;
    margin-bottom: var(--space-sm);
    width: 40px;
}
.cellule-grand p {
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    line-height: var(--lh-normal);
    margin-bottom: var(--space-md);
}
.cellule-grand a { color: var(--color-accent); text-decoration: underline; }
.cellule-grand a:hover { color: var(--color-accent-pressed); }
.cellule-grand ol, .cellule-grand ul {
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    line-height: var(--lh-loose);
    margin-bottom: var(--space-md);
    padding-left: var(--space-xl);
}
.cellule-grand strong { color: var(--color-text); }
.cellule-grand-image {
    border-radius: var(--radius-md);
    margin-block: var(--space-xl);
    width: 100%;
}
.cellule-grand-figure { margin: var(--space-xl) 0; }
.cellule-grand-figure img { border-radius: var(--radius-md); }
.cellule-grand-figure figcaption {
    color: var(--color-text-muted);
    font-size: var(--fs-micro);
    letter-spacing: var(--ls-wide);
    margin-top: var(--space-xs);
    text-align: center;
    text-transform: uppercase;
}

/* === Reviews (REV-01 three-column cards) === */
.support-voile {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-2xl);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.support-voile-heading {
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: var(--fs-h2);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-tight);
    line-height: var(--lh-tight);
    margin-bottom: var(--space-xl);
    text-transform: uppercase;
}
.support-voile-list {
    display: grid;
    gap: var(--space-lg);
    grid-template-columns: repeat(3, minmax(0,1fr));
    list-style: none;
}
.support-voile-item {
    background: var(--color-bg-elevated);
    border: 1px solid rgba(192,192,192,0.1);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
}
.support-voile-item-header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--space-sm);
}
.support-voile-author {
    color: var(--color-text);
    font-size: var(--fs-body);
    font-weight: var(--fw-bold);
}
.support-voile-date {
    color: var(--color-text-muted);
    font-size: var(--fs-micro);
}
.support-voile-rating {
    color: var(--color-accent);
    display: inline-flex;
    font-size: 18px;
    gap: 2px;
    margin-bottom: var(--space-sm);
}
.support-voile-rating .star-empty { color: rgba(192,192,192,0.3); }
.support-voile-text {
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    line-height: var(--lh-loose);
    margin: 0;
}
@media (max-width: 1040px) { .support-voile-list { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 720px) { .support-voile-list { grid-template-columns: 1fr; } }

/* === Contact form (FORM-03 minimal) === */
.hypostyle-lumineux {
    margin-inline: auto;
    max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
    padding-block: var(--space-xl);
    padding-inline: var(--container-padding-desktop);
    width: 100%;
}
.hypostyle-lumineux-intro {
    color: var(--color-text-muted);
    font-size: var(--fs-body);
    line-height: var(--lh-normal);
    margin-inline: auto;
    margin-bottom: var(--space-xl);
    max-width: 540px;
    text-align: center;
}
.hypostyle-lumineux-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin-inline: auto;
    max-width: 540px;
}
.hypostyle-lumineux-field { display: flex; flex-direction: column; gap: var(--space-2xs); }
.hypostyle-lumineux-label {
    color: var(--color-text);
    font-family: var(--font-body);
    font-size: var(--fs-small);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
}
.hypostyle-lumineux-input, .hypostyle-lumineux-textarea {
    background: transparent;
    border: 0;
    border-bottom: 2px dashed rgba(255,255,255,0.2);
    color: var(--color-text);
    font-family: var(--font-body);
    font-size: var(--fs-body);
    padding: var(--space-sm) 0;
    width: 100%;
}
.hypostyle-lumineux-input:focus, .hypostyle-lumineux-textarea:focus {
    border-bottom-color: var(--color-accent);
    outline: 0;
}
.hypostyle-lumineux-textarea { min-height: 120px; resize: vertical; }
.hypostyle-lumineux-submit {
    background: var(--color-accent);
    border: 1px solid var(--color-accent);
    border-radius: var(--radius-xs);
    color: var(--color-bg);
    cursor: pointer;
    font-family: var(--font-display);
    font-size: var(--fs-small);
    font-weight: var(--fw-bold);
    height: 52px;
    letter-spacing: var(--ls-wide);
    margin-top: var(--space-md);
    text-transform: uppercase;
    transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out);
    width: 100%;
}
.hypostyle-lumineux-submit:hover { background: var(--color-accent-pressed); color: var(--color-bg); }
.hypostyle-lumineux-success {
    background: var(--color-bg-elevated);
    border-left: 3px solid var(--color-accent);
    color: var(--color-text);
    font-size: var(--fs-body);
    line-height: var(--lh-loose);
    margin-inline: auto;
    max-width: 540px;
    padding: var(--space-md) var(--space-lg);
}
.hypostyle-lumineux-success[hidden] { display: none; }

/* === Responsible gaming banner === */
.rg-banner {
    align-items: center;
    background: var(--color-rg-banner);
    color: #ffffff;
    display: flex;
    font-size: var(--fs-micro);
    font-weight: var(--fw-medium);
    justify-content: center;
    letter-spacing: var(--ls-wide);
    min-height: 28px;
    padding: 4px var(--space-md);
    text-align: center;
    text-transform: uppercase;
}
.support-secret-nav-item { display: inline-flex; }
.ciboire-mince-question-text { flex: 1; }
.garde-corps-large-role { color: var(--color-text-muted); }
