/* global.css — réservé pour styles transversaux futurs et Blog */

/* Fond global crème papier : les surfaces importantes restent blanches. */
:root {
    --alo-page-bg: #f0eadf;
    --alo-page-bg-strong: #ece2d2;
    --alo-warm-border: #ded2c0;
    --alo-surface: #fffefa;
    --alo-surface-clean: #ffffff;
    --alo-ink: #202018;
    --alo-muted-warm: #6f675c;
    --alo-gold: #b77a18;
    --alo-gold-soft: #fff3d6;
    --alo-border-subtle: rgba(120, 92, 58, 0.14);
    --alo-border-medium: rgba(120, 92, 58, 0.22);
    --alo-border-green-soft: rgba(39, 103, 73, 0.14);
    --alo-shadow-xs: 0 1px 2px rgba(45, 37, 28, 0.035);
    --alo-shadow-sm: 0 1px 2px rgba(45, 37, 28, 0.035), 0 10px 24px rgba(45, 37, 28, 0.06);
    --alo-shadow-md: 0 2px 6px rgba(45, 37, 28, 0.045), 0 18px 44px rgba(45, 37, 28, 0.085);
    --alo-shadow-lg: 0 4px 14px rgba(45, 37, 28, 0.055), 0 26px 70px rgba(45, 37, 28, 0.12);
    --alo-shadow-green: 0 10px 24px rgba(39, 103, 73, 0.18);
    --alo-shadow-green-hover: 0 14px 32px rgba(39, 103, 73, 0.23);
}

body,
.site,
.site-content,
.ast-separate-container,
.ast-separate-container .site-content {
    background-color: var(--alo-page-bg) !important;
}

/* ── Typographie Fluide (Magazine Look) ────────────────────────────────── */

/* Titres principaux (clamped entre 32px et 48px) - Uniquement pour les pages ALO */
.alo-archive__title, .alo-single__title {
    font-size: clamp(2rem, 5vw + 1rem, 3rem) !important;
}

/* Corps de texte (clamped entre 16px et 18px) */
.alo-archive, .alo-single, .entry-content p {
    font-size: clamp(1rem, 0.5vw + 0.9rem, 1.125rem);
}

/* ── Harmonisation Blog (Vert Sapin) ─────────────────────────────────────── */

/* Scrollbar Premium */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
::-webkit-scrollbar-track {
    background: var(--alo-page-bg-strong, #ece2d2);
}
::-webkit-scrollbar-thumb {
    background: rgba(39, 103, 73, 0.4);
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(39, 103, 73, 0.8);
}

/* Bouton natif Astra "retour en haut", harmonise avec la DA ALO. */
#ast-scroll-top.ast-scroll-top-icon {
    right: 26px !important;
    bottom: 24px !important;
    width: 38px !important;
    height: 38px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid rgba(255, 254, 250, 0.16) !important;
    border-radius: 10px !important;
    background: var(--alo-primary, #276749) !important;
    color: #ffffff !important;
    box-shadow: 0 12px 28px rgba(39, 103, 73, 0.24), 0 2px 5px rgba(45, 37, 28, 0.08) !important;
    transition: transform 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease !important;
}

#ast-scroll-top.ast-scroll-top-icon:hover,
#ast-scroll-top.ast-scroll-top-icon:focus-visible {
    background: #1f563b !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 16px 34px rgba(39, 103, 73, 0.3), 0 3px 8px rgba(45, 37, 28, 0.1) !important;
}

#ast-scroll-top.ast-scroll-top-icon:focus-visible {
    outline: 3px solid rgba(39, 103, 73, 0.28) !important;
    outline-offset: 3px !important;
}

#ast-scroll-top .ast-icon,
#ast-scroll-top .ast-arrow-svg {
    display: block !important;
    color: currentColor !important;
}

#ast-scroll-top .ast-arrow-svg {
    width: 16px !important;
    height: 14px !important;
    fill: currentColor !important;
}

#ast-scroll-top .ast-arrow-svg path {
    fill: currentColor !important;
}

@media (max-width: 767px) {
    #ast-scroll-top.ast-scroll-top-icon {
        right: 18px !important;
        bottom: 18px !important;
        width: 40px !important;
        height: 40px !important;
        border-radius: 11px !important;
    }
}

/* Correction radicale de la visibilité du texte sur les boutons ALO */
.alo-blog-cta__btn, 
.alo-slider-section__link, 
.alo-final-button,
.alo-filter-hero__btn {
    color: #ffffff !important;
    font-weight: 800 !important;
    text-decoration: none !important;
}

/* On s'assure que le texte reste blanc au survol */
.alo-blog-cta__btn:hover, 
.alo-slider-section__link:hover, 
.alo-final-button:hover,
.alo-filter-hero__btn:hover {
    color: #ffffff !important;
    text-decoration: none !important;
}

/* Liens et catégories - on cible uniquement l'intérieur des articles pour ne pas bloquer le menu theme */
.entry-content a:not(.alo-blog-cta__btn),
.ast-single-post .entry-title a,
.ast-single-post .entry-meta a,
.ast-single-post .cat-links a,
.ast-single-post .read-more a {
    color: var(--alo-primary, #276749);
    text-decoration: none;
    transition: all 0.2s ease;
}

.entry-content a:not(.alo-blog-cta__btn):hover,
.ast-single-post .entry-title a:hover,
.ast-single-post .entry-meta a:hover,
.ast-single-post .cat-links a:hover,
.ast-single-post .read-more a:hover {
    color: var(--alo-hover, #38a169);
    text-decoration: underline;
}

/* Correction contraste bouton proposition */
.alo-form-proposition button[type="submit"] {
    background-color: var(--alo-primary, #276749) !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    border: none !important;
    padding: 15px 30px !important;
    border-radius: 12px !important;
    cursor: pointer !important;
}

/* ── Header Premium & Navigation (Astra Overrides) ────────────────────── */

.site-header {
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    z-index: 1000 !important;
    font-family: var(--alo-font-main, "DM Sans", sans-serif) !important;
}

body.home .site-header {
    position: absolute !important;
    top: 0 !important;
    background: linear-gradient(180deg, rgba(16, 31, 22, 0.34), rgba(16, 31, 22, 0)) !important;
}

body:not(.home) .site-header {
    position: relative !important;
    background: var(--alo-page-bg, #f7f4ee) !important;
    border-bottom: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14)) !important;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.62), 0 12px 30px rgba(45, 37, 28, 0.045) !important;
}

.site-header .ast-main-header-wrap,
.site-header .ast-primary-header-bar,
.site-header .ast-above-header-wrap,
.site-header .ast-above-header-bar,
.site-header .ast-builder-grid-row-container {
    background: transparent !important;
    border: 0 !important;
}

body:not(.home) .site-header .ast-main-header-wrap,
body:not(.home) .site-header .ast-primary-header-bar,
body:not(.home) .site-header .ast-above-header-wrap,
body:not(.home) .site-header .ast-above-header-bar,
body:not(.home) .site-header .ast-builder-grid-row-container {
    background: var(--alo-page-bg, #f7f4ee) !important;
}

.site-header .ast-primary-header-bar,
.site-header .ast-above-header-bar {
    min-height: 74px !important;
    transition: background 0.25s ease, box-shadow 0.25s ease, min-height 0.25s ease !important;
}

.site-header .site-primary-header-wrap,
.site-header .ast-above-header-bar > .ast-builder-grid-row {
    max-width: 1240px !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
}

#ast-desktop-header .ast-builder-grid-row {
    min-height: 74px !important;
    grid-template-columns: minmax(240px, 1fr) auto minmax(160px, 1fr) !important;
    align-items: center !important;
}

body.home #ast-desktop-header .ast-builder-grid-row {
    grid-template-columns: minmax(24px, 1fr) auto minmax(24px, 1fr) !important;
}

#ast-desktop-header .site-header-primary-section-left,
#ast-desktop-header .site-header-primary-section-center,
#ast-desktop-header .site-header-primary-section-right {
    min-height: 74px !important;
}

.site-header .site-branding.ast-site-identity {
    min-width: 0 !important;
}

body.home #ast-desktop-header .site-branding.ast-site-identity {
    display: none !important;
}

.site-header .site-branding.ast-site-identity.alo-site-brand-mounted,
.site-header .ast-builder-layout-element[data-section="title_tagline"] {
    width: auto !important;
}

.site-header .alo-site-brand {
    display: inline-flex !important;
    align-items: center !important;
    border-radius: 999px !important;
    text-decoration: none !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
}

.site-header .alo-site-brand:hover {
    transform: translateY(-1px);
}

.site-header .alo-site-brand img {
    display: block !important;
    width: clamp(190px, 17vw, 236px) !important;
    max-width: 100% !important;
    height: auto !important;
}

body.home #ast-desktop-header .alo-site-brand {
    display: none !important;
}

body:not(.home) .site-header .alo-site-brand {
    padding: 4px 0 !important;
}

#ast-desktop-header .main-header-menu {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 4px !important;
    padding: 6px !important;
    border-radius: 999px !important;
    width: max-content !important;
    max-width: calc(100vw - 360px) !important;
}

body.home #ast-desktop-header .main-header-menu {
    background: rgba(16, 31, 22, 0.46) !important;
    border: 1px solid rgba(255, 255, 255, 0.24) !important;
    box-shadow: 0 16px 42px rgba(0, 0, 0, 0.16) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
}

body:not(.home) #ast-desktop-header .main-header-menu {
    background: #ffffff !important;
    border: 1px solid var(--alo-border-green-soft, rgba(39, 103, 73, 0.14)) !important;
    box-shadow: var(--alo-shadow-sm, 0 1px 2px rgba(45, 37, 28, 0.035), 0 10px 24px rgba(45, 37, 28, 0.06)) !important;
}

.site-header .main-header-menu > .menu-item > .menu-link {
    display: inline-flex !important;
    align-items: center !important;
    white-space: nowrap !important;
    min-height: auto !important;
    height: auto !important;
    padding: 10px 12px !important;
    border-radius: 999px !important;
    color: #24362d !important;
    font-family: var(--alo-font-main, "DM Sans", sans-serif) !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    line-height: 1.15 !important;
    letter-spacing: 0 !important;
    text-decoration: none !important;
    background: transparent !important;
    box-shadow: none !important;
    transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease !important;
}

body.home .site-header .main-header-menu > .menu-item > .menu-link {
    color: #ffffff !important;
    text-shadow: none !important;
}

body:not(.home) .site-header .main-header-menu > .menu-item > .menu-link {
    color: #24362d !important;
    text-shadow: none !important;
}

.site-header .main-header-menu > .menu-item:hover > .menu-link,
.site-header .main-header-menu > .menu-item > .menu-link:focus-visible {
    outline: 2px solid transparent !important;
    outline-offset: 2px !important;
    box-shadow: none !important;
}

body.home .site-header .main-header-menu > .menu-item:hover > .menu-link,
body.home .site-header .main-header-menu > .menu-item > .menu-link:focus-visible,
body.home .site-header .main-header-menu > .current-menu-item > .menu-link,
body.home .site-header .main-header-menu > .current_page_item > .menu-link {
    color: var(--alo-primary, #276749) !important;
    background: rgba(245, 243, 239, 0.94) !important;
}

body:not(.home) .site-header .main-header-menu > .menu-item:hover > .menu-link,
body:not(.home) .site-header .main-header-menu > .menu-item > .menu-link:focus-visible,
body:not(.home) .site-header .main-header-menu > .current-menu-item > .menu-link,
body:not(.home) .site-header .main-header-menu > .current_page_item > .menu-link {
    color: var(--alo-primary, #276749) !important;
    background: rgba(39, 103, 73, 0.08) !important;
}

.site-header .main-header-menu > .menu-item > .menu-link:focus-visible {
    outline-color: rgba(39, 103, 73, 0.42) !important;
}

body.home .site-header .main-header-menu > .menu-item > .menu-link:focus-visible {
    outline-color: rgba(255, 255, 255, 0.76) !important;
}

.main-navigation .current-menu-item > a::after,
.main-navigation .current_page_item > a::after {
    display: none !important;
}

@media (min-width: 922px) {
    body:not(.home) .site-header,
    body:not(.home) #ast-desktop-header,
    body:not(.home) .site-header .ast-main-header-wrap,
    body:not(.home) .site-header .ast-primary-header-bar,
    body:not(.home) .site-header .ast-above-header-wrap,
    body:not(.home) .site-header .ast-above-header-bar,
    body:not(.home) .site-header .ast-builder-grid-row-container,
    body:not(.home) .site-header .ast-builder-grid-row-container-inner {
        min-height: auto !important;
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }

    body:not(.home) .site-header .ast-primary-header-bar,
    body:not(.home) .site-header .ast-above-header-bar,
    body:not(.home) #ast-desktop-header .ast-builder-grid-row,
    body:not(.home) #ast-desktop-header .site-header-primary-section-left,
    body:not(.home) #ast-desktop-header .site-header-primary-section-center,
    body:not(.home) #ast-desktop-header .site-header-primary-section-right {
        min-height: 112px !important;
    }

    body:not(.home) .site-header .site-primary-header-wrap,
    body:not(.home) .site-header .ast-above-header-bar > .ast-builder-grid-row {
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }
}

.site-header .main-header-menu,
.site-header .main-header-menu > .menu-item,
.site-header .main-header-menu > .menu-item > .menu-link {
    position: relative !important;
    z-index: 2 !important;
    pointer-events: auto !important;
}

.site-header .main-header-menu > .menu-item {
    flex: 0 0 auto !important;
}

@media (max-width: 921px) {
    html {
        scroll-padding-top: 76px;
    }

    .site-header {
        position: relative !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        overflow: visible !important;
        transform: none !important;
    }

    body.home .site-header {
        position: absolute !important;
        top: 0 !important;
        background: linear-gradient(180deg, rgba(16, 31, 22, 0.36), rgba(16, 31, 22, 0)) !important;
    }

    body:not(.home) .site-header {
        position: relative !important;
        top: 0 !important;
        background: var(--alo-page-bg, #f7f4ee) !important;
        border-bottom: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14)) !important;
        box-shadow: 0 1px 0 rgba(255, 255, 255, 0.62), 0 10px 24px rgba(45, 37, 28, 0.045) !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    body:not(.home) #content,
    body:not(.home) .site-content {
        padding-top: 0 !important;
    }

    body.admin-bar .site-header {
        top: 0 !important;
    }

    body.admin-bar:not(.home) #content,
    body.admin-bar:not(.home) .site-content {
        padding-top: 0 !important;
    }

    body.admin-bar:not(.home) .site-header {
        top: 0 !important;
    }

    body:not(.home) #ast-mobile-header .ast-above-header-wrap,
    body:not(.home) #ast-mobile-header .ast-above-header-bar,
    body:not(.home) #ast-mobile-header .ast-builder-grid-row-container {
        background: rgba(247, 244, 238, 0.92) !important;
    }

    #ast-mobile-header .ast-above-header-wrap,
    #ast-mobile-header .ast-above-header-bar {
        min-height: 72px !important;
    }

    #ast-mobile-header .ast-above-header-bar > .ast-builder-grid-row {
        position: relative !important;
        width: 100% !important;
        max-width: none !important;
        min-height: 72px !important;
        padding: 0 18px !important;
        grid-template-columns: 52px minmax(0, 1fr) 52px !important;
        align-items: center !important;
    }

    #ast-mobile-header .site-header-above-section-left,
    #ast-mobile-header .site-header-above-section-center,
    #ast-mobile-header .site-header-above-section-right {
        width: auto !important;
        min-height: 72px !important;
    }

    #ast-mobile-header .site-header-above-section-left {
        grid-column: 1 !important;
        justify-content: flex-start !important;
    }

    #ast-mobile-header .site-header-above-section-center {
        position: absolute !important;
        top: 0 !important;
        left: 50% !important;
        right: auto !important;
        transform: translateX(-50%) !important;
        width: auto !important;
        max-width: calc(100vw - 132px) !important;
        min-width: 0 !important;
        pointer-events: none !important;
        grid-column: auto !important;
        justify-content: center !important;
    }

    #ast-mobile-header .site-header-above-section-right {
        grid-column: 3 !important;
    }

    #ast-mobile-header .site-branding.ast-site-identity {
        width: auto !important;
    }

    #ast-mobile-header .site-branding.ast-site-identity.alo-site-brand-mounted {
        position: absolute !important;
        top: 50% !important;
        left: 50% !important;
        z-index: 4 !important;
        display: block !important;
        width: min(194px, calc(100vw - 132px)) !important;
        max-width: calc(100vw - 132px) !important;
        min-width: 0 !important;
        transform: translate(-50%, -50%) !important;
        pointer-events: none !important;
    }

    body.home #ast-mobile-header .site-branding.ast-site-identity,
    body.home #ast-mobile-header .site-header-above-section-center {
        display: none !important;
    }

    #ast-mobile-header .alo-site-brand {
        padding: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        width: 100% !important;
        justify-content: center !important;
        pointer-events: auto !important;
    }

    #ast-mobile-header .alo-site-brand img {
        width: 100% !important;
    }

    body.home #ast-mobile-header .alo-site-brand {
        display: none !important;
    }

    #ast-mobile-header .menu-toggle {
        position: relative !important;
        visibility: hidden !important;
        pointer-events: none !important;
        width: 46px !important;
        height: 46px !important;
        min-width: 46px !important;
        padding: 0 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-sizing: border-box !important;
        border-radius: 999px !important;
        border: 1px solid rgba(39, 103, 73, 0.22) !important;
        color: #ffffff !important;
        background: var(--alo-primary, #276749) !important;
        line-height: 1 !important;
        overflow: hidden !important;
        box-shadow: 0 12px 28px rgba(39, 103, 73, 0.18) !important;
    }

    body.home #ast-mobile-header .menu-toggle {
        color: #ffffff !important;
        background: rgba(16, 31, 22, 0.48) !important;
        border-color: rgba(255, 255, 255, 0.30) !important;
        box-shadow: 0 12px 28px rgba(0, 0, 0, 0.15) !important;
        backdrop-filter: blur(14px) !important;
        -webkit-backdrop-filter: blur(14px) !important;
    }

    #ast-mobile-header .menu-toggle .ast-mobile-svg {
        display: block !important;
        width: 22px !important;
        height: 22px !important;
        margin: 0 !important;
        position: absolute !important;
        top: 50% !important;
        left: 50% !important;
        transform: translate(-50%, -50%) !important;
        color: currentColor !important;
        fill: currentColor !important;
        stroke: currentColor !important;
    }

    #ast-mobile-header .menu-toggle .ast-mobile-svg path,
    #ast-mobile-header .menu-toggle svg path {
        fill: currentColor !important;
        stroke: currentColor !important;
    }

    #ast-mobile-header .menu-toggle .ast-mobile-svg.ast-close-svg {
        display: none !important;
    }

    #ast-mobile-header .menu-toggle.toggled .ast-mobile-svg.ast-menu-svg,
    #ast-mobile-header .menu-toggle[aria-expanded="true"] .ast-mobile-svg.ast-menu-svg {
        display: none !important;
    }

    #ast-mobile-header .menu-toggle.toggled .ast-mobile-svg.ast-close-svg,
    #ast-mobile-header .menu-toggle[aria-expanded="true"] .ast-mobile-svg.ast-close-svg {
        display: block !important;
    }

    #ast-mobile-header .menu-toggle .mobile-menu-toggle-icon,
    #ast-mobile-header .menu-toggle .ahfb-svg-iconset {
        position: absolute !important;
        inset: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        height: 100% !important;
        margin: 0 !important;
        line-height: 1 !important;
    }

    #ast-mobile-header .ast-button-wrap {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        height: 100% !important;
        margin: 0 !important;
        line-height: 1 !important;
    }

    #ast-mobile-header .ast-mobile-header-content {
        position: fixed !important;
        left: 16px !important;
        right: 16px !important;
        top: 78px !important;
        z-index: 1001 !important;
        width: auto !important;
        height: auto !important;
        padding: 8px !important;
        border: 1px solid var(--alo-border-green-soft, rgba(39, 103, 73, 0.14)) !important;
        border-radius: 18px !important;
        background: #fffefa !important;
        box-shadow: var(--alo-shadow-lg, 0 4px 14px rgba(45, 37, 28, 0.055), 0 26px 70px rgba(45, 37, 28, 0.12)) !important;
        overflow: hidden !important;
        backdrop-filter: blur(14px) !important;
        -webkit-backdrop-filter: blur(14px) !important;
    }

    body.admin-bar #ast-mobile-header .ast-mobile-header-content {
        top: 124px !important;
    }

    #ast-mobile-header .main-header-menu {
        display: flex !important;
        flex-direction: column !important;
        gap: 4px !important;
        background: transparent !important;
        border: 0 !important;
    }

    #ast-mobile-header .main-header-menu > .menu-item > .menu-link {
        min-height: auto !important;
        padding: 14px 16px !important;
        border: 0 !important;
        border-radius: 14px !important;
        color: #26372f !important;
        background: transparent !important;
        font-family: var(--alo-font-main, "DM Sans", sans-serif) !important;
        font-size: 16px !important;
        font-weight: 800 !important;
        line-height: 1.2 !important;
    }

    #ast-mobile-header .main-header-menu > .current-menu-item > .menu-link,
    #ast-mobile-header .main-header-menu > .current_page_item > .menu-link,
    #ast-mobile-header .main-header-menu > .menu-item > .menu-link:hover,
    #ast-mobile-header .main-header-menu > .menu-item > .menu-link:focus-visible {
        color: var(--alo-primary, #276749) !important;
        background: rgba(39, 103, 73, 0.1) !important;
    }

    .alo-floating-menu-toggle {
        position: fixed !important;
        top: 18px !important;
        left: 18px !important;
        z-index: 1003 !important;
        width: 46px !important;
        height: 46px !important;
        padding: 0 !important;
        display: inline-flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 5px !important;
        box-sizing: border-box !important;
        border-radius: 999px !important;
        border: 1px solid rgba(39, 103, 73, 0.22) !important;
        color: #ffffff !important;
        background: var(--alo-primary, #276749) !important;
        box-shadow: 0 12px 28px rgba(39, 103, 73, 0.22) !important;
        cursor: pointer !important;
    }

    body.admin-bar .alo-floating-menu-toggle {
        top: 64px !important;
    }

    body.home .alo-floating-menu-toggle {
        background: rgba(16, 31, 22, 0.48) !important;
        border-color: rgba(255, 255, 255, 0.30) !important;
        box-shadow: 0 12px 28px rgba(0, 0, 0, 0.15) !important;
        backdrop-filter: blur(14px) !important;
        -webkit-backdrop-filter: blur(14px) !important;
    }

    .alo-floating-menu-toggle span {
        display: block !important;
        width: 21px !important;
        height: 3px !important;
        border-radius: 999px !important;
        background: currentColor !important;
        transition: transform 0.2s ease, opacity 0.2s ease !important;
    }

    .alo-floating-menu-toggle.is-open span:nth-child(1) {
        transform: translateY(8px) rotate(45deg) !important;
    }

    .alo-floating-menu-toggle.is-open span:nth-child(2) {
        opacity: 0 !important;
    }

    .alo-floating-menu-toggle.is-open span:nth-child(3) {
        transform: translateY(-8px) rotate(-45deg) !important;
    }

    .alo-floating-menu-toggle:focus-visible {
        outline: 3px solid rgba(39, 103, 73, 0.35) !important;
        outline-offset: 3px !important;
    }
}

@media (min-width: 922px) {
    .alo-floating-menu-toggle {
        display: none !important;
    }
}

/* Hero page d'accueil */
body.home .uagb-block-5b7dce53 {
    position: relative !important;
    isolation: isolate;
    display: flex !important;
    align-items: center !important;
    max-width: none !important;
    min-height: clamp(520px, 62vh, 680px) !important;
    padding: 0 !important;
    overflow: hidden !important;
    background-color: rgba(15, 31, 22, 0.28) !important;
    background-blend-mode: multiply !important;
}

html.alo-city-combobox-is-open body.home .uagb-block-5b7dce53,
html.alo-filter-menu-is-open body.home .uagb-block-5b7dce53 {
    z-index: 50;
    overflow: visible !important;
}

body.home .uagb-block-5b7dce53::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 50% 18%, rgba(255, 243, 214, 0.16), rgba(255, 243, 214, 0) 34%),
        linear-gradient(180deg, rgba(12, 27, 18, 0.58) 0%, rgba(12, 27, 18, 0.36) 42%, rgba(12, 27, 18, 0.52) 100%);
}

body.home .uagb-block-5b7dce53 > .uagb-container-inner-blocks-wrap {
    position: relative;
    z-index: 1;
    width: min(1120px, calc(100% - 40px)) !important;
    margin-right: auto !important;
    margin-left: auto !important;
}

body.home .uagb-block-ffcad06e {
    width: 100% !important;
    min-height: clamp(520px, 62vh, 680px) !important;
    padding: clamp(112px, 14vh, 148px) 0 clamp(70px, 9vh, 98px) !important;
    gap: clamp(20px, 3vw, 30px) !important;
    align-items: center !important;
    justify-content: center !important;
}

body.home .uagb-block-44f701dc {
    max-width: 880px !important;
    padding: 0 !important;
    text-align: center !important;
}

body.home .uagb-block-44f701dc .uagb-heading-text {
    max-width: 780px;
    margin: 0 auto !important;
    color: #fff8e8 !important;
    font-family: "Fraunces", "DM Sans", Georgia, serif !important;
    font-size: 40px !important;
    font-weight: 850 !important;
    line-height: 0.96 !important;
    letter-spacing: 0 !important;
    text-wrap: balance;
    text-shadow: 0 18px 46px rgba(0, 0, 0, 0.38), 0 1px 0 rgba(255, 255, 255, 0.1) !important;
}

body.home .uagb-block-44f701dc .uagb-desc-text {
    max-width: 650px !important;
    margin: 16px auto 0 !important;
    color: rgba(255, 248, 232, 0.94) !important;
    font-family: var(--alo-font-main, "DM Sans", sans-serif) !important;
    font-size: 15.5px !important;
    font-weight: 760 !important;
    line-height: 1.42 !important;
    letter-spacing: 0 !important;
    text-wrap: balance;
    text-shadow: 0 12px 32px rgba(0, 0, 0, 0.34) !important;
}

body.home .uagb-block-44f701dc .uagb-heading-text strong,
body.home .uagb-block-44f701dc .uagb-desc-text strong {
    color: inherit !important;
    font: inherit !important;
}

body.home .uagb-block-44f701dc .uagb-heading-text::after {
    content: "";
    display: block;
    width: 62px;
    height: 2px;
    margin: 15px auto 0;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(183, 122, 24, 0), rgba(245, 217, 159, 0.96), rgba(183, 122, 24, 0));
    box-shadow: 0 6px 18px rgba(245, 217, 159, 0.24);
}

.alo-home-seo-intro {
    width: min(960px, calc(100% - 32px));
    margin: clamp(10px, 2vw, 18px) auto clamp(54px, 7vw, 82px);
    padding-top: clamp(22px, 4vw, 34px);
    border-top: 1px solid rgba(120, 92, 58, 0.14);
    color: #2f2a24;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
}

.alo-home-seo-intro__inner {
    display: block;
}

.alo-home-seo-intro__eyebrow {
    margin: 0 0 10px;
    color: #8b693c;
    font-size: 11.5px;
    font-weight: 950;
    letter-spacing: 0;
    text-transform: uppercase;
}

.alo-home-seo-intro h2,
.alo-home-seo-intro h3 {
    margin: 0;
    color: #1f5139;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-weight: 950;
    letter-spacing: 0;
}

.alo-home-seo-intro h2 {
    max-width: 700px;
    font-size: 24px;
    line-height: 1.15;
}

.alo-home-seo-intro h3 {
    margin-top: 20px;
    font-size: 18px;
    line-height: 1.2;
}

.alo-home-seo-intro p {
    max-width: 720px;
    margin: 12px 0 0;
    color: #5d554b;
    font-size: 14.5px;
    font-weight: 540;
    line-height: 1.64;
    letter-spacing: 0;
}

.alo-home-seo-intro a {
    color: #276749;
    font-weight: 850;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.18em;
}

.alo-home-seo-intro a:hover,
.alo-home-seo-intro a:focus-visible {
    color: #1f5139;
}

.alo-home-seo-intro__figure {
    margin: 16px 0 0;
}

.alo-home-seo-intro__figure img {
    display: block;
    width: 118px;
    height: auto;
    margin: 0;
    border-radius: 7px;
    opacity: 0.58;
    box-shadow: none;
}

.alo-home-events-invite {
    width: min(1120px, calc(100% - 32px));
    margin: clamp(16px, 3vw, 34px) auto clamp(18px, 3vw, 30px);
    padding: 0;
    text-align: center;
}

.alo-home-events-invite__text {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 8px 12px;
    margin: 0;
    padding: 11px 18px;
    border-top: 1px solid rgba(120, 92, 58, 0.16);
    border-bottom: 1px solid rgba(120, 92, 58, 0.12);
    color: #6f675c;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 14.5px;
    font-weight: 760;
    line-height: 1.35;
    letter-spacing: 0;
}

.alo-home-events-invite__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 38px;
    padding: 0 17px;
    border-radius: 999px;
    background: #276749;
    box-shadow: 0 10px 24px rgba(39, 103, 73, 0.16);
    color: #ffffff !important;
    font-weight: 950;
    text-decoration: none !important;
    white-space: nowrap;
    transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.alo-home-events-invite__link:hover,
.alo-home-events-invite__link:focus-visible {
    background: #2f7a57;
    box-shadow: 0 14px 30px rgba(39, 103, 73, 0.22);
    color: #ffffff !important;
    text-decoration: none !important;
    transform: translateY(-1px);
}

.alo-home-events-invite__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    flex: 0 0 auto;
}

.alo-home-events-invite__icon svg {
    width: 15px;
    height: 15px;
}

@media (max-width: 767px) {
    body.home .uagb-block-5b7dce53 {
        min-height: auto !important;
        background-color: rgba(15, 31, 22, 0.34) !important;
    }

    body.home .uagb-block-5b7dce53 > .uagb-container-inner-blocks-wrap {
        width: min(100% - 24px, 460px) !important;
    }

    body.home .uagb-block-ffcad06e {
        min-height: auto !important;
        padding: 96px 0 36px !important;
        gap: 18px !important;
    }

    body.home .uagb-block-44f701dc {
        max-width: 350px !important;
    }

    body.home .uagb-block-44f701dc .uagb-heading-text {
        font-size: 40px !important;
        line-height: 0.96 !important;
    }

    body.home .uagb-block-44f701dc .uagb-desc-text {
        max-width: 335px !important;
        font-size: 15.5px !important;
        line-height: 1.42 !important;
    }

    .alo-home-events-invite {
        width: min(100% - 24px, 460px);
        margin: 18px auto 24px;
    }

    .alo-home-seo-intro {
        width: min(100% - 24px, 460px);
        margin: 12px auto 54px;
        padding-top: 24px;
    }

    .alo-home-seo-intro__inner {
        display: block;
    }

    .alo-home-seo-intro h2 {
        font-size: 22px;
        line-height: 1.15;
    }

    .alo-home-seo-intro p {
        font-size: 14px;
        line-height: 1.6;
    }

    .alo-home-seo-intro__figure img {
        width: 108px;
        margin: 0;
    }

    .alo-home-events-invite__text {
        width: 100%;
        padding: 12px 10px;
        font-size: 14px;
    }

    .alo-home-events-invite__link {
        gap: 6px;
        min-height: 40px;
        padding: 0 16px;
    }
}

@media (min-width: 768px) {
    body.home .uagb-block-44f701dc .uagb-heading-text {
        font-size: 58px !important;
        line-height: 0.94 !important;
    }

    body.home .uagb-block-44f701dc .uagb-heading-text::after {
        width: 74px;
        margin-top: 18px;
    }

    body.home .uagb-block-44f701dc .uagb-desc-text {
        margin-top: 18px !important;
        font-size: 17px !important;
        line-height: 1.38 !important;
    }
}

@media (min-width: 1200px) {
    body.home .uagb-block-44f701dc .uagb-heading-text {
        font-size: 72px !important;
    }

    body.home .uagb-block-44f701dc .uagb-desc-text {
        font-size: 18px !important;
    }
}

/* Brand assets - integration finale */
.site-header .alo-site-brand img {
    width: clamp(204px, 17vw, 232px) !important;
}

body.home #ast-desktop-header .alo-site-brand {
    display: none !important;
}

body:not(.home) .site-header .alo-site-brand {
    padding: 4px 0 !important;
}

.alo-brand-footer {
    position: relative;
    z-index: 1;
    margin-top: 52px;
    padding: 0;
    background:
        radial-gradient(circle at 12% 10%, rgba(229, 184, 92, 0.18), transparent 28%),
        linear-gradient(135deg, #173f2d 0%, #276749 52%, #1d4d37 100%);
    color: #fffefa;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    overflow: hidden;
}

#colophon.site-footer {
    display: none !important;
}

.alo-brand-footer::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 34%),
        radial-gradient(circle at 86% 18%, rgba(255, 243, 214, 0.16), transparent 27%);
}

.alo-brand-footer__inner {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(360px, 0.88fr);
    gap: clamp(34px, 6vw, 78px);
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
    padding: clamp(42px, 6vw, 74px) 0 32px;
}

.alo-brand-footer__main {
    max-width: 590px;
}

.alo-brand-footer__brand {
    display: flex;
    align-items: center;
    gap: 14px;
    width: fit-content;
    color: #ffffff !important;
    text-decoration: none !important;
}

.alo-brand-footer__mark {
    display: block;
    width: 54px;
    height: 54px;
    flex: 0 0 54px;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    filter: drop-shadow(0 12px 18px rgba(0, 0, 0, 0.18));
}

.alo-brand-footer__name {
    color: #ffffff;
    font-size: clamp(24px, 2.2vw, 34px);
    font-weight: 950;
    line-height: 1.04;
    letter-spacing: 0;
}

.alo-brand-footer__text {
    max-width: 540px;
    margin: 20px 0 0;
    color: rgba(255, 254, 250, 0.84);
    font-size: clamp(16px, 1vw, 18px);
    font-weight: 650;
    line-height: 1.62;
}

.alo-brand-footer__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 26px;
}

.alo-brand-footer__button {
    display: inline-flex;
    min-height: 46px;
    align-items: center;
    justify-content: center;
    padding: 12px 20px;
    border: 1px solid rgba(255, 243, 214, 0.72);
    border-radius: 999px;
    background: rgba(255, 243, 214, 0.1);
    color: #fff3d6 !important;
    font-size: 14px;
    font-weight: 900;
    line-height: 1.15;
    text-decoration: none !important;
    box-shadow: inset 0 1px 0 rgba(255, 254, 250, 0.1);
    transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.alo-brand-footer__button--primary {
    border-color: #fff3d6;
    background: #fff3d6;
    color: #17402d !important;
    box-shadow: 0 12px 28px rgba(8, 24, 16, 0.14);
}

.alo-brand-footer__button:hover,
.alo-brand-footer__button:focus-visible {
    border-color: #f5d99f;
    background: #f5d99f;
    color: #17402d !important;
    transform: translateY(-1px);
    box-shadow: 0 16px 34px rgba(8, 24, 16, 0.18);
}

.alo-brand-footer__nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
    align-self: start;
}

.alo-brand-footer__group {
    min-width: 0;
    padding: 22px;
    border: 1px solid rgba(255, 254, 250, 0.14);
    border-radius: 8px;
    background: rgba(255, 254, 250, 0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.alo-brand-footer__group h2 {
    margin: 0 0 14px;
    color: #fff3d6;
    font-size: 13px;
    font-weight: 950;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.alo-brand-footer__group ul {
    display: grid;
    gap: 9px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.alo-brand-footer__group a {
    display: inline-flex;
    color: rgba(255, 254, 250, 0.86) !important;
    font-size: 15px;
    font-weight: 750;
    line-height: 1.28;
    text-decoration: none !important;
}

.alo-brand-footer__group a:hover,
.alo-brand-footer__group a:focus-visible {
    color: #ffffff !important;
    text-decoration: underline !important;
    text-underline-offset: 4px;
}

.alo-brand-footer__bottom {
    position: relative;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
    padding: 18px 0 22px;
    border-top: 1px solid rgba(255, 254, 250, 0.16);
    color: rgba(255, 254, 250, 0.68);
    font-size: 13px;
    font-weight: 700;
}

body.home .alo-brand-footer__bottom {
    padding-bottom: 76px;
}

.alo-brand-footer__bottom p {
    margin: 0;
}

.alo-brand-footer__bottom-note {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    flex-wrap: wrap;
    padding-right: 54px;
}

.alo-brand-footer__social-link {
    display: inline-flex;
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 254, 250, 0.24);
    border-radius: 999px;
    background: rgba(255, 254, 250, 0.08);
    color: rgba(255, 254, 250, 0.78) !important;
    text-decoration: none !important;
    box-shadow: inset 0 1px 0 rgba(255, 254, 250, 0.08);
    transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
}

.alo-brand-footer__social-link svg {
    display: block;
    width: 21px;
    height: 21px;
    fill: currentColor;
    transform: translateX(-1px);
}

.alo-brand-footer__social-link:hover,
.alo-brand-footer__social-link:focus-visible {
    border-color: #fff3d6;
    background: #fff3d6;
    color: #17402d !important;
    transform: translateY(-1px);
}

@media (max-width: 921px) {
    #ast-mobile-header .site-branding.ast-site-identity.alo-site-brand-mounted {
        width: min(176px, calc(100vw - 132px)) !important;
    }

    #ast-mobile-header .alo-site-brand img {
        width: 100% !important;
    }

    body.home #ast-mobile-header .alo-site-brand {
        display: none !important;
    }

    .alo-brand-footer {
        margin-top: 38px;
    }

    .alo-brand-footer__inner {
        grid-template-columns: 1fr;
        padding-top: 44px;
    }

    .alo-brand-footer__main {
        max-width: 680px;
    }
}

@media (max-width: 640px) {
    .alo-brand-footer {
        margin-top: 30px;
    }

    .alo-brand-footer__inner {
        width: calc(100% - 32px);
        gap: 26px;
        padding: 90px 0 24px;
    }

    .alo-brand-footer__brand {
        align-items: flex-start;
    }

    .alo-brand-footer__mark {
        width: 48px;
        height: 48px;
        flex-basis: 48px;
        border-radius: 14px;
    }

    .alo-brand-footer__actions {
        flex-direction: column;
    }

    .alo-brand-footer__button {
        width: 100%;
    }

    .alo-brand-footer__nav {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .alo-brand-footer__group {
        padding: 18px;
    }

    .alo-brand-footer__bottom {
        align-items: flex-start;
        flex-direction: column;
        width: calc(100% - 32px);
        gap: 6px;
        padding-bottom: 24px;
        font-size: 14px;
    }

    .alo-brand-footer__bottom-note {
        justify-content: flex-start;
        padding-right: 0;
    }
}

/* ── Accessibilité : Focus visible... (rest of the file) */
.alo-card:focus-visible,
.alo-filter-hero__input:focus-visible,
.alo-filter-hero__btn:focus-visible,
.alo-slider-section__link:focus-visible {
    outline: 3px solid var(--alo-primary, #276749) !important;
    outline-offset: 3px !important;
    box-shadow: none !important;
}

html {
    scroll-behavior: smooth;
}

/* ==========================================================================
   Pages editoriales : Proposer un evenement, Blog, Contact
   ========================================================================== */

body.alo-page-editorial,
body.alo-page-editorial .site-content,
body.alo-page-editorial .ast-container {
    background: var(--alo-page-bg, #f7f4ee);
}

body.alo-page-editorial .ast-container {
    display: block;
    width: min(100%, 1180px);
    max-width: 1180px;
    padding: clamp(26px, 3.2vw, 42px) 20px clamp(64px, 8vw, 104px);
}

body.alo-page-propose .ast-container {
    max-width: 980px;
}

body.alo-page-contact .ast-container {
    max-width: 1080px;
}

body.alo-page-blog .ast-container {
    max-width: 1180px;
}

body.alo-page-editorial .entry-content {
    width: 100%;
    margin: 0 auto;
    color: var(--alo-ink, #202018);
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
}

body.alo-page-editorial .entry-content > h1:empty,
body.alo-page-editorial .entry-content > h2:empty,
body.alo-page-editorial .entry-content > p:empty {
    display: none !important;
}

body.alo-page-editorial .entry-content > h1:first-child,
body.alo-page-editorial .entry-title,
body.alo-page-editorial .entry-content .alo-page-title {
    max-width: 880px;
    margin: 0 auto 14px;
    color: var(--alo-ink, #202018);
    font-family: var(--alo-font-heading, "DM Sans", sans-serif);
    font-size: clamp(2.35rem, 4vw, 4rem);
    font-weight: 950;
    line-height: 0.98;
    letter-spacing: 0;
    text-align: center;
}

body.alo-page-propose .entry-content > h1:first-child,
body.alo-page-propose .entry-title,
body.alo-page-contact .entry-content > h1:first-child,
body.alo-page-contact .entry-title {
    color: var(--alo-primary, #276749);
}

body.alo-page-editorial .entry-content > h1:first-child::after,
body.alo-page-editorial .entry-title::after,
body.alo-page-editorial .entry-content .alo-page-title::after {
    content: "";
    display: block;
    width: 74px;
    height: 3px;
    margin: 18px auto 0;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--alo-primary, #276749), var(--alo-gold, #b77a18));
}

body.alo-page-editorial .entry-content > p:first-of-type,
body.alo-page-editorial .entry-content .alo-page-lead {
    max-width: 680px;
    margin: 0 auto clamp(26px, 4vw, 42px);
    color: var(--alo-muted-warm, #6f675c);
    font-size: clamp(1.02rem, 0.8vw + 0.9rem, 1.2rem);
    font-weight: 500;
    line-height: 1.7;
    text-align: center;
}

body.alo-page-editorial .entry-content > *:last-child {
    margin-bottom: 0;
}

/* Formulaire de proposition */
.alo-form-feedback {
    width: min(100%, 780px);
    margin: 0 auto 22px;
    padding: 16px 18px;
    border-radius: 16px;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 15px;
    font-weight: 700;
    line-height: 1.45;
}

.alo-form-success {
    color: #185c36;
    background: #ecf8ef;
    border: 1px solid #b9dfc4;
}

.alo-form-error {
    color: #8f2424;
    background: #fff0ee;
    border: 1px solid #efc1ba;
}

.alo-duplicate-confirmation {
    width: min(100%, 780px);
    margin: clamp(24px, 4vw, 38px) auto 0;
    padding: clamp(20px, 4vw, 30px);
    border: 1px solid rgba(120, 92, 58, 0.16);
    border-radius: 22px;
    outline: none;
    background:
        linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(255, 255, 255, 0.98)),
        #ffffff;
    box-shadow: var(--alo-shadow-md, 0 2px 6px rgba(45, 37, 28, 0.045), 0 18px 44px rgba(45, 37, 28, 0.085));
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
}

.alo-duplicate-confirmation:focus-visible {
    box-shadow:
        0 0 0 4px rgba(39, 103, 73, 0.14),
        var(--alo-shadow-md, 0 2px 6px rgba(45, 37, 28, 0.045), 0 18px 44px rgba(45, 37, 28, 0.085));
}

.alo-duplicate-confirmation[hidden] {
    display: none;
}

.alo-duplicate-confirmation__head {
    margin-bottom: 18px;
}

.alo-duplicate-confirmation__eyebrow {
    margin: 0 0 7px;
    color: #7c5b16;
    font-size: 12px;
    font-weight: 900;
    line-height: 1.2;
    text-transform: uppercase;
}

.alo-duplicate-confirmation h2 {
    margin: 0 0 8px;
    color: var(--alo-primary, #276749);
    font-size: clamp(20px, 3vw, 26px);
    font-weight: 950;
    line-height: 1.15;
}

.alo-duplicate-confirmation p {
    margin: 0;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 15px;
    font-weight: 650;
    line-height: 1.5;
}

.alo-duplicate-confirmation__grid {
    display: grid;
    gap: 12px;
}

.alo-duplicate-card {
    display: grid;
    grid-template-columns: 112px minmax(0, 1fr);
    gap: 14px;
    padding: 12px;
    border: 1px solid rgba(120, 92, 58, 0.14);
    border-radius: 16px;
    background: #fffefa;
}

.alo-duplicate-card__media {
    display: block;
    width: 112px;
    aspect-ratio: 1 / 1;
    border-radius: 13px;
    overflow: hidden;
    background: #f5f3ef;
}

.alo-duplicate-card__media .alo-card__image,
.alo-duplicate-card__media .alo-card__image--placeholder {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.alo-duplicate-card__body {
    display: grid;
    align-content: start;
    gap: 9px;
    min-width: 0;
}

.alo-duplicate-card__title {
    margin: 0;
    font-size: 17px;
    font-weight: 900;
    line-height: 1.22;
}

.alo-duplicate-card__title a {
    color: var(--alo-primary, #276749);
    text-decoration: none;
}

.alo-duplicate-card__title a:hover,
.alo-duplicate-card__title a:focus-visible {
    color: #1f563b;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.alo-duplicate-card__metas {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 10px;
    color: var(--alo-card-meta-color, #4b463e);
    font-size: 13px;
    font-weight: 760;
    line-height: 1.35;
}

.alo-duplicate-card__metas span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-width: 0;
}

.alo-duplicate-card__metas .alo-icon {
    width: 15px;
    height: 15px;
    flex: 0 0 15px;
    color: var(--alo-primary, #276749);
}

.alo-duplicate-card__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(39, 103, 73, 0.1);
    color: var(--alo-primary, #276749);
    font-size: 13px;
    font-weight: 900;
    line-height: 1.1;
    text-decoration: none;
}

.alo-duplicate-card__button:hover,
.alo-duplicate-card__button:focus-visible {
    background: var(--alo-primary, #276749);
    color: #ffffff;
}

.alo-duplicate-confirmation__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid rgba(233, 226, 216, 0.9);
}

.alo-duplicate-confirmation__actions button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 20px;
    border-radius: 999px;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.1;
    cursor: pointer;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.alo-duplicate-confirmation__primary {
    border: 1px solid var(--alo-primary, #276749);
    background: var(--alo-primary, #276749);
    color: #ffffff;
    box-shadow: var(--alo-shadow-green, 0 10px 24px rgba(39, 103, 73, 0.18));
}

.alo-duplicate-confirmation__secondary {
    border: 1px solid rgba(39, 103, 73, 0.26);
    background: #ffffff;
    color: var(--alo-primary, #276749);
}

.alo-duplicate-confirmation__primary:hover,
.alo-duplicate-confirmation__primary:focus-visible {
    background: #1f563b;
    border-color: #1f563b;
}

.alo-duplicate-confirmation__secondary:hover,
.alo-duplicate-confirmation__secondary:focus-visible {
    border-color: var(--alo-primary, #276749);
    box-shadow: 0 0 0 4px rgba(39, 103, 73, 0.1);
}

.alo-duplicate-confirmation__final {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid #b9dfc4;
    border-radius: 14px;
    background: #ecf8ef;
    color: #185c36 !important;
    font-weight: 800 !important;
}

.alo-form-proposition.is-checking-duplicates button[type="submit"],
.alo-form-proposition button[type="submit"]:disabled {
    opacity: 0.72;
    cursor: wait !important;
    transform: none !important;
}

@media (max-width: 680px) {
    .alo-duplicate-confirmation {
        padding: 18px;
        border-radius: 18px;
    }

    .alo-duplicate-card {
        grid-template-columns: 86px minmax(0, 1fr);
        gap: 12px;
        padding: 10px;
    }

    .alo-duplicate-card__media {
        width: 86px;
    }

    .alo-duplicate-card__title {
        font-size: 15px;
    }

    .alo-duplicate-card__metas {
        font-size: 12px;
    }

    .alo-duplicate-card__button,
    .alo-duplicate-confirmation__actions button {
        width: 100%;
    }
}

.alo-form-proposition {
    width: min(100%, 780px);
    margin: clamp(28px, 5vw, 46px) auto 0;
    padding: clamp(24px, 4vw, 36px);
    background:
        linear-gradient(180deg, rgba(255, 254, 250, 0.98), rgba(255, 255, 255, 0.98)),
        var(--alo-surface-clean, #ffffff);
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 24px;
    box-shadow: var(--alo-shadow-md, 0 2px 6px rgba(45, 37, 28, 0.045), 0 18px 44px rgba(45, 37, 28, 0.085));
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
}

.alo-form-proposition__section + .alo-form-proposition__section {
    margin-top: 30px;
    padding-top: 30px;
    border-top: 1px solid rgba(233, 226, 216, 0.9);
}

.alo-form-proposition__section-head {
    margin-bottom: 18px;
}

.alo-form-proposition__section-head h2 {
    display: flex;
    align-items: center;
    gap: 7px;
    margin: 0 0 6px;
    color: var(--alo-primary, #276749);
    font-size: 18px;
    font-weight: 900;
    line-height: 1.2;
}

.alo-form-proposition__section-head .alo-section-star {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: auto;
    height: auto;
    border-radius: 0;
    background: transparent;
    color: #a25b00;
    font-size: 18px;
    font-weight: 950;
    line-height: 1;
}

.alo-form-proposition__section-head p {
    max-width: 620px;
    margin: 0;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.5;
}

.alo-form-proposition__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.alo-form-proposition .alo-field {
    margin: 0 0 18px;
}

.alo-form-proposition .alo-field:last-child {
    margin-bottom: 0;
}

.alo-form-proposition label {
    display: block;
    margin: 0 0 8px;
    color: #2d342e;
    font-size: 14px;
    font-weight: 850;
    line-height: 1.3;
}

.alo-form-proposition .required {
    color: #a25b00;
    font-weight: 950;
}

.alo-form-proposition input[type="text"],
.alo-form-proposition input[type="url"],
.alo-form-proposition input[type="email"],
.alo-form-proposition input[type="date"],
.alo-form-proposition input[type="file"],
.alo-form-proposition select,
.alo-form-proposition textarea {
    width: 100%;
    min-height: 52px;
    padding: 13px 15px;
    border: 1px solid var(--alo-border-medium, rgba(120, 92, 58, 0.22));
    border-radius: 15px;
    outline: none;
    background: #fffdf8;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
    color: var(--alo-ink, #202018);
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 16px;
    font-weight: 650;
    line-height: 1.35;
    box-sizing: border-box;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.alo-form-proposition textarea {
    min-height: 156px;
    resize: vertical;
}

.alo-form-proposition input[type="file"] {
    padding: 10px;
    color: var(--alo-muted-warm, #6f675c);
}

.alo-form-proposition input[type="file"]::file-selector-button {
    margin-right: 12px;
    padding: 10px 14px;
    border: 0;
    border-radius: 999px;
    background: var(--alo-gold-soft, #fff3d6);
    color: #6b4e13;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-weight: 850;
    cursor: pointer;
}

.alo-form-proposition input:focus,
.alo-form-proposition select:focus,
.alo-form-proposition textarea:focus {
    border-color: var(--alo-primary, #276749);
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(39, 103, 73, 0.11);
}

.alo-form-proposition select {
    appearance: none;
    padding-right: 48px;
    background-image:
        linear-gradient(45deg, transparent 50%, var(--alo-primary, #276749) 50%),
        linear-gradient(135deg, var(--alo-primary, #276749) 50%, transparent 50%);
    background-position:
        calc(100% - 21px) 50%,
        calc(100% - 15px) 50%;
    background-repeat: no-repeat;
    background-size: 7px 7px, 7px 7px;
}

.alo-form-proposition select:focus {
    background-color: #ffffff;
    background-image:
        linear-gradient(45deg, transparent 50%, var(--alo-primary, #276749) 50%),
        linear-gradient(135deg, var(--alo-primary, #276749) 50%, transparent 50%);
}

.alo-form-proposition select#alo_categorie {
    min-height: 52px;
    padding: 13px 44px 13px 16px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.18));
    border-radius: 14px;
    background-color: #fffdf8;
    box-shadow: none;
    color: #243228;
    font-size: 15px;
    font-weight: 850;
    line-height: 1.25;
}

.alo-form-proposition select#alo_categorie:hover,
.alo-form-proposition select#alo_categorie:focus {
    border-color: rgba(39, 103, 73, 0.42);
    background-color: #ffffff;
}

.alo-form-proposition select#alo_categorie:focus {
    box-shadow: 0 0 0 4px rgba(39, 103, 73, 0.11);
}

.alo-form-proposition .alo-help {
    margin: 7px 0 0;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 13px;
    font-weight: 600;
    line-height: 1.45;
}

.alo-form-proposition .alo-field__label {
    display: block;
    margin: 0 0 8px;
    color: #2d342e;
    font-size: 14px;
    font-weight: 850;
    line-height: 1.3;
}

.alo-form-proposition .alo-choice-group {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 12px;
}

.alo-form-proposition .alo-choice {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    padding: 11px 13px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 14px;
    background: #fffdf8;
    color: #34382f;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.25;
    cursor: pointer;
}

.alo-form-proposition .alo-choice input {
    width: 17px;
    height: 17px;
    margin: 0;
    accent-color: var(--alo-primary, #276749);
}

.alo-form-proposition .alo-choice span {
    white-space: nowrap;
}

.alo-form-proposition .alo-primary-select {
    position: relative;
    max-width: 100%;
    margin-top: 8px;
}

.alo-form-proposition .alo-primary-select__trigger {
    display: none;
}

.alo-form-proposition .alo-primary-select.is-enhanced [data-alo-primary-native] {
    position: absolute;
    width: 1px !important;
    min-width: 0;
    min-height: 0 !important;
    height: 1px !important;
    margin: 0;
    padding: 0;
    border: 0 !important;
    opacity: 0;
    pointer-events: none;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
}

.alo-form-proposition .alo-primary-select.is-enhanced .alo-primary-select__trigger {
    appearance: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    min-height: 52px;
    margin: 0;
    padding: 13px 16px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.18));
    border-radius: 14px;
    background: #fffdf8;
    box-shadow: none;
    color: #243228;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 15px;
    font-weight: 850;
    line-height: 1.25;
    text-align: left;
    box-sizing: border-box;
    cursor: pointer;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.alo-form-proposition .alo-primary-select.is-enhanced .alo-primary-select__trigger:hover,
.alo-form-proposition .alo-primary-select.is-open .alo-primary-select__trigger {
    border-color: var(--alo-primary, #276749);
    background: #ffffff;
}

.alo-form-proposition .alo-primary-select.is-enhanced .alo-primary-select__trigger:focus-visible,
.alo-form-proposition .alo-primary-select.has-error .alo-primary-select__trigger {
    outline: none;
    border-color: var(--alo-primary, #276749);
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(39, 103, 73, 0.11);
}

.alo-form-proposition .alo-primary-select.is-open .alo-primary-select__trigger {
    box-shadow: 0 0 0 4px rgba(39, 103, 73, 0.11);
}

.alo-form-proposition .alo-primary-select.is-enhanced .alo-primary-select__trigger::after {
    content: "";
    width: 9px;
    height: 9px;
    flex: 0 0 auto;
    border-right: 2px solid var(--alo-primary, #276749);
    border-bottom: 2px solid var(--alo-primary, #276749);
    transform: rotate(45deg);
    transition: transform 0.18s ease;
}

.alo-form-proposition .alo-primary-select.is-open .alo-primary-select__trigger::after {
    transform: rotate(225deg);
}

.alo-form-proposition .alo-primary-select__trigger [data-alo-primary-summary] {
    min-width: 0;
    overflow-wrap: anywhere;
}

.alo-form-proposition .alo-primary-select__menu {
    margin-top: 8px;
    padding: 10px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.16));
    border-radius: 16px;
    background: #fffefa;
}

.alo-form-proposition .alo-primary-select.is-enhanced .alo-primary-select__menu {
    max-height: 318px;
    overflow: auto;
    box-shadow: 0 18px 38px rgba(45, 52, 46, 0.12);
}

.alo-form-proposition .alo-primary-select__menu[hidden] {
    display: none;
}

.alo-form-proposition .alo-primary-select__options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
}

.alo-form-proposition .alo-primary-select__option {
    appearance: none;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    min-height: 42px;
    margin: 0;
    padding: 10px 12px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 12px;
    background: #fffdf8;
    box-shadow: none;
    color: #34382f;
    font: inherit;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.25;
    text-align: left;
    cursor: pointer;
    transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.alo-form-proposition .alo-primary-select__option::before {
    content: "";
    width: 16px;
    height: 16px;
    margin-top: 1px;
    flex: 0 0 auto;
    border: 1px solid rgba(81, 89, 75, 0.52);
    border-radius: 4px;
    background: #ffffff;
    box-sizing: border-box;
}

.alo-form-proposition .alo-primary-select__option:hover,
.alo-form-proposition .alo-primary-select__option:focus-visible {
    border-color: rgba(39, 103, 73, 0.34);
    background: #ffffff;
}

.alo-form-proposition .alo-primary-select__option:focus-visible {
    outline: 3px solid rgba(39, 103, 73, 0.18);
    outline-offset: 2px;
}

.alo-form-proposition .alo-primary-select__option.is-selected {
    border-color: rgba(39, 103, 73, 0.58);
    background: #f1f8f1;
    color: #1f5d42;
}

.alo-form-proposition .alo-primary-select__option.is-selected::before {
    border-color: var(--alo-primary, #276749);
    background:
        linear-gradient(45deg, transparent 48%, #ffffff 48% 58%, transparent 58%),
        linear-gradient(-45deg, transparent 42%, #ffffff 42% 54%, transparent 54%),
        var(--alo-primary, #276749);
}

.alo-form-proposition .alo-primary-select__option span {
    min-width: 0;
}

.alo-form-proposition .alo-secondary-select {
    position: relative;
    max-width: 100%;
    margin-top: 8px;
}

.alo-form-proposition .alo-secondary-select__trigger {
    display: none;
}

.alo-form-proposition .alo-secondary-select.is-enhanced .alo-secondary-select__trigger {
    appearance: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    min-height: 52px;
    margin: 0;
    padding: 13px 16px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.18));
    border-radius: 14px;
    background: #fffdf8;
    box-shadow: none;
    color: #243228;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 15px;
    font-weight: 850;
    line-height: 1.25;
    text-align: left;
    box-sizing: border-box;
    cursor: pointer;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.alo-form-proposition .alo-secondary-select.is-enhanced .alo-secondary-select__trigger:hover,
.alo-form-proposition .alo-secondary-select.is-open .alo-secondary-select__trigger {
    border-color: var(--alo-primary, #276749);
    background: #ffffff;
}

.alo-form-proposition .alo-secondary-select.is-enhanced .alo-secondary-select__trigger:focus-visible {
    outline: none;
    border-color: var(--alo-primary, #276749);
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(39, 103, 73, 0.11);
}

.alo-form-proposition .alo-secondary-select.is-open .alo-secondary-select__trigger {
    box-shadow: 0 0 0 4px rgba(39, 103, 73, 0.11);
}

.alo-form-proposition .alo-secondary-select.is-enhanced .alo-secondary-select__trigger::after {
    content: "";
    width: 9px;
    height: 9px;
    flex: 0 0 auto;
    border-right: 2px solid var(--alo-primary, #276749);
    border-bottom: 2px solid var(--alo-primary, #276749);
    transform: rotate(45deg);
    transition: transform 0.18s ease;
}

.alo-form-proposition .alo-secondary-select.is-open .alo-secondary-select__trigger::after {
    transform: rotate(225deg);
}

.alo-form-proposition .alo-secondary-select__trigger [data-alo-secondary-summary] {
    min-width: 0;
    overflow-wrap: anywhere;
}

.alo-form-proposition .alo-secondary-select__count {
    flex: 0 0 auto;
    padding: 4px 9px;
    border-radius: 999px;
    background: rgba(39, 103, 73, 0.09);
    color: var(--alo-primary, #276749);
    font-size: 12px;
    font-weight: 900;
    white-space: nowrap;
}

.alo-form-proposition .alo-secondary-select__count.is-full {
    background: rgba(39, 103, 73, 0.16);
}

.alo-form-proposition .alo-secondary-select__menu {
    margin-top: 8px;
    padding: 10px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.16));
    border-radius: 16px;
    background: #fffefa;
}

.alo-form-proposition .alo-secondary-select.is-enhanced .alo-secondary-select__menu {
    max-height: 318px;
    overflow: auto;
    box-shadow: 0 18px 38px rgba(45, 52, 46, 0.12);
}

.alo-form-proposition .alo-secondary-select__menu[hidden],
.alo-form-proposition .alo-secondary-select__tags[hidden] {
    display: none;
}

.alo-form-proposition .alo-category-checks {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
    margin-top: 8px;
}

.alo-form-proposition .alo-secondary-select.is-enhanced .alo-category-checks {
    margin-top: 0;
}

.alo-form-proposition .alo-category-check {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    min-height: 42px;
    margin: 0;
    padding: 10px 12px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 12px;
    background: #fffdf8;
    color: #34382f;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.25;
    cursor: pointer;
    transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.alo-form-proposition .alo-category-check:hover,
.alo-form-proposition .alo-category-check:focus-within {
    border-color: rgba(39, 103, 73, 0.34);
    background: #ffffff;
}

.alo-form-proposition .alo-category-check.is-selected {
    border-color: rgba(39, 103, 73, 0.58);
    background: #f1f8f1;
    color: #1f5d42;
}

.alo-form-proposition .alo-category-check.is-disabled {
    background: #faf8f1;
    color: #7b766d;
    cursor: not-allowed;
}

.alo-form-proposition .alo-category-check input {
    width: 16px;
    height: 16px;
    margin: 1px 0 0;
    flex: 0 0 auto;
    accent-color: var(--alo-primary, #276749);
}

.alo-form-proposition .alo-category-check input:disabled + span,
.alo-form-proposition .alo-category-check.is-disabled span {
    opacity: 0.52;
}

.alo-form-proposition .alo-category-check span {
    min-width: 0;
}

.alo-form-proposition .alo-secondary-select__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.alo-form-proposition .alo-secondary-select__tag {
    appearance: none;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    max-width: 100%;
    margin: 0;
    padding: 7px 10px;
    border: 1px solid rgba(39, 103, 73, 0.18);
    border-radius: 999px;
    background: #edf6ee;
    box-shadow: none;
    color: #1f5d42;
    font: inherit;
    font-size: 12px;
    font-weight: 850;
    line-height: 1.2;
    cursor: pointer;
}

.alo-form-proposition .alo-secondary-select__tag span:first-child {
    min-width: 0;
    overflow-wrap: anywhere;
}

.alo-form-proposition .alo-secondary-select__tag span:last-child {
    font-size: 15px;
    line-height: 1;
}

.alo-form-proposition .alo-secondary-select__tag:hover {
    border-color: rgba(39, 103, 73, 0.42);
    background: #e3f0e5;
}

.alo-form-proposition .alo-secondary-select__tag:focus-visible {
    outline: 3px solid rgba(39, 103, 73, 0.24);
    outline-offset: 2px;
}

.alo-form-proposition__conditional {
    margin-top: 8px;
}

.alo-form-proposition__conditional--price {
    max-width: 360px;
}

.alo-form-proposition__conditional.is-disabled {
    opacity: 0.48;
}

.alo-form-proposition__inline {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.alo-form-proposition__price-input {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
}

.alo-form-proposition__price-input span {
    color: var(--alo-primary, #276749);
    font-size: 16px;
    font-weight: 900;
}

.alo-form-proposition .alo-field--tarif {
    max-width: 560px;
}

.alo-form-proposition .alo-honeypot {
    position: absolute;
    left: -9999px;
}

.alo-form-proposition .alo-check {
    display: grid;
    grid-template-columns: 20px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    padding: 15px 16px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 16px;
    background: #f6f0e6;
    cursor: pointer;
}

.alo-form-proposition .alo-check input {
    width: 18px;
    height: 18px;
    margin-top: 1px;
    accent-color: var(--alo-primary, #276749);
}

.alo-form-proposition .alo-check span {
    color: #34382f;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.45;
}

.alo-form-proposition__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-top: 32px;
    padding-top: 28px;
    border-top: 1px solid rgba(233, 226, 216, 0.9);
}

.alo-form-proposition button[type="submit"] {
    min-height: 52px;
    padding: 0 28px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: var(--alo-primary, #276749) !important;
    box-shadow: var(--alo-shadow-green, 0 10px 24px rgba(39, 103, 73, 0.18)) !important;
    color: #ffffff !important;
    font-family: var(--alo-font-main, "DM Sans", sans-serif) !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease !important;
}

.alo-form-proposition button[type="submit"]:hover,
.alo-form-proposition button[type="submit"]:focus-visible {
    background: #1f563b !important;
    box-shadow: var(--alo-shadow-green-hover, 0 14px 32px rgba(39, 103, 73, 0.23)) !important;
    transform: translateY(-1px);
}

.alo-form-proposition__actions p {
    max-width: 280px;
    margin: 0;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 13px;
    font-weight: 700;
    line-height: 1.45;
    text-align: right;
}

/* Contact */
body.alo-page-contact .entry-content > .wp-block-columns {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
    align-items: stretch !important;
    margin-top: clamp(30px, 5vw, 48px);
}

body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column {
    position: relative;
    display: flex;
    flex-direction: column;
    min-width: 0;
    padding: clamp(24px, 3vw, 32px);
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(255, 254, 250, 0.98), rgba(255, 255, 255, 0.98)),
        #ffffff;
    box-shadow: var(--alo-shadow-md, 0 2px 6px rgba(45, 37, 28, 0.045), 0 18px 44px rgba(45, 37, 28, 0.085));
    overflow: hidden;
}

body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column::before,
.alo-contact-pro-card::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--alo-primary, #276749), rgba(39, 103, 73, 0.20));
}

body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column:nth-child(2) {
    border-color: rgba(39, 103, 73, 0.18);
    background:
        linear-gradient(180deg, rgba(255, 254, 250, 0.98), rgba(255, 255, 255, 0.98)),
        #ffffff;
    box-shadow: var(--alo-shadow-md, 0 2px 6px rgba(45, 37, 28, 0.045), 0 18px 44px rgba(45, 37, 28, 0.085));
}

body.alo-page-contact .entry-content h3 {
    margin: 0 0 10px;
    color: var(--alo-primary, #276749);
    font-size: 21px;
    font-weight: 920;
    line-height: 1.2;
}

body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column:nth-child(2) h3,
body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column:nth-child(2) p,
body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column:nth-child(2) strong {
    color: var(--alo-primary, #276749);
}

body.alo-page-contact .entry-content .wp-block-column p {
    margin-bottom: 18px;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 16px;
    font-weight: 600;
    line-height: 1.65;
}

body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column:nth-child(2) p {
    color: var(--alo-muted-warm, #6f675c);
}

body.alo-page-contact .entry-content strong {
    display: inline-flex;
    max-width: 100%;
    padding: 8px 12px;
    border: 1px solid rgba(39, 103, 73, 0.13);
    border-radius: 999px;
    background: rgba(39, 103, 73, 0.07);
    color: var(--alo-primary, #276749);
    font-weight: 900;
    overflow-wrap: anywhere;
}

body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column:nth-child(2) strong {
    border-color: rgba(39, 103, 73, 0.18);
    background: rgba(39, 103, 73, 0.07);
    color: var(--alo-primary, #276749);
}

body.alo-page-contact .wp-block-buttons {
    justify-content: center !important;
    margin-top: auto;
}

body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column:nth-child(2) p:last-child {
    display: flex;
    justify-content: center;
    margin-top: auto;
    margin-bottom: 0;
}

body.alo-page-contact .wp-block-button__link {
    min-height: 48px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 0 22px !important;
    border-radius: 999px !important;
    background: var(--alo-primary, #276749) !important;
    box-shadow: var(--alo-shadow-green, 0 10px 24px rgba(39, 103, 73, 0.18));
    color: #ffffff !important;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 15px;
    font-weight: 900;
    text-decoration: none !important;
}

body.alo-page-contact .entry-content > p:last-child {
    width: fit-content;
    max-width: 100%;
    margin: 34px auto 0;
    padding: 10px 16px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.62);
    color: var(--alo-muted-warm, #6f675c);
    font-size: 14px !important;
    font-weight: 700;
}

.alo-contact-pro {
    margin-top: clamp(34px, 5vw, 56px);
}

.alo-contact-pro__head {
    max-width: 760px;
    margin: 0 auto 22px;
    text-align: center;
}

.alo-contact-pro__eyebrow {
    margin: 0 0 8px;
    color: var(--alo-primary, #276749);
    font-size: 12px;
    font-weight: 950;
    letter-spacing: 0;
    text-transform: uppercase;
}

.alo-contact-pro__head h2 {
    margin: 0;
    color: #191713;
    font-size: clamp(1.55rem, 3vw, 2.15rem);
    font-weight: 950;
    line-height: 1.12;
}

.alo-contact-pro__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.alo-contact-pro-card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-width: 0;
    padding: clamp(22px, 3vw, 30px);
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 20px;
    background: #fffefa;
    box-shadow: var(--alo-shadow-sm, 0 1px 2px rgba(45, 37, 28, 0.035), 0 10px 24px rgba(45, 37, 28, 0.06));
    overflow: hidden;
}

.alo-contact-pro-card h3 {
    margin: 0 0 10px;
    color: var(--alo-primary, #276749);
    font-size: 20px;
    font-weight: 950;
    line-height: 1.18;
}

.alo-contact-pro-card p {
    margin: 0 0 22px;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 15px;
    font-weight: 650;
    line-height: 1.62;
}

.alo-contact-pro-card a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    width: fit-content;
    max-width: 100%;
    margin-top: auto;
    padding: 0 20px;
    border-radius: 999px;
    background: var(--alo-primary, #276749);
    color: #ffffff !important;
    font-size: 14px;
    font-weight: 900;
    text-decoration: none !important;
    box-shadow: var(--alo-shadow-green, 0 10px 24px rgba(39, 103, 73, 0.18));
}

.alo-contact-pro-card a:hover,
.alo-contact-pro-card a:focus-visible {
    background: #1f563b;
    color: #ffffff !important;
    transform: translateY(-1px);
}

/* Page À propos */
body.alo-page-about .entry-title {
    display: none !important;
}

body.alo-page-about .site-content > .ast-container {
    padding-top: 0 !important;
}

body.alo-page-about .content-area.primary {
    margin-top: -18px !important;
}

.alo-about-page {
    max-width: 1120px;
    margin: 0 auto;
    color: var(--alo-ink, #202018);
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
}

.alo-about-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.16fr) minmax(260px, 0.84fr);
    gap: 28px;
    align-items: end;
    overflow: hidden;
    padding: 52px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 254, 250, 0.98), rgba(245, 243, 239, 0.96)),
        #fffefa;
}

.alo-about-hero::after {
    content: "";
    position: absolute;
    right: 52px;
    bottom: 0;
    width: 250px;
    height: 6px;
    background: linear-gradient(90deg, rgba(39, 103, 73, 0), #276749 48%, #b77a18);
}

.alo-about-eyebrow {
    margin: 0 0 12px !important;
    color: #8a6519 !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    letter-spacing: 0.06em !important;
    line-height: 1.2 !important;
    text-transform: uppercase;
}

.alo-about-hero h1,
.alo-about-hero h2 {
    max-width: 760px;
    margin: 0 0 18px;
    color: #202018;
    font-family: "Fraunces", "DM Sans", Georgia, serif;
    font-size: 4.15rem;
    font-weight: 900;
    line-height: 0.98;
    letter-spacing: 0;
}

.alo-about-lead {
    max-width: 740px;
    margin: 0;
    color: #5f584d;
    font-size: 1.16rem !important;
    font-weight: 650;
    line-height: 1.7;
}

.alo-about-actions,
.alo-about-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 26px;
}

.alo-about-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border: 1px solid rgba(39, 103, 73, 0.22);
    border-radius: 999px;
    background: #ffffff;
    color: #276749 !important;
    font-size: 14px;
    font-weight: 950;
    line-height: 1.15;
    text-align: center;
    text-decoration: none !important;
    transition: transform 0.18s ease, background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

.alo-about-btn--primary {
    border-color: #276749;
    background: #276749;
    color: #ffffff !important;
    box-shadow: var(--alo-shadow-green, 0 10px 24px rgba(39, 103, 73, 0.18));
}

.alo-about-btn--disabled {
    border-color: rgba(120, 92, 58, 0.18);
    background: #d8d2c7;
    color: #4f463d !important;
    cursor: not-allowed;
}

.alo-about-btn:hover,
.alo-about-btn:focus-visible {
    transform: translateY(-1px);
    text-decoration: none !important;
}

.alo-about-btn--primary:hover,
.alo-about-btn--primary:focus-visible {
    background: #1f563b;
    color: #ffffff !important;
}

.alo-about-card {
    min-width: 0;
    padding: 24px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 8px;
    background: #fffefa;
}

.alo-about-card__label {
    display: inline-flex;
    margin-bottom: 14px;
    padding: 6px 10px;
    border: 1px solid rgba(183, 122, 24, 0.22);
    border-radius: 999px;
    background: var(--alo-gold-soft, #fff3d6);
    color: #6b4e13;
    font-size: 12px;
    font-weight: 950;
}

.alo-about-card h2,
.alo-about-card h3,
.alo-about-section h2 {
    margin: 0 0 12px;
    color: #202018;
    font-family: "Fraunces", "DM Sans", Georgia, serif;
    font-weight: 850;
    line-height: 1.08;
    letter-spacing: 0;
}

.alo-about-card h2,
.alo-about-section h2 {
    font-size: 2rem;
}

.alo-about-card h3 {
    font-size: 1.35rem;
}

.alo-about-card p,
.alo-about-section p {
    margin: 0 0 16px;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 1rem !important;
    font-weight: 620;
    line-height: 1.66;
}

.alo-about-card p:last-child,
.alo-about-section p:last-child {
    margin-bottom: 0;
}

.alo-about-story,
.alo-about-support {
    margin-top: 30px;
}

.alo-about-story {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(260px, 0.65fr);
    gap: 22px;
    align-items: start;
}

.alo-about-note {
    border-color: rgba(39, 103, 73, 0.16);
    background:
        linear-gradient(135deg, rgba(39, 103, 73, 0.07), rgba(255, 254, 250, 0.98)),
        #fffefa;
}

.alo-about-note strong {
    color: #276749;
    font-weight: 950;
}

.alo-about-section {
    margin-top: 30px;
    padding: 32px;
    border-top: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-bottom: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
}

.alo-about-help-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 20px;
}

.alo-about-support-section {
    background: rgba(255, 255, 255, 0.26);
}

.alo-about-support-section > p {
    max-width: 790px;
}

.alo-about-support {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 24px;
    align-items: center;
    padding: 28px 32px;
    border: 1px solid rgba(39, 103, 73, 0.14);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 254, 250, 0.98), rgba(245, 243, 239, 0.98)),
        #fffefa;
}

.alo-about-support h2,
.alo-about-support h3 {
    margin: 0 0 10px;
    color: #202018;
    font-family: "Fraunces", "DM Sans", Georgia, serif;
    font-size: 2rem;
    font-weight: 850;
    line-height: 1.08;
    letter-spacing: 0;
}

.alo-about-support p {
    max-width: 730px;
    margin: 0 0 12px;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 1rem !important;
    font-weight: 620;
    line-height: 1.66;
}

.alo-about-support small {
    color: #6f675c;
    font-weight: 850;
}

@media (max-width: 920px) {
    .alo-about-hero,
    .alo-about-story,
    .alo-about-support {
        grid-template-columns: 1fr;
    }

    .alo-about-hero {
        padding: 38px;
    }

    .alo-about-hero h1,
    .alo-about-hero h2 {
        font-size: 3.15rem;
    }

    .alo-about-help-grid {
        grid-template-columns: 1fr;
    }

    .alo-about-support {
        align-items: stretch;
    }
}

@media (max-width: 560px) {
    body.alo-page-about .content-area.primary {
        margin-top: -10px !important;
    }

    .alo-about-hero,
    .alo-about-card,
    .alo-about-section,
    .alo-about-support {
        padding: 22px;
    }

    .alo-about-hero h1,
    .alo-about-hero h2 {
        font-size: 2.42rem;
        line-height: 1.02;
    }

    .alo-about-lead {
        font-size: 1.03rem !important;
    }

    .alo-about-actions,
    .alo-about-card-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .alo-about-btn {
        width: 100%;
    }
}

/* Blog SEO */
.alo-blog-index {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
    margin-top: clamp(32px, 5vw, 54px);
}

body.alo-page-blog .entry-content > p:first-of-type + .alo-blog-index {
    margin-top: 0;
}

.alo-blog-card {
    min-width: 0;
    overflow: hidden;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255, 254, 250, 0.98), rgba(255, 255, 255, 0.98));
    box-shadow: var(--alo-shadow-sm, 0 1px 2px rgba(45, 37, 28, 0.035), 0 10px 24px rgba(45, 37, 28, 0.06));
}

.alo-blog-card--featured {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: minmax(280px, 0.92fr) minmax(0, 1.08fr);
    min-height: 330px;
}

.alo-blog-card__media {
    position: relative;
    display: block;
    min-height: 210px;
    overflow: hidden;
    background: #efe7da;
    text-decoration: none !important;
}

.alo-blog-card--featured .alo-blog-card__media {
    min-height: 100%;
}

.alo-blog-card__media img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: inherit;
    object-fit: cover;
    transition: transform 0.24s ease;
}

.alo-blog-card:hover .alo-blog-card__media img {
    transform: scale(1.03);
}

.alo-blog-card__fallback {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    padding: 22px;
    background:
        radial-gradient(circle at 18% 22%, rgba(39, 103, 73, 0.16), transparent 34%),
        linear-gradient(135deg, #f8f0df 0%, #fffdf8 48%, #e6dccb 100%);
}

.alo-blog-card__fallback span {
    display: inline-flex;
    max-width: 78%;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    color: #6b4e13;
    font-size: 13px;
    font-weight: 900;
    line-height: 1.2;
}

.alo-blog-card__body {
    padding: clamp(22px, 3vw, 32px);
}

.alo-blog-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-bottom: 13px;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 13px;
    font-weight: 850;
    line-height: 1.2;
}

.alo-blog-card__meta span {
    display: inline-flex;
    padding: 6px 10px;
    border: 1px solid rgba(183, 122, 24, 0.22);
    border-radius: 999px;
    background: var(--alo-gold-soft, #fff3d6);
    color: #6b4e13;
}

.alo-blog-card__title {
    margin: 0 0 12px;
    color: var(--alo-ink, #202018);
    font-size: clamp(1.25rem, 1vw + 1rem, 1.8rem);
    font-weight: 950;
    line-height: 1.08;
}

.alo-blog-card:not(.alo-blog-card--featured) .alo-blog-card__title {
    font-size: 1.28rem;
    line-height: 1.15;
}

.alo-blog-card__title a {
    color: inherit !important;
    text-decoration: none !important;
}

.alo-blog-card__title a:hover {
    color: var(--alo-primary, #276749) !important;
}

.alo-blog-card__excerpt {
    margin: 0 0 20px;
    color: var(--alo-muted-warm, #6f675c);
    font-size: 15px !important;
    font-weight: 600;
    line-height: 1.62;
}

.alo-blog-card__link {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0 16px;
    border-radius: 999px;
    background: rgba(39, 103, 73, 0.08);
    color: var(--alo-primary, #276749) !important;
    font-size: 14px;
    font-weight: 900;
    text-decoration: none !important;
}

.alo-blog-card__link:hover {
    background: var(--alo-primary, #276749);
    color: #ffffff !important;
}

.alo-blog-empty {
    grid-column: 1 / -1;
    padding: 28px;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 22px;
    background: #fffefa;
    text-align: center;
}

.alo-blog-empty p {
    margin: 0;
    color: var(--alo-muted-warm, #6f675c);
    font-weight: 700;
}

@media (max-width: 820px) {
    body.alo-page-editorial .ast-container {
        padding: clamp(24px, 6vw, 38px) 16px 66px;
    }

    body.alo-page-editorial .entry-content > h1:first-child,
    body.alo-page-editorial .entry-title,
    body.alo-page-editorial .entry-content .alo-page-title {
        font-size: clamp(2.05rem, 9vw, 3rem);
    }

    .alo-form-proposition {
        padding: 22px;
        border-radius: 20px;
    }

    .alo-form-proposition__grid,
    .alo-form-proposition__inline,
    body.alo-page-contact .entry-content > .wp-block-columns,
    .alo-contact-pro__grid,
    .alo-blog-index,
    .alo-blog-card--featured {
        grid-template-columns: 1fr;
    }

    .alo-form-proposition__actions {
        align-items: stretch;
        flex-direction: column;
    }

    .alo-form-proposition .alo-primary-select__options,
    .alo-form-proposition .alo-category-checks {
        grid-template-columns: 1fr;
    }

    .alo-form-proposition button[type="submit"] {
        width: 100%;
    }

    .alo-form-proposition__actions p {
        max-width: none;
        text-align: center;
    }

    .alo-blog-card--featured .alo-blog-card__media {
        min-height: 230px;
    }
}

@media (max-width: 560px) {
    body.alo-page-editorial .ast-container {
        padding-left: 14px;
        padding-right: 14px;
    }

    .alo-form-proposition,
    body.alo-page-contact .entry-content > .wp-block-columns > .wp-block-column,
    .alo-contact-pro-card,
    .alo-blog-card__body {
        padding: 20px;
    }

    .alo-form-proposition input[type="text"],
    .alo-form-proposition input[type="url"],
    .alo-form-proposition input[type="email"],
    .alo-form-proposition input[type="date"],
    .alo-form-proposition input[type="file"],
    .alo-form-proposition select,
    .alo-form-proposition textarea {
        font-size: 16px;
        border-radius: 13px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .alo-form-proposition button[type="submit"],
    .alo-blog-card__media img {
        transition: none !important;
        transform: none !important;
    }
}

/* ==========================================================================
   Design des Articles de Blog (Standard WordPress)
   ========================================================================== */

body.single-post .site-content {
    background-color: var(--alo-page-bg); /* Fond crème chaleureux */
}

body.single-post .ast-container,
body.single-post .site-main {
    max-width: 800px; /* Largeur de lecture optimale */
    margin: 0 auto;
    padding: 20px;
}

body.single-post article.post {
    background: #ffffff;
    padding: 40px;
    border-radius: 16px;
    box-shadow: var(--alo-shadow-sm, 0 1px 2px rgba(45, 37, 28, 0.035), 0 10px 24px rgba(45, 37, 28, 0.06));
    margin-top: 40px;
    margin-bottom: 40px;
}

/* Style des métadonnées (Nettoyage radical : on ne garde que la date) */
.entry-meta {
    font-size: 0 !important; /* Cache les textes "Par" et "/" qui ne sont pas dans des balises */
    color: var(--alo-text-muted);
    margin-bottom: 20px;
}

.entry-meta .posted-on {
    font-size: 14px !important; /* Réactive uniquement la date */
    display: inline-block !important;
}

.entry-meta .posted-by,
.entry-meta .byline,
.entry-meta .author,
.entry-meta .author-name {
    display: none !important;
}

/* Titre principal */
body.single-post .entry-title {
    font-size: 36px;
    font-weight: 800;
    color: var(--alo-primary, #276749);
    line-height: 1.2;
    margin-bottom: 24px;
}

/* Typographie du corps de texte */
body.single-post .entry-content {
    font-size: 18px;
    line-height: 1.7;
    color: #333333;
    font-family: 'DM Sans', sans-serif;
}

body.single-post .entry-content p {
    margin-bottom: 1.5em;
}

body.single-post .entry-content h2 {
    font-size: 26px;
    font-weight: 700;
    color: var(--alo-primary, #276749);
    margin-top: 2em;
    margin-bottom: 1em;
}

body.single-post .entry-content h3 {
    font-size: 22px;
    font-weight: 700;
    color: #111111;
    margin-top: 1.5em;
    margin-bottom: 0.8em;
}

body.single-post .entry-content a {
    color: var(--alo-primary, #276749);
    text-decoration: underline;
    font-weight: 500;
}

body.single-post .entry-content a:hover {
    color: var(--alo-hover, #1a4d36);
}

/* Images dans l'article */
body.single-post .entry-content img {
    border-radius: 12px;
    margin: 20px 0;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

/* Masquer la section commentaires par CSS (sécurité visuelle supplémentaire) */
body.single-post .comments-area {
    display: none !important;
}

/* Bloc CTA Agenda (Audit Final Cycle 4 - Épuration et Correctifs) */
body.single-post .alo-blog-cta {
    background: #ffffff !important;
    border: none !important; /* On enlève la bordure pour un look plus moderne/aéré */
    border-top: 1px solid #eee !important;
    border-bottom: 1px solid #eee !important;
    border-radius: 0 !important;
    padding: 60px 20px !important;
    margin: 80px 0 !important;
    text-align: center !important;
    box-shadow: none !important;
}

body.single-post .alo-blog-cta__header {
    margin-bottom: 40px !important;
}

body.single-post .alo-blog-cta__title {
    font-size: 32px !important;
    color: #276749 !important; /* Retour au vert sapin pour la cohérence */
    font-weight: 800 !important;
    margin-bottom: 15px !important;
    line-height: 1.2 !important;
}

body.single-post .alo-blog-cta__text {
    font-size: 18px !important;
    color: var(--alo-text-muted) !important;
    max-width: 600px !important;
    margin: 0 auto !important;
}

/* Centrage et structure du carrousel */
body.single-post .alo-blog-cta .alo-carousel-wrapper {
    display: block !important;
    margin: 0 auto !important;
    max-width: 100% !important;
}

body.single-post .alo-blog-cta .alo-carousel {
    display: flex !important;
    justify-content: center !important;
    gap: 15px !important;
    padding: 20px 0 28px !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
}

/* On s'assure que les cartes ne sont pas trop larges dans le blog */
body.single-post .alo-blog-cta .alo-card {
    flex: 0 0 var(--alo-card-width) !important;
    max-width: var(--alo-card-width) !important;
    text-align: left !important;
    background:
        linear-gradient(180deg, rgba(255, 254, 250, 0.98) 0%, rgba(255, 255, 255, 0.99) 100%),
        var(--alo-card-bg, #fffefa) !important;
    border: 1px solid var(--alo-border-green-soft, rgba(39, 103, 73, 0.14)) !important;
    border-radius: 16px !important;
    box-shadow: var(--alo-shadow-sm, 0 1px 2px rgba(45, 37, 28, 0.035), 0 10px 24px rgba(45, 37, 28, 0.06)) !important;
}

body.single-post .alo-blog-cta .alo-card:hover {
    border-color: rgba(39, 103, 73, 0.22) !important;
    box-shadow: var(--alo-shadow-md, 0 2px 6px rgba(45, 37, 28, 0.045), 0 18px 44px rgba(45, 37, 28, 0.085)) !important;
}

body.single-post .alo-blog-cta .alo-nav-prev,
body.single-post .alo-blog-cta .alo-nav-next {
    display: none !important;
}

body.single-post .alo-blog-cta__footer {
    margin-top: 40px !important;
}

body.single-post .alo-blog-cta__btn {
    display: inline-block !important;
    background: var(--alo-primary, #276749) !important;
    color: #ffffff !important;
    padding: 16px 40px !important;
    border-radius: var(--alo-btn-radius, 50px) !important;
    font-weight: 800 !important;
    font-size: 18px !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 4px 12px rgba(39, 103, 73, 0.2) !important;
}

body.single-post .alo-blog-cta__btn:hover {
    background: var(--alo-hover, #1a4d36) !important;
    transform: scale(1.05) !important;
    color: #ffffff !important;
    text-decoration: none !important;
}

@media (max-width: 768px) {
    body.single-post .alo-blog-cta {
        padding: 40px 15px !important;
        margin: 50px -15px !important;
    }
    body.single-post .alo-blog-cta__title {
        font-size: 26px !important;
    }
    body.single-post .alo-blog-cta .alo-carousel {
        justify-content: flex-start !important;
        padding-left: 20px !important;
        padding-right: 20px !important;
    }
}

@media (max-width: 768px) {
    body.single-post article.post {
        padding: 24px 15px;
        border-radius: 12px;
        margin-top: 20px;
    }
    body.single-post .entry-title {
        font-size: 28px;
    }
    body.single-post .entry-content {
        font-size: 16px;
    }
}

/* ==========================================================================
   Guides SEO V1
   ========================================================================== */

body.alo-page-guide .entry-title {
    display: none !important;
}

body.alo-page-guide .ast-container {
    max-width: 1180px;
}

.alo-guide-landing {
    display: block;
}

body.alo-page-guide .site-content > .ast-container,
body.alo-single-guide .site-content > .ast-container {
    padding-top: 0 !important;
}

body.alo-page-guide .content-area.primary,
body.alo-single-guide .content-area.primary {
    margin-top: -18px !important;
}

.alo-guide-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(32px, 5vw, 58px);
    border: 1px solid rgba(120, 92, 58, 0.14);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 254, 250, 0.98), rgba(245, 243, 239, 0.94)),
        #fffefa;
    box-shadow: 0 1px 2px rgba(45, 37, 28, 0.035), 0 18px 42px rgba(45, 37, 28, 0.06);
}

.alo-guide-hero::after {
    content: "";
    position: absolute;
    right: clamp(22px, 5vw, 58px);
    bottom: 0;
    width: min(32vw, 270px);
    height: 6px;
    background: linear-gradient(90deg, rgba(39, 103, 73, 0), #276749 45%, #b77a18);
}

.alo-guide-hero__eyebrow {
    margin: 0 0 12px !important;
    color: #8a6519 !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    letter-spacing: 0.08em !important;
    line-height: 1.2 !important;
    text-align: left !important;
    text-transform: uppercase;
}

.alo-guide-hero h1 {
    max-width: 780px;
    margin: 0 0 18px;
    color: #202018;
    font-family: "Fraunces", "DM Sans", Georgia, serif;
    font-size: clamp(2.45rem, 5vw, 4.9rem);
    font-weight: 900;
    line-height: 0.95;
    letter-spacing: 0;
}

.alo-guide-hero p:not(.alo-guide-hero__eyebrow) {
    max-width: 760px;
    margin: 0;
    color: #5f584d;
    font-size: clamp(1.03rem, 0.45vw + 0.95rem, 1.22rem);
    font-weight: 600;
    line-height: 1.7;
}

.alo-guide-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 28px;
}

.alo-guide-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border: 1px solid rgba(39, 103, 73, 0.22);
    border-radius: 999px;
    background: #ffffff;
    color: #276749 !important;
    font-size: 14px;
    font-weight: 950;
    line-height: 1.15;
    text-align: center;
    text-decoration: none !important;
}

.alo-guide-btn--primary {
    border-color: #276749;
    background: #276749;
    color: #ffffff !important;
    box-shadow: 0 10px 22px rgba(39, 103, 73, 0.16);
}

.alo-guide-btn:hover,
.alo-guide-btn:focus-visible {
    transform: translateY(-1px);
}

.alo-guide-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin: clamp(26px, 4vw, 40px) 0 0;
}

.alo-guide-categories a {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 14px;
    border: 1px solid rgba(120, 92, 58, 0.14);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.75);
    color: #3f3a31 !important;
    font-size: 13px;
    font-weight: 900;
    text-decoration: none !important;
}

.alo-guide-categories a:hover {
    border-color: rgba(39, 103, 73, 0.24);
    color: #276749 !important;
}

body.alo-page-guide .alo-blog-index {
    margin-top: clamp(22px, 3vw, 34px);
}

body.alo-page-guide .alo-blog-card {
    border-radius: 8px;
}

body.alo-page-guide .alo-blog-card__media {
    background: #e8e1d3;
}

body.alo-page-guide .alo-blog-card__fallback {
    background:
        linear-gradient(135deg, rgba(39, 103, 73, 0.14), rgba(245, 243, 239, 0.88)),
        #efe7da;
}

body.alo-page-guide .alo-blog-card__link::after {
    content: " →";
}

body.alo-single-guide .site-content {
    background: var(--alo-page-bg, #f7f4ee);
}

body.alo-single-guide .ast-container,
body.alo-single-guide .site-main {
    max-width: 940px;
}

body.alo-single-guide article.post {
    overflow: hidden;
    max-width: 900px;
    padding: clamp(28px, 5vw, 58px);
    border: 1px solid rgba(120, 92, 58, 0.12);
    border-radius: 8px;
    background: #fffefa;
    box-shadow: 0 1px 2px rgba(45, 37, 28, 0.035), 0 16px 40px rgba(45, 37, 28, 0.06);
    margin-top: 0 !important;
}

body.alo-single-guide .entry-title {
    max-width: 760px;
    color: #202018;
    font-family: "Fraunces", "DM Sans", Georgia, serif;
    font-size: clamp(2.15rem, 4vw, 4rem);
    font-weight: 900;
    line-height: 0.98;
    letter-spacing: 0;
}

body.alo-single-guide .entry-content {
    color: #2f2b24;
    font-size: 18px;
    line-height: 1.75;
}

body.alo-single-guide .entry-content h2 {
    margin-top: 1.75em;
    margin-bottom: 0.7em;
    color: #276749;
}

body.alo-single-guide .entry-content h3 {
    margin-top: 1.45em;
    margin-bottom: 0.55em;
}

body.alo-single-guide .entry-content > p:first-child,
.alo-guide-chapo {
    max-width: 760px;
    margin: 0 0 28px;
    color: #4f483d;
    font-size: clamp(1.08rem, 0.8vw + 1rem, 1.34rem);
    font-weight: 650;
    line-height: 1.65;
}

.alo-guide-summary,
.alo-guide-info-card,
.alo-guide-spot,
.alo-guide-sources,
.alo-guide-events-block,
.alo-guide-faq,
.alo-guide-note {
    border: 1px solid rgba(120, 92, 58, 0.13);
    border-radius: 8px;
    background: #ffffff;
}

.alo-guide-summary {
    margin: 30px 0;
    padding: 22px;
}

body.alo-single-guide .entry-content .alo-guide-summary h2,
body.alo-single-guide .entry-content .alo-guide-info-card h3,
body.alo-single-guide .entry-content .alo-guide-spot h3,
body.alo-single-guide .entry-content .alo-guide-events-block h2,
body.alo-single-guide .entry-content .alo-guide-sources h2,
body.alo-single-guide .entry-content .alo-guide-faq h2,
body.alo-single-guide .entry-content .alo-guide-faq h3 {
    margin-top: 0 !important;
    margin-bottom: 12px !important;
}

.alo-guide-summary ol {
    display: grid;
    gap: 8px;
    margin: 0;
    padding-left: 22px;
}

.alo-guide-summary a {
    color: #276749 !important;
    font-weight: 850 !important;
    text-decoration: none !important;
}

.alo-guide-info-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: 30px 0;
}

.alo-guide-info-card {
    padding: 18px;
}

.alo-guide-info-card h3 {
    color: #276749;
    font-size: 15px;
    font-weight: 950;
}

.alo-guide-info-card p {
    margin: 0;
    color: #5f584d;
    font-size: 15px;
    font-weight: 650;
    line-height: 1.55;
}

.alo-guide-checklist {
    margin: 26px 0;
    padding-left: 22px;
}

.alo-guide-checklist li + li {
    margin-top: 9px;
}

.alo-guide-picks {
    display: grid;
    gap: 18px;
    margin: 30px 0;
}

.alo-guide-photo {
    margin: clamp(26px, 4vw, 42px) 0;
}

.alo-guide-photo img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
    max-height: 520px;
    object-fit: cover;
    border-radius: 8px;
    box-shadow: 0 1px 2px rgba(45, 37, 28, 0.035), 0 16px 34px rgba(45, 37, 28, 0.08);
}

.alo-guide-photo figcaption {
    margin-top: 9px;
    color: #6f675c;
    font-size: 12px;
    font-weight: 650;
    line-height: 1.45;
}

.alo-guide-photo figcaption a {
    color: #276749 !important;
    font-weight: 850 !important;
    text-decoration: none !important;
}

.alo-guide-spot {
    padding: clamp(18px, 3vw, 24px);
}

.alo-guide-spot h3 {
    color: #202018;
    font-size: clamp(1.22rem, 0.7vw + 1rem, 1.55rem);
    font-weight: 950;
    line-height: 1.18;
}

.alo-guide-spot p:last-child,
.alo-guide-events-block p:last-child,
.alo-guide-faq p:last-child,
.alo-guide-sources p:last-child {
    margin-bottom: 0;
}

.alo-guide-events-block {
    margin: 34px 0;
    padding: clamp(20px, 3vw, 28px);
    background:
        linear-gradient(180deg, rgba(245, 243, 239, 0.55), rgba(255, 255, 255, 0.98)),
        #ffffff;
}

.alo-guide-events-block .alo-global-sponsored {
    display: none;
}

.alo-guide-events-block > p {
    color: #5f584d;
    font-weight: 650;
}

.alo-guide-faq {
    margin: 34px 0;
    padding: clamp(18px, 3vw, 24px);
    background: #fffefa;
}

.alo-guide-faq h3 {
    color: #202018;
    font-size: 18px;
    font-weight: 950;
    line-height: 1.25;
}

.alo-guide-faq h3:not(:first-of-type) {
    margin-top: 22px !important;
}

.alo-guide-cta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 26px 0;
}

.alo-guide-cta-row a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid rgba(39, 103, 73, 0.2);
    border-radius: 999px;
    background: #ffffff;
    color: #276749 !important;
    font-size: 14px;
    font-weight: 900 !important;
    text-decoration: none !important;
}

.alo-guide-cta-row a:first-child {
    border-color: #276749;
    background: #276749;
    color: #ffffff !important;
}

.alo-guide-sources {
    margin: 32px 0 0;
    padding: 18px 22px;
    background: #fbfaf7;
}

.alo-guide-sources ul {
    margin-bottom: 0;
}

.alo-guide-note {
    margin: 24px 0;
    padding: 16px 18px;
    background: #f5f3ef;
    color: #5f584d;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.6;
}

body.alo-single-guide .alo-slider-section--guide {
    margin-top: 14px;
}

@media (max-width: 820px) {
    .alo-guide-info-grid {
        grid-template-columns: 1fr;
    }

    body.alo-single-guide .ast-container,
    body.alo-single-guide .site-main {
        padding-left: 14px;
        padding-right: 14px;
    }

    body.alo-page-guide .content-area.primary,
    body.alo-single-guide .content-area.primary {
        margin-top: -10px !important;
    }
}

@media (max-width: 560px) {
    .alo-guide-hero {
        padding: 26px 20px 32px;
    }

    .alo-guide-hero h1,
    body.alo-single-guide .entry-title {
        font-size: clamp(2rem, 12vw, 2.7rem);
    }

    .alo-guide-hero__actions,
    .alo-guide-cta-row {
        align-items: stretch;
        flex-direction: column;
    }

    .alo-guide-btn,
    .alo-guide-cta-row a {
        width: 100%;
    }
}
