/* ==========================================================================
   Rénov'Appart 53 — Feuille de style principale
   À déposer dans /assets/css/style.css
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Tokens (variables CSS)
   -------------------------------------------------------------------------- */
:root {
    /* Couleurs — palette du logo Rénov'Appart 53 (accents) */
    --color-primary:        #1FA8C7;   /* teal du "A" — accent rare */
    --color-primary-dark:   #17839E;
    --color-primary-darker: #0F5C70;
    --color-primary-light:  #E6F5F9;

    --color-accent:         #F26430;   /* orange — accent rare */
    --color-accent-dark:    #D44D1E;
    --color-accent-light:   #FDE7DC;

    --color-leaf:           #7FB539;
    --color-leaf-dark:      #639128;

    /* Palette pastel premium — alignée sur les photos du studio */
    --cream:                #FAF7F2;   /* crème pastel — fond principal */
    --cream-deep:           #EFE8DB;   /* crème un cran plus chaud (sections alt) */
    --sand:                 #D9CFB8;   /* séparateurs, fonds chauds */
    --stone:                #8A8579;   /* gris chaud — texte muted */
    --canard:               #17373E;   /* canard profond (issu des photos) — signature dark */
    --canard-soft:          #2D5762;   /* canard adouci */
    --terracotta:           #B98969;   /* clay warm — accent rare */
    --sage:                 #9DAA92;   /* vert sauge des cuisines — accent rare */

    --ink:                  #1A2A30;   /* charcoal teinté canard — texte principal */
    --ink-soft:             #4A5A60;   /* texte secondaire */

    --color-text:           var(--ink);
    --color-text-muted:     var(--ink-soft);
    --color-bg:             var(--cream);
    --color-bg-alt:         var(--cream-deep);
    --color-surface:        #FFFFFF;
    --color-border:         #E8E0D0;
    --color-border-light:   rgba(26, 42, 48, .06);

    /* Promotion : --color-primary-darker devient canard pour s'aligner sur les photos */
    --color-primary-darker: var(--canard);

    /* Typo — Inter (sans, neutre) + Fraunces (serif moderne, optical sizing) */
    --font-sans:  'Inter', system-ui, -apple-system, sans-serif;
    --font-serif: 'Fraunces', Georgia, serif;

    /* Échelle typographique (inspirée du design de référence) */
    --fs-display:    clamp(2.25rem, 5vw, 3rem);   /* 48px */
    --fs-headline-l: clamp(1.75rem, 3.5vw, 2rem); /* 32px */
    --fs-headline-m: 1.5rem;                       /* 24px */
    --fs-body-l:     1.125rem;                     /* 18px */
    --fs-body:       1rem;                         /* 16px */
    --fs-label:      .875rem;                      /* 14px */
    --fs-caption:    .75rem;                       /* 12px */

    /* Espacements */
    --container-max: 1280px;
    --pad-desktop:   2rem;
    --pad-mobile:    1rem;
    --gutter:        1.5rem;
    --u-xs:          .25rem;
    --u-sm:          .5rem;
    --u-md:          1rem;
    --u-lg:          2rem;
    --u-xl:          4rem;

    /* Header */
    --header-h:      80px;

    /* Radius */
    --radius-sm:  4px;
    --radius:     8px;
    --radius-lg:  12px;
    --radius-xl:  16px;
    --radius-2xl: 24px;

    /* Ombres */
    --shadow-sm: 0 1px 2px rgba(15, 42, 53, .06);
    --shadow:    0 4px 12px rgba(15, 42, 53, .08);
    --shadow-lg: 0 10px 32px rgba(15, 42, 53, .12);
    --shadow-xl: 0 20px 50px rgba(15, 42, 53, .18);

    /* Transitions */
    --t-fast: 150ms ease;
    --t-med:  250ms ease;
    --t-slow: 400ms ease;
}

/* --------------------------------------------------------------------------
   2. Reset / base
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html {
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    line-height: 1.5;
    color: var(--color-text);
    background: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    padding-top: var(--header-h);
}

h1, h2, h3, h4 {
    font-family: var(--font-serif);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -.015em;
    margin: 0 0 .5em;
    color: var(--ink);
    /* Fraunces variable : ajuste la taille optique automatiquement */
    font-optical-sizing: auto;
}

h1 { font-size: var(--fs-display); font-weight: 600; line-height: 1.05; letter-spacing: -.025em; }
h2 { font-size: var(--fs-headline-l); }
h3 { font-size: var(--fs-headline-m); font-weight: 500; }
h4 { font-family: var(--font-sans); font-size: var(--fs-label); font-weight: 600; letter-spacing: 0; }

p {
    margin: 0 0 1em;
    font-size: var(--fs-body);
    line-height: 1.6;
}

a {
    color: var(--color-primary);
    text-decoration: none;
    transition: color var(--t-fast);
}
a:hover { color: var(--color-accent); }

img { max-width: 100%; height: auto; display: block; }

ul, ol { margin: 0 0 1em; padding-left: 1.25rem; }

.container {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--pad-desktop);
}
@media (max-width: 768px) {
    .container { padding-inline: var(--pad-mobile); }
}

/* Material Symbols par défaut */
.material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    vertical-align: middle;
}

/* --------------------------------------------------------------------------
   3. Header
   -------------------------------------------------------------------------- */
.site-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    height: var(--header-h);
    background: rgba(250, 247, 242, .85);     /* crème pastel translucide */
    backdrop-filter: saturate(180%) blur(20px);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    border-bottom: 1px solid rgba(31, 45, 51, .04);
    z-index: 1000;
}

.site-header__inner {
    max-width: var(--container-max);
    height: 100%;
    margin-inline: auto;
    padding-inline: var(--pad-desktop);
    display: grid;
    grid-template-columns: auto 1fr auto;     /* logo · nav centrée · CTA */
    align-items: center;
    gap: 2rem;
}

/* Logo */
.site-header__logo {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    height: 100%;
    transition: opacity var(--t-fast);
    justify-self: start;
}
.site-header__logo img {
    height: 42px;
    width: auto;
    display: block;
}
.site-header__logo:hover { opacity: .8; }

@media (max-width: 480px) {
    .site-header__logo img { height: 34px; }
}

/* Navigation — éditoriale, centrée, indicateur en dot */
.site-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .25rem;
    justify-self: center;
}

.site-nav__link {
    position: relative;
    padding: .65rem .95rem;
    font-size: .75rem;                        /* 12px — tracking aéré */
    font-weight: 500;
    letter-spacing: .18em;                    /* large tracking = magazine */
    text-transform: uppercase;
    color: var(--stone);
    background: transparent;
    transition: color var(--t-med);
    display: inline-flex;
    align-items: center;
    line-height: 1;
}
.site-nav__link span {
    transition: transform var(--t-med);
    display: inline-block;
}

.site-nav__link:hover {
    color: var(--ink);
}

/* Indicateur dot — apparaît au hover et reste sur l'active */
.site-nav__link::before {
    content: '';
    position: absolute;
    left: 50%;
    bottom: .35rem;
    width: 4px; height: 4px;
    border-radius: 50%;
    background: var(--color-primary);
    transform: translateX(-50%) scale(0);
    transition: transform var(--t-med);
}
.site-nav__link:hover::before {
    transform: translateX(-50%) scale(1);
}
.site-nav__link.is-active {
    color: var(--ink);
}
.site-nav__link.is-active::before {
    transform: translateX(-50%) scale(1);
    background: var(--color-accent);
}

/* CTA dans le 3e slot — pilule pleine ink */
.site-header__cta {
    justify-self: end;
}
.header-cta {
    display: inline-flex;
    align-items: center;
    padding: .7rem 1.35rem;
    background: var(--ink);
    color: var(--cream);
    border-radius: 999px;
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    line-height: 1;
    transition: background var(--t-med), color var(--t-med);
}
.header-cta:hover {
    background: var(--color-primary-darker);
    color: var(--cream);
}

/* Dropdown (Prestations) */
.site-nav__item {
    display: inline-flex;
    align-items: center;
}
.site-nav__item--has-dropdown {
    position: relative;
}
.site-nav__chevron {
    margin-left: .4em;
    transition: transform var(--t-fast);
    flex-shrink: 0;
}

.dropdown-trigger { display: none; }

.site-nav__dropdown {
    position: absolute;
    top: calc(100% + .5rem);
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    min-width: 300px;
    padding: .85rem;
    background: var(--cream);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    box-shadow: 0 30px 60px -20px rgba(31, 45, 51, .15);
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--t-med), transform var(--t-med), visibility var(--t-med);
    z-index: 1001;
}
.site-nav__dropdown-link {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .7rem .85rem;
    font-size: .8125rem;
    font-weight: 500;
    letter-spacing: .02em;
    text-transform: none;
    color: var(--ink-soft);
    border-radius: var(--radius);
    transition: color var(--t-fast), background var(--t-fast);
}
.site-nav__dropdown-link::before {
    content: '';
    width: 4px; height: 4px;
    border-radius: 50%;
    background: transparent;
    transition: background var(--t-fast);
    flex-shrink: 0;
}
.site-nav__dropdown-link:hover {
    color: var(--ink);
    background: var(--cream-deep);
}
.site-nav__dropdown-link:hover::before {
    background: var(--color-primary);
}
.site-nav__dropdown-link.is-active {
    color: var(--ink);
    background: var(--cream-deep);
    font-weight: 600;
}
.site-nav__dropdown-link.is-active::before {
    background: var(--color-accent);
}

@media (min-width: 1025px) {
    .site-nav__item--has-dropdown:hover > .site-nav__dropdown,
    .site-nav__item--has-dropdown:focus-within > .site-nav__dropdown {
        opacity: 1;
        visibility: visible;
        transform: translateX(-50%) translateY(0);
    }
    .site-nav__item--has-dropdown:hover .site-nav__chevron,
    .site-nav__item--has-dropdown:focus-within .site-nav__chevron {
        transform: rotate(180deg);
    }
}

/* CTA mobile dans le nav drawer */
.site-nav__cta { display: none; }

/* Backdrop derrière le menu mobile */
.nav-backdrop { display: none; }

/* Burger */
.nav-toggle { display: none; }
.nav-burger {
    display: none;
    width: 44px; height: 44px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    cursor: pointer;
    background: transparent;
    border: 0;
    border-radius: 50%;
    transition: background var(--t-fast);
    z-index: 1002;
}
.nav-burger span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--ink);
    border-radius: 2px;
    transform-origin: center;
    transition: transform 280ms cubic-bezier(.22, 1, .36, 1),
                opacity 180ms ease,
                width 200ms ease;
}

/* Backdrop & CTA mobile — masqués par défaut sur desktop */
.nav-backdrop { display: none; }
.site-nav__cta { display: none; }

@media (max-width: 1024px) {
    .site-header__inner {
        grid-template-columns: auto 1fr;
    }
    .site-header__cta { display: none; }       /* CTA déplacé dans le drawer mobile */

    .nav-burger { display: flex; justify-self: end; }
    .nav-burger:hover { background: rgba(26, 42, 48, .05); }
    .nav-toggle:checked ~ .nav-burger { background: rgba(26, 42, 48, .06); }
    .nav-toggle:checked ~ .nav-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .nav-toggle:checked ~ .nav-burger span:nth-child(2) { opacity: 0; width: 0; }
    .nav-toggle:checked ~ .nav-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    /* Verrouille le scroll de page quand le menu est ouvert */
    body:has(#nav-toggle:checked) { overflow: hidden; }

    /* Backdrop : floute tout le site quand le menu est ouvert */
    .nav-backdrop {
        display: block;
        position: fixed;
        inset: var(--header-h) 0 0 0;
        background: rgba(23, 55, 62, .22);
        -webkit-backdrop-filter: blur(14px) saturate(120%);
        backdrop-filter: blur(14px) saturate(120%);
        opacity: 0;
        visibility: hidden;
        transition: opacity 280ms ease, visibility 280ms ease;
        z-index: 1;
        cursor: pointer;
    }
    .nav-toggle:checked ~ .nav-backdrop { opacity: 1; visibility: visible; }

    /* Sidenav gauche (off-canvas) */
    .site-nav {
        position: fixed;
        top: var(--header-h);
        left: 0;
        bottom: 0;
        width: min(86vw, 360px);
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        gap: 0;
        padding: .75rem var(--pad-mobile) calc(1.5rem + env(safe-area-inset-bottom));
        background: var(--cream);
        border-top-right-radius: 0;
        border-bottom-right-radius: var(--radius-xl);
        box-shadow: 18px 0 60px -20px rgba(15, 42, 53, .28);
        transform: translateX(-105%);
        opacity: 1;
        visibility: visible;
        transition: transform 380ms cubic-bezier(.22, 1, .36, 1);
        height: calc(100dvh - var(--header-h));
        overflow-y: auto;
        overscroll-behavior: contain;
        z-index: 2;
    }
    .nav-toggle:checked ~ .site-nav {
        transform: translateX(0);
    }

    /* Liens — tap targets confortables, pas de jank sur touch */
    .site-nav__link {
        padding: 1.05rem .25rem 1.05rem 1.25rem;
        font-size: .8rem;
        letter-spacing: .14em;
        border-bottom: 1px solid var(--color-border-light);
        border-radius: 0;
        color: var(--ink-soft);
        min-height: 52px;
    }
    .site-nav__link:hover { color: var(--ink); transition: color var(--t-fast); }
    .site-nav__link::before {
        left: .25rem;
        bottom: 50%;
        width: 5px; height: 5px;
        transform: translateY(50%) scale(0);
    }
    .site-nav__link:hover::before,
    .site-nav__link.is-active::before {
        transform: translateY(50%) scale(1);
    }
    .site-nav__link.is-active {
        color: var(--ink);
        font-weight: 600;
    }

    /* Items / dropdown */
    .site-nav__item { display: block; width: 100%; position: relative; }
    .site-nav__item--has-dropdown > .site-nav__link { padding-right: 3.5rem; }
    .site-nav__item--has-dropdown > .site-nav__link .site-nav__chevron { display: none; }

    .dropdown-trigger {
        display: flex;
        position: absolute;
        top: 50%; right: .25rem;
        transform: translateY(-50%);
        width: 44px; height: 44px;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        border-radius: 50%;
        transition: background var(--t-fast);
    }
    .dropdown-trigger:hover,
    .dropdown-toggle:checked ~ .dropdown-trigger { background: var(--cream-deep); }
    .dropdown-trigger::before {
        content: '';
        width: 8px; height: 8px;
        border-right: 2px solid var(--ink);
        border-bottom: 2px solid var(--ink);
        transform: rotate(45deg) translate(-2px, -2px);
        transition: transform var(--t-med);
    }
    .dropdown-toggle:checked ~ .dropdown-trigger::before {
        transform: rotate(-135deg) translate(-2px, -2px);
    }

    .site-nav__dropdown {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        min-width: 0;
        margin: 0;
        padding: 0 0 0 1.5rem;
        border: 0;
        background: transparent;
        box-shadow: none;
        max-height: 0;
        overflow: hidden;
        transition: max-height 340ms cubic-bezier(.22, 1, .36, 1);
    }
    .dropdown-toggle:checked ~ .site-nav__dropdown {
        max-height: 600px;
        padding-block: .25rem .5rem;
    }
    .site-nav__dropdown-link {
        padding: .8rem .85rem;
        font-size: .9rem;
        min-height: 44px;
    }

    /* CTA inline en bas du drawer */
    .site-nav__cta {
        display: flex;
        flex-direction: column;
        gap: .5rem;
        margin-top: 1.5rem;
        padding-top: 1.25rem;
        border-top: 1px solid var(--color-border);
    }
    .site-nav__cta-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 1rem 1.5rem;
        background: var(--ink);
        color: var(--cream);
        border-radius: 999px;
        font-size: .72rem;
        font-weight: 600;
        letter-spacing: .18em;
        text-transform: uppercase;
        line-height: 1;
        min-height: 52px;
        transition: background var(--t-med), color var(--t-med);
    }
    .site-nav__cta-btn:hover,
    .site-nav__cta-btn.is-active {
        background: var(--color-primary-darker);
        color: var(--cream);
    }
}

/* --------------------------------------------------------------------------
   4. Buttons
   -------------------------------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .85rem 1.5rem;
    font-family: var(--font-sans);
    font-size: var(--fs-label);
    font-weight: 600;
    letter-spacing: .03em;
    border: 0;
    border-radius: var(--radius);
    cursor: pointer;
    text-decoration: none;
    transition: transform var(--t-fast), background var(--t-fast), box-shadow var(--t-fast), color var(--t-fast);
}
.btn--primary {
    background: var(--ink);
    color: var(--cream);
    box-shadow: var(--shadow);
}
.btn--primary:hover {
    background: var(--canard);
    color: var(--cream);
    box-shadow: var(--shadow-lg);
    transform: translateY(-1px);
}
.btn--secondary {
    background: transparent;
    color: var(--ink);
    border: 1px solid var(--ink);
}
.btn--secondary:hover {
    background: var(--ink);
    color: var(--cream);
}
/* .btn--ghost : pensé pour fonds sombres (hero image, cta-final--image).
   Variables locales pour pouvoir le rendre lisible sur fond clair via override. */
.btn--ghost {
    --ghost-fg: #fff;
    --ghost-border: rgba(255, 255, 255, .4);
    --ghost-bg-hover: rgba(255, 255, 255, .1);
    --ghost-border-hover: rgba(255, 255, 255, .7);

    background: transparent;
    color: var(--ghost-fg);
    border: 1px solid var(--ghost-border);
}
.btn--ghost:hover {
    background: var(--ghost-bg-hover);
    color: var(--ghost-fg);
    border-color: var(--ghost-border-hover);
}

/* Filet de sécurité : sur fond clair (section, page-hero, cta-final non-image…),
   le ghost devient ink-on-cream. Évite tout bouton invisible. */
.section .btn--ghost,
.page-hero .btn--ghost,
.prestation-content .btn--ghost,
.prestation-cta .btn--ghost,
.contact-form .btn--ghost {
    --ghost-fg: var(--ink);
    --ghost-border: var(--ink);
    --ghost-bg-hover: var(--ink);
    --ghost-border-hover: var(--ink);
}
.section .btn--ghost:hover,
.page-hero .btn--ghost:hover,
.prestation-content .btn--ghost:hover,
.prestation-cta .btn--ghost:hover,
.contact-form .btn--ghost:hover {
    color: var(--cream);
}
.btn--lg {
    padding: 1.1rem 2rem;
    font-size: 1rem;
}

/* --------------------------------------------------------------------------
   5. Patterns de sections
   -------------------------------------------------------------------------- */
.section {
    padding: var(--u-xl) 0;
}
.section--alt {
    background: var(--color-bg-alt);
}
.section--primary {
    background: var(--color-primary-darker);
    color: rgba(255, 255, 255, .9);
}
.section--primary h2,
.section--primary h3 { color: #fff; }

.section-label {
    display: inline-block;
    font-size: var(--fs-label);
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: .5rem;
}

.section-header {
    text-align: center;
    margin-bottom: var(--u-xl);
}
.section-header h2 {
    margin-bottom: .5rem;
}
.section-divider {
    width: 40px;
    height: 1px;
    background: var(--ink);
    border: 0;
    margin: 1.25rem auto 0;
}

/* --- Liste détaillée des prestations (home) --- */
.prestations-detail {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 3rem 2.5rem;
    margin-top: 2rem;
}
.prestations-detail__col h3 {
    font-family: var(--font-sans);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--canard);
    margin: 0 0 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--color-border);
}
.prestations-detail__col ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.prestations-detail__col li {
    padding: .55rem 0 .55rem 1.25rem;
    font-size: .9rem;
    line-height: 1.5;
    color: var(--ink);
    position: relative;
    border-bottom: 1px solid var(--color-border-light);
}
.prestations-detail__col li:last-child { border-bottom: 0; }
.prestations-detail__col li::before {
    content: '';
    position: absolute;
    left: 0; top: 1.05rem;
    width: 8px; height: 1px;
    background: var(--terracotta);
}

@media (max-width: 1024px) {
    .prestations-detail { grid-template-columns: repeat(2, 1fr); gap: 2.5rem 2rem; }
}
@media (max-width: 600px) {
    .prestations-detail { grid-template-columns: 1fr; gap: 2rem; }
}

/* --- Section Instagram (home) --- */
.insta-section {
    background:
        radial-gradient(ellipse at 80% 20%, rgba(185, 137, 105, .12) 0%, transparent 50%),
        radial-gradient(ellipse at 20% 80%, rgba(23, 55, 62, .08) 0%, transparent 55%),
        var(--cream-deep);
    position: relative;
    overflow: hidden;
}

.insta-section__grid {
    display: grid;
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: 5rem;
    align-items: center;
}

/* --- Gauche : présentation --- */
.insta-section__lede h2 {
    font-size: clamp(1.75rem, 3.2vw, 2.5rem);
    line-height: 1.1;
    margin-bottom: 1.25rem;
    color: var(--ink);
}
.insta-section__lede h2 em {
    font-style: italic;
    color: var(--terracotta);
    font-weight: 500;
}
.insta-section__lede > p {
    color: var(--ink-soft);
    font-size: 1rem;
    line-height: 1.65;
    margin-bottom: 2rem;
    max-width: 460px;
}

/* Card handle "@renovappart53" */
.insta-section__handle {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    padding: .65rem 1.25rem .65rem .65rem;
    background: var(--cream);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    margin-bottom: 1.75rem;
    box-shadow: var(--shadow-sm);
}
.insta-section__avatar {
    width: 42px; height: 42px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}
.insta-section__avatar img {
    width: 75%;
    height: auto;
    object-fit: contain;
}
.insta-section__handle-info {
    display: flex;
    flex-direction: column;
    line-height: 1.25;
}
.insta-section__handle-info strong {
    font-family: var(--font-sans);
    font-size: .9rem;
    font-weight: 600;
    color: var(--ink);
}
.insta-section__handle-info span {
    font-size: .7rem;
    color: var(--ink-soft);
}

/* CTA pill avec dégradé Insta */
.insta-section__cta {
    display: inline-flex;
    align-items: center;
    gap: .7rem;
    padding: 1rem 1.5rem 1rem 1.4rem;
    background: linear-gradient(135deg, #FEDA77 0%, #F58529 25%, #DD2A7B 55%, #8134AF 80%, #515BD4 100%);
    color: #fff;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    line-height: 1;
    box-shadow: 0 6px 24px -8px rgba(221, 42, 123, .5);
    transition: transform var(--t-med), box-shadow var(--t-med);
    position: relative;
}
.insta-section__cta svg:last-child {
    transition: transform var(--t-med);
}
.insta-section__cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px -8px rgba(221, 42, 123, .6);
    color: #fff;
}
.insta-section__cta:hover svg:last-child {
    transform: translateX(4px);
}

/* --- Droite : feed grid --- */
.insta-section__feed {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
    position: relative;
    padding: 14px;
    background: var(--cream);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow);
}

.insta-tile {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: var(--radius);
    position: relative;
    display: block;
    background: var(--cream-deep);
}
.insta-tile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--t-slow);
}
.insta-tile__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(221, 42, 123, .85) 0%, rgba(81, 91, 212, .85) 100%);
    color: #fff;
    opacity: 0;
    transition: opacity var(--t-med);
}
.insta-tile:hover img {
    transform: scale(1.08);
}
.insta-tile:hover .insta-tile__overlay {
    opacity: 1;
}
.insta-tile__overlay svg {
    transform: scale(.7);
    transition: transform var(--t-med);
}
.insta-tile:hover .insta-tile__overlay svg {
    transform: scale(1);
}

/* Mise en avant de la première tuile (plus grande) */
.insta-tile:first-child {
    grid-row: span 2;
    grid-column: span 2;
}

@media (max-width: 900px) {
    .insta-section__grid {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
}
@media (max-width: 540px) {
    .insta-section__feed {
        grid-template-columns: repeat(2, 1fr);
        padding: 10px;
    }
    .insta-tile:first-child {
        grid-row: span 2;
        grid-column: span 2;
    }
}

/* --- Galerie masonry (réalisations) --- */
.gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin: 0;
    padding: 0;
    list-style: none;
}
.gallery__item {
    aspect-ratio: 4 / 3;
    margin: 0;
    border-radius: var(--radius-lg);
    overflow: hidden;
    position: relative;
    display: block;
    background: var(--cream-deep);
    box-shadow: var(--shadow-sm);
}
/* Variation masonry : une carte sur six est portrait (span 2 rangées) */
.gallery__item:nth-child(7n+3) {
    aspect-ratio: 3 / 4;
    grid-row: span 2;
}
.gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform var(--t-slow);
}
.gallery__item:hover img {
    transform: scale(1.04);
}
.gallery__item__caption {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    padding: 1.25rem 1.5rem;
    background: linear-gradient(to top, rgba(23, 55, 62, .85) 0%, rgba(23, 55, 62, 0) 50%);
    opacity: 0;
    transition: opacity var(--t-med);
    color: #fff;
}
.gallery__item:hover .gallery__item__caption {
    opacity: 1;
}
.gallery__item__caption span {
    display: block;
    font-size: .7rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .8);
    margin-bottom: .25rem;
}
.gallery__item__caption strong {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 1rem;
    line-height: 1.2;
}

@media (max-width: 900px) {
    .gallery { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
    .gallery__item:nth-child(7n+3) { grid-row: span 1; aspect-ratio: 4 / 3; }
}
@media (max-width: 540px) {
    .gallery { grid-template-columns: 1fr; }
}

/* --------------------------------------------------------------------------
   6. Hero
   -------------------------------------------------------------------------- */
.hero {
    position: relative;
    min-height: 720px;
    display: flex;
    align-items: center;
    overflow: hidden;
    margin-top: calc(var(--header-h) * -1);
    padding-top: var(--header-h);
}
.hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.hero__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(23, 55, 62, .75) 0%,
        rgba(23, 55, 62, .35) 60%,
        rgba(23, 55, 62, .55) 100%
    );
}
.hero__inner {
    position: relative;
    z-index: 1;
    max-width: var(--container-max);
    width: 100%;
    margin-inline: auto;
    padding: 4rem var(--pad-desktop);
}
.hero__content {
    max-width: 640px;
}
.hero__label {
    display: inline-block;
    font-size: var(--fs-label);
    font-weight: 500;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .85);
    margin-bottom: 1.25rem;
    padding-left: 2.25rem;
    position: relative;
}
.hero__label::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    width: 1.5rem; height: 1px;
    background: rgba(255, 255, 255, .6);
}
.hero__title {
    font-family: var(--font-serif);
    font-size: var(--fs-display);
    font-weight: 700;
    line-height: 1.1;
    color: #fff;
    margin: 0 0 1.25rem;
}
.hero__lead {
    font-size: var(--fs-body-l);
    line-height: 1.6;
    color: rgba(255, 255, 255, .9);
    margin: 0 0 2rem;
}
.hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

@media (max-width: 768px) {
    .hero { min-height: 560px; }
    .hero__inner { padding-inline: var(--pad-mobile); }
}

/* --------------------------------------------------------------------------
   7. Section : Expertise & valeurs (2-col texte + image circulaire)
   -------------------------------------------------------------------------- */
.expertise-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--u-xl);
    align-items: center;
}
.expertise-grid h2 { color: var(--color-primary-darker); }
.expertise-grid p { color: var(--color-text-muted); }

.expertise-features {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    padding-top: 1rem;
}
.feature-card {
    padding: 1.25rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-sm);
}
.feature-card .material-symbols-outlined {
    font-size: 2rem;
    color: var(--color-primary);
    margin-bottom: .5rem;
    font-variation-settings: 'FILL' 1, 'wght' 400;
    display: block;
}
.feature-card h4 {
    margin: 0 0 .25rem;
    color: var(--color-primary-darker);
    font-family: var(--font-sans);
    font-size: var(--fs-label);
    font-weight: 600;
}
.feature-card p {
    margin: 0;
    font-size: var(--fs-caption);
    color: var(--color-text-muted);
}

.expertise-image {
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    overflow: hidden;
    border: 12px solid var(--color-surface);
    box-shadow: var(--shadow-xl);
}
.expertise-image img {
    width: 100%; height: 100%;
    object-fit: cover;
}

@media (max-width: 900px) {
    .expertise-grid { grid-template-columns: 1fr; gap: var(--u-lg); }
    .expertise-image { max-width: 360px; margin-inline: auto; }
}

/* --------------------------------------------------------------------------
   8. Bento grid services
   -------------------------------------------------------------------------- */
.services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--gutter);
}
.service-card {
    display: flex;
    flex-direction: column;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform var(--t-med), box-shadow var(--t-med), border-color var(--t-med);
}
.service-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-border);
    color: inherit;
}

/* Media area */
.service-card__media {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--cream-deep);
    position: relative;
}
.service-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--t-slow);
}
.service-card:hover .service-card__media img {
    transform: scale(1.05);
}

/* Body */
.service-card__body {
    padding: 1.5rem 1.75rem 1.75rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.service-card__icon {
    font-size: 1.75rem !important;
    color: var(--canard);
    margin-bottom: .75rem;
    display: block;
    opacity: .9;
}
.service-card h3 {
    color: var(--ink);
    font-size: var(--fs-headline-m);
    margin: 0 0 .5rem;
    line-height: 1.2;
}
.service-card p {
    color: var(--color-text-muted);
    font-size: .95rem;
    line-height: 1.55;
    margin: 0 0 1.25rem;
    flex: 1;
}
.service-card__more {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: var(--ink);
    font-weight: 600;
    font-size: .75rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    transition: gap var(--t-med), color var(--t-fast);
}
.service-card:hover .service-card__more {
    gap: .75rem;
    color: var(--canard);
}

@media (max-width: 900px) {
    .services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .services-grid { grid-template-columns: 1fr; }
}

/* --------------------------------------------------------------------------
   9. Why-us (carte primary avec stats)
   -------------------------------------------------------------------------- */
.why-us {
    background: linear-gradient(135deg, var(--canard) 0%, var(--canard-soft) 100%);
    color: rgba(255, 255, 255, .92);
    border-radius: var(--radius-2xl);
    padding: var(--u-xl);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--u-xl);
    align-items: center;
}
.why-us h2 { color: #fff; }
.why-us p { color: rgba(255, 255, 255, .8); }

.why-us__list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.why-us__list li {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: .75rem;
    color: rgba(255, 255, 255, .92);
}
.why-us__list .material-symbols-outlined {
    color: var(--color-leaf);
    font-variation-settings: 'FILL' 1, 'wght' 500;
}

.stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.stat-card {
    background: rgba(255, 255, 255, .08);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, .12);
    padding: 1.5rem;
    border-radius: var(--radius-xl);
    text-align: center;
}
.stat-card__value {
    display: block;
    font-family: var(--font-serif);
    font-size: 2.75rem;
    font-weight: 600;
    color: var(--terracotta);
    line-height: 1;
    margin-bottom: .25rem;
    letter-spacing: -.02em;
}
.stat-card__label {
    display: block;
    font-size: var(--fs-caption);
    text-transform: uppercase;
    letter-spacing: .12em;
    color: rgba(255, 255, 255, .85);
}

@media (max-width: 900px) {
    .why-us { grid-template-columns: 1fr; padding: var(--u-lg); }
}

/* --------------------------------------------------------------------------
   10. Témoignages
   -------------------------------------------------------------------------- */
.testimonials-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 1rem;
    margin-bottom: var(--u-xl);
    flex-wrap: wrap;
}
.testimonials-header h2 { margin: 0; }

.testimonials-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--gutter);
}
.testimonial-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 2rem;
    box-shadow: var(--shadow-sm);
}
.testimonial-card__stars {
    color: var(--terracotta);
    margin-bottom: .75rem;
    display: flex;
    gap: .15rem;
}
.testimonial-card__stars .material-symbols-outlined {
    font-variation-settings: 'FILL' 1;
    font-size: 1.25rem;
}
.testimonial-card__quote {
    font-family: var(--font-serif);
    font-size: var(--fs-body-l);
    font-style: italic;
    line-height: 1.5;
    color: var(--color-primary-darker);
    margin: 0 0 1.5rem;
}
.testimonial-card__author {
    display: flex;
    align-items: center;
    gap: .85rem;
}
.testimonial-card__avatar {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--sand);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--canard);
    font-family: var(--font-serif);
    font-weight: 600;
    font-size: .95rem;
    letter-spacing: -.01em;
}
.testimonial-card__author h4 {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--fs-label);
    color: var(--color-primary-darker);
}
.testimonial-card__author p {
    margin: 0;
    font-size: var(--fs-caption);
    color: var(--color-text-muted);
}

@media (max-width: 768px) {
    .testimonials-grid { grid-template-columns: 1fr; }
}

/* Variante 3 colonnes (page /avis-clients + section accueil)
   La grille de base reste en 2 cols pour les autres usages éventuels. */
.testimonials-grid--3 {
    grid-template-columns: repeat(3, 1fr);
    list-style: none;
    padding: 0;
}
@media (max-width: 1024px) {
    .testimonials-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .testimonials-grid--3 { grid-template-columns: 1fr; }
}

/* CTA dans le hero de la page /avis-clients */
.avis-hero__cta {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 2rem;
}

/* --------------------------------------------------------------------------
   10b. Instagram embed
   -------------------------------------------------------------------------- */
.section-header p {
    max-width: 600px;
    margin: 1rem auto 0;
    color: var(--color-text-muted);
    font-size: var(--fs-body-l);
}
.insta-embed {
    display: flex;
    justify-content: center;
    margin: 0 auto;
    max-width: 540px;
    width: 100%;
}
.insta-embed .instagram-media {
    width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
}
.insta-cta {
    display: flex;
    justify-content: center;
    margin-top: 2rem;
}
.insta-cta .btn {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
}

/* --------------------------------------------------------------------------
   11. CTA final
   -------------------------------------------------------------------------- */
.cta-final {
    text-align: center;
    padding: var(--u-xl) 0;
}
.cta-final h2 {
    font-size: var(--fs-display);
    font-weight: 700;
    margin-bottom: 1rem;
}
.cta-final p {
    font-size: var(--fs-body-l);
    color: var(--color-text-muted);
    max-width: 600px;
    margin: 0 auto 2rem;
}

/* --------------------------------------------------------------------------
   12. Page hero (sous-pages)
   -------------------------------------------------------------------------- */
.page-hero {
    background: var(--cream-deep);
    padding: 5rem 0 3.5rem;
    text-align: center;
}
.page-hero .section-label {
    color: var(--canard);
    margin-bottom: 1rem;
}
.page-hero h1 {
    color: var(--ink);
    font-size: var(--fs-display);
    margin: 0 0 .75rem;
}
.page-hero__lead {
    font-size: var(--fs-body-l);
    color: var(--color-text-muted);
    max-width: 640px;
    margin: 0 auto;
}
.page-hero__back {
    margin: 1.5rem 0 0;
    font-size: .75rem;
    font-weight: 500;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.page-hero__back a {
    color: var(--stone);
    transition: color var(--t-fast);
}
.page-hero__back a:hover {
    color: var(--ink);
}

/* --- Prestation hero (sous-pages) — immersif avec image --- */
.prestation-hero {
    position: relative;
    min-height: 480px;
    display: flex;
    align-items: center;
    overflow: hidden;
    margin-top: calc(var(--header-h) * -1);
    padding: calc(var(--header-h) + 4rem) 0 5rem;
    color: #fff;
}
.prestation-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.prestation-hero__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.prestation-hero__overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(
            135deg,
            rgba(23, 55, 62, .82) 0%,
            rgba(23, 55, 62, .55) 60%,
            rgba(23, 55, 62, .72) 100%
        );
}
.prestation-hero__inner {
    position: relative;
    z-index: 1;
    max-width: var(--container-max);
    width: 100%;
    margin-inline: auto;
    padding-inline: var(--pad-desktop);
}
.prestation-hero__back {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin-bottom: 2rem;
    font-size: .7rem;
    font-weight: 500;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .75);
    transition: color var(--t-fast), gap var(--t-fast);
}
.prestation-hero__back:hover {
    color: #fff;
    gap: .65rem;
}
.prestation-hero__title {
    font-family: var(--font-serif);
    font-size: clamp(2.25rem, 5vw, 3.5rem);
    font-weight: 600;
    line-height: 1.05;
    letter-spacing: -.02em;
    color: #fff;
    margin: 0 0 1.25rem;
    max-width: 720px;
}
.prestation-hero__lead {
    font-size: var(--fs-body-l);
    line-height: 1.6;
    color: rgba(255, 255, 255, .88);
    max-width: 620px;
    margin: 0;
}

@media (max-width: 768px) {
    .prestation-hero {
        min-height: 380px;
        padding: calc(var(--header-h) + 3rem) 0 4rem;
    }
    .prestation-hero__inner { padding-inline: var(--pad-mobile); }
}

/* --- Sections plus aérées sur les sous-pages prestations --- */
.prestation-hero + .section,
.prestation-hero ~ .section {
    padding-block: 5.5rem;
}
@media (max-width: 768px) {
    .prestation-hero + .section,
    .prestation-hero ~ .section {
        padding-block: 4rem;
    }
}

/* --- Variante service-card non cliquable (sur sous-pages) --- */
.service-card--static {
    cursor: default;
}
.service-card--static:hover {
    transform: none;
    box-shadow: var(--shadow-sm);
    border-color: var(--color-border);
}
.service-card--static:hover .service-card__media img {
    transform: scale(1.04);
}

/* --- Forcer 3 colonnes (utilisé sur sous-pages) --- */
.services-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 900px) {
    .services-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .services-grid--3 { grid-template-columns: 1fr; }
}

/* --- Mini galerie sur sous-pages prestations --- */
.prestation-gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}
.prestation-gallery__item {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border-radius: var(--radius-lg);
    background: var(--cream-deep);
}
.prestation-gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--t-slow);
}
.prestation-gallery__item:hover img {
    transform: scale(1.05);
}
.prestation-gallery__item:first-child {
    grid-column: span 2;
    grid-row: span 2;
    aspect-ratio: auto;
}
@media (max-width: 768px) {
    .prestation-gallery {
        grid-template-columns: repeat(2, 1fr);
    }
    .prestation-gallery__item:first-child {
        grid-column: span 2;
        grid-row: auto;
        aspect-ratio: 16 / 10;
    }
}
@media (max-width: 480px) {
    .prestation-gallery { grid-template-columns: 1fr; }
    .prestation-gallery__item:first-child { aspect-ratio: 4 / 3; }
}

/* --------------------------------------------------------------------------
   13. Footer — éditorial pastel
   -------------------------------------------------------------------------- */
.site-footer {
    margin-top: var(--u-xl);
    background: var(--cream);
    color: var(--ink);
    position: relative;
}
.site-footer::before {
    content: '';
    position: absolute;
    top: 0; left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 4rem);
    max-width: var(--container-max);
    height: 1px;
    background: var(--color-border);
}

.site-footer__inner {
    max-width: var(--container-max);
    margin-inline: auto;
    padding: 6rem var(--pad-desktop) 4rem;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 5rem;
    align-items: start;
}

/* Bloc éditorial (gauche) */
.site-footer__lede {
    max-width: 540px;
}
.site-footer__eyebrow {
    display: inline-block;
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--stone);
    margin-bottom: 1.75rem;
    position: relative;
    padding-left: 2rem;
}
.site-footer__eyebrow::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    width: 1.5rem; height: 1px;
    background: var(--ink);
    transform: translateY(-50%);
}
.site-footer__statement {
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 600;
    line-height: 1.2;
    color: var(--ink);
    margin: 0 0 2.5rem;
}
.site-footer__statement em {
    font-style: italic;
    color: var(--ink-soft);
    font-weight: 400;
}

.site-footer__cta {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.5rem 1rem 1.75rem;
    background: transparent;
    border: 1px solid var(--ink);
    border-radius: 999px;
    color: var(--ink);
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    transition: background var(--t-med), color var(--t-med);
}
.site-footer__cta svg {
    transition: transform var(--t-med);
}
.site-footer__cta:hover {
    background: var(--ink);
    color: var(--cream);
}
.site-footer__cta:hover svg {
    transform: translateX(4px);
}

/* Réseaux sociaux dans le footer */
.site-footer__socials {
    display: flex;
    gap: .65rem;
    margin-top: 2.5rem;
}
.site-footer__socials a {
    width: 42px; height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ink);
    border: 1px solid var(--color-border);
    border-radius: 50%;
    transition: background var(--t-med), color var(--t-med), border-color var(--t-med);
}
.site-footer__socials a:hover {
    background: var(--ink);
    color: var(--cream);
    border-color: var(--ink);
}
.site-footer__socials a::after { display: none; }

/* Mini-colonnes (droite) */
.site-footer__cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem 2rem;
}

.site-footer__col h4 {
    font-family: var(--font-sans);
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--stone);
    margin: 0 0 1.25rem;
}
.site-footer__col p {
    font-size: .9rem;
    line-height: 1.6;
    color: var(--ink-soft);
    margin: 0 0 1rem;
    max-width: 360px;
}
.site-footer__col ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.site-footer__col li {
    margin: 0 0 .5rem;
    font-size: .95rem;
    font-family: var(--font-serif);
    font-weight: 500;
}
.site-footer__col a {
    color: var(--ink);
    transition: color var(--t-fast);
    position: relative;
    display: inline-block;
}
.site-footer__col a::after {
    content: '';
    position: absolute;
    left: 0; right: 0;
    bottom: -2px;
    height: 1px;
    background: var(--ink);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--t-med);
}
.site-footer__col a:hover::after {
    transform: scaleX(1);
}
.site-footer__col .site-footer__meta {
    font-family: var(--font-sans);
    font-size: .85rem;
    color: var(--ink-soft);
    font-weight: 400;
}

/* Bottom bar */
.site-footer__bottom {
    border-top: 1px solid var(--color-border);
    padding: 1.5rem var(--pad-desktop);
}
.site-footer__bottom-inner {
    max-width: var(--container-max);
    margin-inline: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    font-size: .75rem;
    color: var(--stone);
}
.site-footer__bottom-inner p {
    margin: 0;
    font-size: .75rem;
    letter-spacing: .03em;
}
.site-footer__legal {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}
.site-footer__legal a {
    color: var(--stone);
    transition: color var(--t-fast);
}
.site-footer__legal a:hover {
    color: var(--ink);
}
.site-footer__sep {
    color: var(--color-border);
}

@media (max-width: 900px) {
    .site-footer__inner {
        grid-template-columns: 1fr;
        gap: 3.5rem;
        padding: 4rem var(--pad-desktop) 3rem;
    }
}
@media (max-width: 600px) {
    .site-footer__inner {
        padding: 3.5rem var(--pad-mobile) 2.5rem;
        gap: 3rem;
    }
    .site-footer__cols {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }
    .site-footer__bottom-inner {
        justify-content: center;
        text-align: center;
        flex-direction: column;
    }
}


/* ===== Contact + Map + Timeline ===== */

/* --------------------------------------------------------------------------
   Contact — hero, infos, formulaire
   -------------------------------------------------------------------------- */
.contact-hero {
    position: relative;
    height: clamp(280px, 35vw, 420px);
    overflow: hidden;
}
.contact-hero img {
    width: 100%; height: 100%;
    object-fit: cover; object-position: center 60%;
    display: block;
}
.contact-hero__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg,
                rgba(23, 55, 62, .25) 0%,
                rgba(23, 55, 62, .75) 100%);
}
.contact-hero__content {
    position: absolute; inset: 0;
    display: flex; align-items: flex-end;
    padding-bottom: 3rem;
}
.contact-hero__content .container { color: #fff; }
.contact-hero__content .section-label { color: rgba(255, 255, 255, .8); }
.contact-hero__content h1 {
    color: #fff;
    font-size: clamp(2rem, 4vw, 3.2rem);
    margin: .25rem 0 .75rem;
    max-width: 760px;
}
.contact-hero__content p {
    color: rgba(255, 255, 255, .92);
    font-size: 1.05rem;
    line-height: 1.55;
    max-width: 620px;
    margin: 0;
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.45fr;
    gap: 3rem;
    align-items: start;
}
.contact-infos h2,
.contact-form h2 { margin: 0 0 1.5rem; }

.contact-card-list {
    display: grid;
    gap: 1rem;
}
.contact-card {
    display: flex; align-items: flex-start; gap: 1rem;
    padding: 1.25rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: transform var(--t-med), box-shadow var(--t-med);
}
.contact-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}
.contact-card .material-symbols-outlined {
    font-size: 1.4rem;
    color: var(--color-primary-darker);
    background: rgba(23, 55, 62, .08);
    padding: .55rem;
    border-radius: var(--radius);
    flex-shrink: 0;
}
.contact-card__label {
    display: block;
    font-size: .75rem; font-weight: 600;
    color: var(--ink-soft);
    text-transform: uppercase;
    letter-spacing: .1em;
    margin-bottom: .35rem;
}
.contact-card__value,
.contact-card__value a {
    display: block;
    color: var(--ink);
    font-weight: 500;
    line-height: 1.4;
    text-decoration: none;
}
.contact-card__value a:hover { color: var(--color-primary-darker); }

/* Formulaire */
.contact-form {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 2.5rem;
    box-shadow: var(--shadow-sm);
}
.form-row {
    margin-bottom: 1.25rem;
    display: flex; flex-direction: column;
    gap: .4rem;
}
.form-row label {
    font-weight: 500;
    font-size: .9rem;
    color: var(--ink);
}
.form-row input[type="text"],
.form-row input[type="email"],
.form-row input[type="tel"],
.form-row select,
.form-row textarea {
    padding: .85rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-bg);
    font-family: inherit;
    font-size: 1rem;
    color: var(--ink);
    transition: border-color var(--t-fast), box-shadow var(--t-fast),
                background var(--t-fast);
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus {
    outline: none;
    border-color: var(--color-primary-darker);
    background: var(--color-surface);
    box-shadow: 0 0 0 3px rgba(23, 55, 62, .1);
}
.form-row textarea {
    resize: vertical;
    min-height: 140px;
    font-family: inherit;
}
.form-row--two {
    flex-direction: row;
    gap: 1rem;
}
.form-row--two > .form-row {
    flex: 1;
    margin-bottom: 0;
}
.form-row--checkbox {
    flex-direction: row;
    align-items: flex-start;
    gap: .65rem;
    margin: 1.5rem 0;
}
.form-row--checkbox input[type="checkbox"] {
    margin-top: .2rem;
    accent-color: var(--color-primary-darker);
    width: 16px; height: 16px;
}
.form-row--checkbox label {
    font-weight: 400;
    font-size: .85rem;
    color: var(--ink-soft);
    line-height: 1.5;
    margin: 0;
}
.contact-form .btn { width: 100%; justify-content: center; }

@media (max-width: 900px) {
    .contact-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .contact-form { padding: 1.75rem; }
    .form-row--two { flex-direction: column; gap: 1.25rem; }
}

/* --------------------------------------------------------------------------
   Zone d'intervention — carte + liste des communes
   -------------------------------------------------------------------------- */
.map-wrap {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: 0;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow);
    background: var(--color-surface);
}
.map-iframe {
    width: 100%;
    height: 480px;
    border: 0;
    display: block;
    filter: grayscale(.15);
}
.map-side {
    background: var(--color-primary-darker);
    color: #fff;
    padding: 2.5rem 2rem;
    display: flex; flex-direction: column;
    justify-content: center;
}
.map-side .section-label {
    color: rgba(255, 255, 255, .7);
    margin-bottom: .35rem;
}
.map-side h3 {
    color: #fff;
    margin: 0 0 1rem;
    font-size: 1.5rem;
}
.map-side p {
    color: rgba(255, 255, 255, .85);
    margin: 0 0 1.5rem;
    line-height: 1.55;
}
.map-side__list {
    list-style: none;
    padding: 0;
    margin: 0;
    columns: 2;
    column-gap: 1.25rem;
}
.map-side__list li {
    padding: .3rem 0;
    color: rgba(255, 255, 255, .92);
    font-size: .92rem;
    display: flex; align-items: center;
    gap: .5rem;
    break-inside: avoid;
}
.map-side__list li::before {
    content: "";
    width: 5px; height: 5px;
    background: var(--terracotta);
    border-radius: 50%;
    flex-shrink: 0;
}

@media (max-width: 900px) {
    .map-wrap { grid-template-columns: 1fr; }
    .map-iframe { height: 360px; }
    .map-side { padding: 2rem 1.5rem; }
}

/* --------------------------------------------------------------------------
   Timeline projet client
   -------------------------------------------------------------------------- */
.timeline {
    position: relative;
    margin: 3rem auto 0;
    max-width: 880px;
    padding-left: 3rem;
}
.timeline::before {
    content: "";
    position: absolute;
    left: 19px; top: 12px; bottom: 12px;
    width: 2px;
    background: linear-gradient(180deg,
                var(--color-primary-darker) 0%,
                var(--color-primary-darker) 60%,
                var(--color-border) 100%);
}
.timeline__item {
    position: relative;
    margin-bottom: 2.5rem;
}
.timeline__item:last-child { margin-bottom: 0; }

.timeline__marker {
    position: absolute;
    left: -3rem; top: 0;
    width: 40px; height: 40px;
    background: var(--color-primary-darker);
    color: #fff;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 0 0 4px var(--color-bg);
}
.timeline__marker .material-symbols-outlined {
    font-size: 1.25rem;
}
.section--alt .timeline__marker {
    box-shadow: 0 0 0 4px var(--color-bg-alt);
}
.timeline__step {
    display: inline-block;
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--terracotta);
    margin-bottom: .25rem;
}
.timeline__title {
    margin: 0 0 .5rem;
    font-family: var(--font-serif);
    font-size: 1.35rem;
    color: var(--color-primary-darker);
}
.timeline__content p {
    margin: 0;
    color: var(--ink-soft);
    line-height: 1.6;
}
.timeline__meta {
    display: inline-flex; align-items: center; gap: .35rem;
    margin-top: .75rem;
    padding: .3rem .75rem;
    background: var(--color-primary-light);
    color: var(--color-primary-darker);
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 500;
}
.timeline__meta .material-symbols-outlined { font-size: .95rem; }

@media (max-width: 600px) {
    .timeline { padding-left: 2.5rem; }
    .timeline__marker { left: -2.5rem; width: 34px; height: 34px; }
    .timeline__marker .material-symbols-outlined { font-size: 1.05rem; }
    .timeline::before { left: 16px; }
}

/* --------------------------------------------------------------------------
   14. Page hero — variante split (texte + image)
   -------------------------------------------------------------------------- */
.page-hero--split {
    text-align: left;
    padding: 4rem 0;
}
.page-hero--split .page-hero__split {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: var(--u-xl);
    align-items: center;
}
.page-hero--split h1 {
    font-size: clamp(2rem, 4.5vw, 3rem);
    margin: .5rem 0 1rem;
}
.page-hero__lead--left {
    margin: 0 0 1.5rem;
    max-width: 520px;
    text-align: left;
}
.page-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-top: 1.75rem;
}
.page-hero__media {
    position: relative;
    aspect-ratio: 5 / 4;
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: var(--shadow-xl);
}
.page-hero__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.page-hero__media__badge {
    position: absolute;
    bottom: 1.25rem;
    left: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: .1rem;
    padding: .85rem 1.1rem;
    background: rgba(250, 247, 242, .94);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
}
.page-hero__media__badge strong {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--canard);
    line-height: 1;
}
.page-hero__media__badge span {
    font-size: .68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--stone);
}

@media (max-width: 900px) {
    .page-hero--split { padding: 3rem 0 2.5rem; }
    .page-hero--split .page-hero__split { grid-template-columns: 1fr; gap: var(--u-lg); }
    .page-hero__media { aspect-ratio: 16 / 10; }
}

/* --------------------------------------------------------------------------
   15. Universe grid — galerie d'inspirations (cards carrées, uniformes)
   -------------------------------------------------------------------------- */
.universe-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-top: 2.5rem;
}
.universe-card {
    position: relative;
    display: block;
    aspect-ratio: 1 / 1;                    /* carré uniforme — recadrage propre */
    overflow: hidden;
    border-radius: var(--radius-xl);
    background: var(--cream-deep);
    color: #fff;
    isolation: isolate;
    border: 1px solid var(--color-border-light);
    box-shadow: var(--shadow-sm);
    transition: transform var(--t-med), box-shadow var(--t-med);
}
.universe-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 55%;
    transition: transform 700ms cubic-bezier(.22, 1, .36, 1);
}
.universe-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(23, 55, 62, .04) 0%, transparent 35%, rgba(23, 55, 62, .85) 100%);
    pointer-events: none;
    z-index: 1;
}
.universe-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}
.universe-card:hover img { transform: scale(1.06); }
.universe-card__caption {
    position: absolute;
    left: 1.25rem;
    right: 1.25rem;
    bottom: 1.25rem;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: .4rem;
}
.universe-card__tag {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: #fff;
    opacity: .9;
}
.universe-card__tag::before {
    content: '';
    width: 18px;
    height: 1px;
    background: var(--terracotta);
}
.universe-card__title {
    color: #fff;
    font-family: var(--font-serif);
    font-size: 1.15rem;
    font-weight: 500;
    line-height: 1.25;
    letter-spacing: -.01em;
}

@media (max-width: 900px) {
    .universe-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
    .universe-grid { grid-template-columns: 1fr; gap: 1rem; }
    .universe-card { aspect-ratio: 4 / 3; }
}

/* --------------------------------------------------------------------------
   16. CTA final — variante image de fond
   -------------------------------------------------------------------------- */
.cta-final--image {
    position: relative;
    padding: 4.5rem 2rem;
    border-radius: var(--radius-2xl);
    overflow: hidden;
    color: #fff;
    isolation: isolate;
    background:
        linear-gradient(135deg, rgba(23, 55, 62, .82) 0%, rgba(15, 92, 112, .72) 100%),
        url('/assets/img/renovation-cuisine-blanche-sur-mesure-renovappart_orig.jpg') center/cover no-repeat;
}
.cta-final--image .section-label { color: var(--terracotta); }
.cta-final--image h2 { color: #fff; }
.cta-final--image p { color: rgba(255, 255, 255, .88); }
.cta-final__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .75rem;
    margin-top: 2rem;
}
.cta-final--image .btn--ghost {
    background: transparent;
    border-color: rgba(255, 255, 255, .35);
    color: #fff;
}
.cta-final--image .btn--ghost:hover {
    background: rgba(255, 255, 255, .12);
    border-color: rgba(255, 255, 255, .55);
    color: #fff;
}

@media (max-width: 600px) {
    .cta-final--image { padding: 3rem 1.25rem; }
}

/* --------------------------------------------------------------------------
   17. Testimonial card — variante avec photo de chantier
       hauteurs strictement uniformes : grid stretch + height 100% +
       auteur épinglé en bas via margin-top: auto.
   -------------------------------------------------------------------------- */
.testimonials-grid--3 > li,
.testimonials-grid > li {
    margin: 0;
    list-style: none;
}

.testimonial-card--with-media {
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;                           /* remplit la cellule de grille */
    transition: transform var(--t-med), box-shadow var(--t-med);
}
.testimonial-card--with-media:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow);
}
.testimonial-card--with-media .testimonial-card__media {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--cream-deep);
    flex-shrink: 0;
}
.testimonial-card--with-media .testimonial-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 50%;
    transition: transform 700ms cubic-bezier(.22, 1, .36, 1);
}
.testimonial-card--with-media:hover .testimonial-card__media img {
    transform: scale(1.05);
}
.testimonial-card--with-media .testimonial-card__body {
    padding: 1.75rem 1.75rem 1.85rem;
    display: flex;
    flex-direction: column;
    flex: 1;                                /* corps remplit la hauteur restante */
}
.testimonial-card--with-media .testimonial-card__stars { margin-bottom: .75rem; }
.testimonial-card--with-media .testimonial-card__quote {
    margin: 0 0 1.5rem;
    font-size: 1rem;
    line-height: 1.55;
}
.testimonial-card--with-media .testimonial-card__author {
    margin-top: auto;                       /* épingle l'auteur tout en bas */
    padding-top: 1.25rem;
    border-top: 1px solid var(--color-border-light);
}

/* --------------------------------------------------------------------------
   18. Realisations teaser — strip 4 colonnes
   -------------------------------------------------------------------------- */
.realisations-teaser {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-top: 2.5rem;
}
.realisations-teaser__item {
    position: relative;
    display: block;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: var(--radius-lg);
}
.realisations-teaser__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 600ms cubic-bezier(.22, 1, .36, 1);
}
.realisations-teaser__item::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(23, 55, 62, 0);
    transition: background var(--t-med);
}
.realisations-teaser__item:hover img { transform: scale(1.06); }
.realisations-teaser__item:hover::after { background: rgba(23, 55, 62, .15); }

@media (max-width: 768px) {
    .realisations-teaser { grid-template-columns: repeat(2, 1fr); }
}

/* --------------------------------------------------------------------------
   Page loader — apparition immersive + dézoome à la fermeture
   -------------------------------------------------------------------------- */
.page-loader {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.75rem;
    background: var(--cream);
    opacity: 1;
    visibility: visible;
    will-change: opacity;
    transition:
        opacity 700ms cubic-bezier(.22, .61, .36, 1),
        visibility 0s linear 700ms;
}

.page-loader__logo {
    width: 180px;
    height: auto;
    animation: pl-pulse 1.9s ease-in-out infinite;
}

@keyframes pl-pulse {
    0%, 100% { opacity: 1;   transform: scale(1); }
    50%      { opacity: .55; transform: scale(.965); }
}

.page-loader__bar {
    position: relative;
    width: min(220px, 40vw);
    height: 2px;
    background: rgba(26, 42, 48, .08);
    border-radius: 999px;
    overflow: hidden;
}

.page-loader__bar span {
    position: absolute;
    top: 0;
    left: 0;
    width: 35%;
    height: 100%;
    background: linear-gradient(90deg,
        rgba(23, 55, 62, 0),
        var(--canard) 50%,
        rgba(23, 55, 62, 0));
    border-radius: 999px;
    animation: pl-sweep 1.4s cubic-bezier(.4, 0, .2, 1) infinite;
}

@keyframes pl-sweep {
    0%   { transform: translateX(-120%); }
    100% { transform: translateX(380%); }
}

/* Pré-chargement : contenu invisible et légèrement zoomé,
   mais on ne transforme PAS le body — sinon le loader (position: fixed)
   serait positionné par rapport au body scalé au lieu du viewport. */
body:not(.is-loaded) {
    overflow: hidden;
}

body:not(.is-loaded) .site-header,
body:not(.is-loaded) .site-main {
    opacity: 0;
    transform: scale(1.06);
}

.site-header,
.site-main {
    transform-origin: 50% 35%;
    transition:
        opacity    800ms cubic-bezier(.22, .61, .36, 1) 150ms,
        transform 1100ms cubic-bezier(.22, .61, .36, 1);
}

/* Chargé : on fait disparaître le loader + dézoome la page */
body.is-loaded .page-loader {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

body.is-loaded .site-header,
body.is-loaded .site-main {
    opacity: 1;
    transform: scale(1);
}

@media (prefers-reduced-motion: reduce) {
    .page-loader__logo,
    .page-loader__bar span { animation: none; }
    body,
    .site-header,
    .site-main,
    .site-footer {
        transition: opacity 250ms ease !important;
        transform: none !important;
    }
}


/* ===== Skills grid (entreprise) ===== */

.skills-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}
.skills-grid .feature-card {
    transition: transform var(--t-med), box-shadow var(--t-med), border-color var(--t-fast);
}
.skills-grid .feature-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow);
    border-color: var(--color-primary-darker);
}
.skills-grid .feature-card h4 {
    font-size: 1.05rem;
}
.skills-grid .feature-card p {
    margin-top: .35rem;
    line-height: 1.5;
}

@media (max-width: 900px) {
    .skills-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .skills-grid { grid-template-columns: 1fr; }
}

/* --------------------------------------------------------------------------
   FAQ — accordéon SEO-friendly (details/summary + FAQPage schema)
   -------------------------------------------------------------------------- */
.faq-section .section-header { margin-bottom: 2.5rem; }

.faq-section__intro {
    max-width: 640px;
    margin: 1.25rem auto 0;
    color: var(--ink-soft);
    font-size: var(--fs-body-l);
}

.faq-list {
    max-width: 820px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: .75rem;
}

.faq-item {
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: box-shadow var(--t-med), border-color var(--t-med);
}

.faq-item[open] {
    border-color: rgba(23, 55, 62, .18);
    box-shadow: var(--shadow);
}

.faq-item__summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1.15rem 1.5rem;
    cursor: pointer;
    list-style: none;
    color: var(--ink);
    font-family: var(--font-serif);
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1.4;
    transition: color var(--t-fast), background var(--t-fast);
}

.faq-item__summary::-webkit-details-marker { display: none; }
.faq-item__summary::marker { content: ''; }

.faq-item__summary:hover {
    color: var(--canard);
    background: rgba(23, 55, 62, .03);
}

.faq-item__q { flex: 1; }

.faq-item__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    border-radius: 999px;
    background: var(--cream-deep);
    color: var(--canard);
    transition: transform var(--t-med), background var(--t-fast);
}

.faq-item[open] .faq-item__icon {
    transform: rotate(180deg);
    background: var(--canard);
    color: #fff;
}

.faq-item__a {
    padding: 0 1.5rem 1.4rem;
    color: var(--ink-soft);
    font-size: var(--fs-body);
    line-height: 1.65;
    animation: faq-reveal 350ms cubic-bezier(.22, .61, .36, 1);
}

.faq-item__a p { margin: 0 0 .75rem; }
.faq-item__a p:last-child { margin-bottom: 0; }
.faq-item__a ul {
    margin: .5rem 0 0;
    padding-left: 1.25rem;
}
.faq-item__a a {
    color: var(--canard);
    text-decoration: underline;
    text-underline-offset: 3px;
}

@keyframes faq-reveal {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 600px) {
    .faq-item__summary {
        padding: 1rem 1.15rem;
        font-size: 1rem;
        gap: 1rem;
    }
    .faq-item__a { padding: 0 1.15rem 1.15rem; }
    .faq-item__icon { width: 28px; height: 28px; }
}

@media (prefers-reduced-motion: reduce) {
    .faq-item, .faq-item__icon, .faq-item__summary {
        transition: none !important;
    }
    .faq-item__a { animation: none !important; }
}

/* ==========================================================================
   N. Effets au scroll
   ========================================================================== */

/* --- Reveal (fade + translateY) --------------------------------------------
   Le JS ajoute la classe .reveal aux éléments cibles puis .is-visible
   quand ils entrent dans le viewport (IntersectionObserver).
*/
@media (prefers-reduced-motion: no-preference) {
    .reveal {
        opacity: 0;
        transform: translateY(28px);
        transition: opacity 800ms cubic-bezier(.22, 1, .36, 1),
                    transform 800ms cubic-bezier(.22, 1, .36, 1);
        will-change: opacity, transform;
    }
    .reveal--fade   { transform: none; }
    .reveal--left   { transform: translateX(-32px); }
    .reveal--right  { transform: translateX(32px); }
    .reveal--scale  { transform: scale(.96); }

    .reveal.is-visible {
        opacity: 1;
        transform: none;
    }

    /* Stagger : un parent .reveal-stagger echelonne ses enfants .reveal */
    .reveal-stagger > .reveal                 { transition-delay: 0ms; }
    .reveal-stagger > .reveal:nth-child(2)    { transition-delay: 90ms; }
    .reveal-stagger > .reveal:nth-child(3)    { transition-delay: 180ms; }
    .reveal-stagger > .reveal:nth-child(4)    { transition-delay: 270ms; }
    .reveal-stagger > .reveal:nth-child(5)    { transition-delay: 360ms; }
    .reveal-stagger > .reveal:nth-child(6)    { transition-delay: 450ms; }
    .reveal-stagger > .reveal:nth-child(7)    { transition-delay: 540ms; }
    .reveal-stagger > .reveal:nth-child(8)    { transition-delay: 630ms; }
    .reveal-stagger > .reveal:nth-child(n+9)  { transition-delay: 720ms; }
}

/* --- Header : densification au scroll -------------------------------------- */
.site-header {
    transition: background var(--t-med),
                box-shadow var(--t-med),
                border-color var(--t-med);
}
body.is-scrolled .site-header {
    background: rgba(250, 247, 242, .96);
    box-shadow: 0 6px 24px -12px rgba(15, 42, 53, .14);
    border-bottom-color: rgba(31, 45, 51, .08);
}

/* --- Parallax hero --------------------------------------------------------- */
@media (prefers-reduced-motion: no-preference) {
    .hero__bg {
        will-change: transform;
        transition: transform 60ms linear;
    }
}

/* --- Back-to-top ----------------------------------------------------------- */
.back-to-top {
    position: fixed;
    right: 1.5rem;
    bottom: 1.5rem;
    width: 48px;
    height: 48px;
    border-radius: 999px;
    background: var(--ink);
    color: var(--cream);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    cursor: pointer;
    box-shadow: var(--shadow-lg);
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity var(--t-med),
                visibility var(--t-med),
                transform var(--t-med),
                background var(--t-fast);
    z-index: 900;
}
.back-to-top:hover {
    background: var(--canard);
    color: var(--cream);
}
body.is-scrolled .back-to-top {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
@media (max-width: 600px) {
    .back-to-top {
        right: 1rem;
        bottom: calc(1rem + env(safe-area-inset-bottom));
        width: 44px;
        height: 44px;
    }
}

/* --- Scroll progress bar (fine ligne en haut) ------------------------------ */
.scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    height: 2px;
    width: 100%;
    transform: scaleX(0);
    transform-origin: 0 50%;
    background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
    z-index: 1100;
    pointer-events: none;
}

/* --- Liens d'ancrage : decalage pour le header fixe ------------------------ */
[id] { scroll-margin-top: calc(var(--header-h) + 1rem); }

/* --------------------------------------------------------------------------
   Lightbox — clic sur miniature de galerie pour aperçu plein écran
   -------------------------------------------------------------------------- */
.gallery__item img {
    cursor: zoom-in;
}

.lightbox {
    position: fixed;
    inset: 0;
    z-index: 9998;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(1rem, 4vw, 3rem);
    background: rgba(23, 55, 62, .92);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    opacity: 0;
    visibility: hidden;
    transition:
        opacity 320ms ease,
        visibility 0s linear 320ms;
}
.lightbox.is-open {
    opacity: 1;
    visibility: visible;
    transition:
        opacity 320ms ease,
        visibility 0s linear 0s;
}

.lightbox__figure {
    margin: 0;
    max-width: min(1200px, 92vw);
    max-height: 86vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    transform: scale(.96);
    transition: transform 360ms cubic-bezier(.22, 1, .36, 1);
}
.lightbox.is-open .lightbox__figure {
    transform: scale(1);
}

.lightbox__img {
    max-width: 100%;
    max-height: 76vh;
    width: auto;
    height: auto;
    border-radius: var(--radius-lg);
    box-shadow: 0 40px 80px rgba(0, 0, 0, .45);
    background: var(--cream);
    object-fit: contain;
}

.lightbox__caption {
    text-align: center;
    color: var(--cream);
    max-width: 720px;
    padding-inline: 1rem;
}
.lightbox__tag {
    display: inline-block;
    text-transform: uppercase;
    letter-spacing: .14em;
    font-size: .72rem;
    font-weight: 600;
    color: var(--terracotta);
    margin-bottom: .35rem;
}
.lightbox__title {
    display: block;
    font-family: var(--font-serif);
    font-size: 1.15rem;
    font-weight: 500;
    line-height: 1.3;
    color: var(--cream);
}
.lightbox__counter {
    display: block;
    margin-top: .5rem;
    font-size: .75rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(250, 247, 242, .55);
}

/* Boutons : close + nav */
.lightbox__close,
.lightbox__nav {
    position: absolute;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .18);
    color: var(--cream);
    cursor: pointer;
    transition:
        background var(--t-fast),
        border-color var(--t-fast),
        transform var(--t-fast);
    z-index: 2;
}
.lightbox__close:hover,
.lightbox__nav:hover {
    background: rgba(255, 255, 255, .18);
    border-color: rgba(255, 255, 255, .35);
}

.lightbox__close {
    top: clamp(.75rem, 2.5vw, 1.5rem);
    right: clamp(.75rem, 2.5vw, 1.5rem);
}
.lightbox__nav--prev {
    top: 50%;
    left: clamp(.5rem, 2vw, 1.5rem);
    transform: translateY(-50%);
}
.lightbox__nav--next {
    top: 50%;
    right: clamp(.5rem, 2vw, 1.5rem);
    transform: translateY(-50%);
}
.lightbox__nav--prev:hover { transform: translateY(-50%) translateX(-2px); }
.lightbox__nav--next:hover { transform: translateY(-50%) translateX(2px); }

@media (max-width: 600px) {
    .lightbox__close,
    .lightbox__nav { width: 40px; height: 40px; }
    .lightbox__nav svg { width: 22px; height: 22px; }
    .lightbox__img { max-height: 68vh; }
    .lightbox__title { font-size: 1rem; }
}

@media (prefers-reduced-motion: reduce) {
    .lightbox,
    .lightbox__figure { transition: none; }
    .lightbox__figure { transform: none; }
}

/* --- Respect du reduced-motion --------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    .reveal,
    .reveal.is-visible {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
    .hero__bg { transform: none !important; }
}

/* --------------------------------------------------------------------------
   Capabilities — vue d'ensemble compacte (remplace .prestations-detail)
   -------------------------------------------------------------------------- */
.capabilities {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
    max-width: 980px;
    margin: 0 auto;
}

.capability-group {
    position: relative;
    display: block;
    padding: 1.75rem 1.75rem 1.5rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: inherit;
    transition: transform var(--t-med), border-color var(--t-med), box-shadow var(--t-med);
}

.capability-group:hover {
    transform: translateY(-3px);
    border-color: rgba(23, 55, 62, .18);
    box-shadow: var(--shadow);
}

.capability-group__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    margin-bottom: 1rem;
    border-radius: 999px;
    background: var(--cream-deep);
    color: var(--canard);
    font-size: 1.4rem !important;
    transition: background var(--t-fast), color var(--t-fast);
}

.capability-group:hover .capability-group__icon {
    background: var(--canard);
    color: #fff;
}

.capability-group__title {
    margin: 0 0 1rem;
    font-family: var(--font-serif);
    font-size: 1.25rem;
    font-weight: 500;
    color: var(--ink);
}

.capability-group__chips {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem .45rem;
    margin-bottom: 1.25rem;
}

.capability-group__chips span {
    display: inline-block;
    padding: .35rem .7rem;
    background: var(--cream);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    font-size: .82rem;
    color: var(--ink-soft);
    line-height: 1.2;
    transition: border-color var(--t-fast), color var(--t-fast), background var(--t-fast);
}

.capability-group:hover .capability-group__chips span {
    border-color: rgba(23, 55, 62, .15);
    color: var(--ink);
}

.capability-group__more {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .85rem;
    font-weight: 500;
    color: var(--canard);
    letter-spacing: .01em;
    transition: gap var(--t-fast);
}

.capability-group:hover .capability-group__more {
    gap: .55rem;
}

@media (max-width: 720px) {
    .capabilities { grid-template-columns: 1fr; }
    .capability-group { padding: 1.4rem; }
}


/* ===== Gallery — reveal par rangée ===== */

@media (prefers-reduced-motion: no-preference) {
    /* On annule le stagger cumulatif global pour la galerie,
       et on stagger par colonne pour un reveal en vague par rangée. */
    .gallery.reveal-stagger > .reveal,
    .gallery.reveal-stagger > .reveal:nth-child(n) {
        transition-delay: 0ms;
    }
    /* 3 colonnes (desktop) */
    .gallery.reveal-stagger > .reveal:nth-child(3n+2) { transition-delay: 90ms; }
    .gallery.reveal-stagger > .reveal:nth-child(3n+3) { transition-delay: 180ms; }

    @media (max-width: 900px) {
        /* 2 colonnes (tablette) */
        .gallery.reveal-stagger > .reveal:nth-child(3n+2),
        .gallery.reveal-stagger > .reveal:nth-child(3n+3) { transition-delay: 0ms; }
        .gallery.reveal-stagger > .reveal:nth-child(2n) { transition-delay: 90ms; }
    }
    @media (max-width: 600px) {
        /* 1 colonne (mobile) — chaque carte arrive séparément */
        .gallery.reveal-stagger > .reveal:nth-child(2n),
        .gallery.reveal-stagger > .reveal:nth-child(3n+2),
        .gallery.reveal-stagger > .reveal:nth-child(3n+3) { transition-delay: 0ms; }
    }
}
