/* ==========================================================================
   Agenda Lyon Ouest — Styles Carrousel & Cartes
   ========================================================================== */

/* ── Section wrapper ─────────────────────────────────────────────────────── */

.alo-slider-section {
    position: relative;
    background: transparent;
    border: 0;
    border-radius: 0;
    padding: 30px 0 34px;
    box-sizing: border-box;
    overflow: visible; /* Ne pas couper l'ombre des cartes */
    box-shadow: none;
}

.alo-slider-section--blog {
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 0;
    border-radius: 0;
}

.alo-global-sponsored {
    width: min(1180px, calc(100% - 32px));
    margin: 14px auto 18px;
}

.alo-global-sponsored .alo-slider-section {
    padding: 14px 0 16px;
    border-top: 1px solid rgba(120, 92, 58, 0.16);
    border-bottom: 1px solid rgba(120, 92, 58, 0.12);
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.alo-global-sponsored .alo-slider-section::before {
    content: "";
    position: absolute;
    top: -1px;
    left: 0;
    width: 92px;
    height: 2px;
    background: linear-gradient(90deg, #d9b45f, rgba(217, 180, 95, 0));
}

.alo-global-sponsored .alo-slider-section__title {
    color: #28241c;
    font-size: 19px;
}

.alo-global-sponsored .alo-slider-section__header {
    margin-bottom: 14px;
}

.alo-global-sponsored .alo-carousel {
    padding-bottom: 12px;
}

body.alo-page-guide .alo-global-sponsored,
body.alo-single-guide .alo-global-sponsored {
    margin-bottom: 12px;
}

.alo-archive .alo-global-sponsored--archive {
    width: 100%;
    margin: -18px auto 34px;
}

.alo-global-sponsored--guide {
    width: 100%;
    margin: 0;
}

.alo-featured-pro-cta {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 22px;
    padding: clamp(18px, 3vw, 28px);
    border: 1px solid rgba(120, 92, 58, 0.16);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 254, 250, 0.98), rgba(245, 243, 239, 0.98)),
        #fffefa;
    box-shadow: 0 1px 2px rgba(45, 37, 28, 0.035), 0 12px 30px rgba(45, 37, 28, 0.055);
}

.alo-featured-pro-cta__eyebrow {
    margin: 0 0 8px;
    color: #8a6519;
    font-size: 12px;
    font-weight: 950;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.alo-featured-pro-cta h2 {
    margin: 0 0 8px;
    color: #202018;
    font-family: "Fraunces", "DM Sans", Georgia, serif;
    font-size: clamp(1.45rem, 1.4vw + 1rem, 2.15rem);
    font-weight: 850;
    line-height: 1.05;
    letter-spacing: 0;
}

.alo-featured-pro-cta p {
    max-width: 720px;
    margin: 0;
    color: #6f675c;
    font-size: 15px;
    font-weight: 650;
    line-height: 1.55;
}

.alo-featured-pro-cta__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.alo-featured-pro-cta__button {
    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;
    line-height: 1.15;
    text-align: center;
    text-decoration: none !important;
}

.alo-featured-pro-cta__button--primary {
    border-color: #276749;
    background: #276749;
    color: #ffffff !important;
    box-shadow: 0 8px 18px rgba(39, 103, 73, 0.16);
}

.alo-featured-pro-cta__button:hover,
.alo-featured-pro-cta__button:focus-visible {
    transform: translateY(-1px);
}

@media ( max-width: 767px ) {
    .alo-slider-section {
        padding: 24px 0 28px;
    }

    .alo-slider-section--blog {
        padding: 0;
    }

    .alo-global-sponsored {
        width: calc(100% - 24px);
        margin: 14px auto 26px;
    }

    .alo-global-sponsored .alo-slider-section {
        padding: 14px 0 16px;
    }

    .alo-archive .alo-global-sponsored--archive {
        width: 100%;
        margin: -12px auto 28px;
    }

    .alo-featured-pro-cta {
        grid-template-columns: 1fr;
        gap: 16px;
        padding: 18px;
    }

    .alo-featured-pro-cta__actions {
        justify-content: stretch;
    }

    .alo-featured-pro-cta__button {
        width: 100%;
    }
}

/* En-tête de section */

.alo-slider-section__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 16px;
    margin-bottom: 24px;
    padding: 0 2px;
}

.alo-slider-section__heading {
    min-width: 0;
}

.alo-slider-section__title {
    position: relative;
    display: inline-block;
    min-width: 0;
    max-width: min(760px, 100%);
    margin: 0;
    padding-bottom: 10px;
    color: #28241c;
    font-family: "Fraunces", "DM Sans", Georgia, serif !important;
    font-size: 25px;
    font-weight: 820;
    line-height: 1.02;
    letter-spacing: 0;
    text-wrap: balance;
}

.alo-slider-section__title .alo-slider-section__title-amp {
    display: inline-block;
    margin: 0 0.14em;
    color: #4b4338;
    font-family: "DM Sans", Arial, sans-serif !important;
    font-size: 0.8em;
    font-weight: 800;
    line-height: 1;
    transform: translateY(-0.03em);
}

.alo-slider-section__title::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 76px;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(183, 122, 24, 0.92), rgba(183, 122, 24, 0.24), rgba(183, 122, 24, 0));
}

.alo-slider-section__local-note {
    max-width: 520px;
    margin: 8px 0 0;
    color: #5f6f66;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 13px;
    font-weight: 750;
    line-height: 1.35;
    letter-spacing: 0;
}

/* On force le blanc avec une spécificité élevée pour contrer Astra */
.alo-slider-section .alo-slider-section__link,
.alo-slider-section .alo-slider-section__header .alo-slider-section__link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    font-weight: 800 !important;
    color: #ffffff !important;
    background-color: var(--alo-primary);
    box-shadow: var(--alo-shadow-green, 0 10px 24px rgba(39, 103, 73, 0.18));
    text-decoration: none !important;
    white-space: nowrap;
    flex-shrink: 0;
    padding: 8px 20px;
    border-radius: var(--alo-btn-radius, 20px);
    transition: background-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.alo-slider-section .alo-slider-section__link:hover {
    background-color: var(--alo-hover);
    color: #ffffff !important;
    text-decoration: none !important;
    transform: translateY(-1px);
    box-shadow: var(--alo-shadow-green-hover, 0 14px 32px rgba(39, 103, 73, 0.23));
}

@media ( max-width: 767px ) {
    .alo-slider-section__header {
        align-items: flex-end;
        gap: 12px;
        margin-bottom: 20px;
        padding: 0 20px;
    }

    .alo-slider-section__title {
        font-size: 22px;
        line-height: 1.04;
        padding-bottom: 9px;
    }

    .alo-slider-section__title::after {
        width: 58px;
    }

    .alo-slider-section .alo-slider-section__link,
    .alo-slider-section .alo-slider-section__header .alo-slider-section__link {
        padding: 8px 15px;
        font-size: 12px;
    }

    .alo-global-sponsored .alo-slider-section__header {
        padding-right: 0;
        padding-left: 0;
    }
}

/* ── Carousel ─────────────────────────────────────────────────────────────── */

.alo-carousel {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-behavior: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 15px;
    padding-top: 4px;
    padding-bottom: 22px;
    padding-right: 20px;
    transform: translate3d(0, 0, 0);
    transition: opacity 0.42s ease, transform 0.42s ease, filter 0.42s ease;
}

/* Scrollbar masquée sur tous les écrans */
.alo-carousel::-webkit-scrollbar { display: none; }
.alo-carousel { -ms-overflow-style: none; scrollbar-width: none; }

.alo-carousel-wrapper.is-sliding .alo-carousel,
.alo-carousel-wrapper.is-looping .alo-carousel {
    scroll-snap-type: none;
}

.alo-carousel-wrapper.is-looping .alo-carousel {
    opacity: 0.82;
    transform: translate3d(4px, 0, 0) scale(0.998);
    filter: saturate(0.98);
    pointer-events: none;
}

.alo-carousel-wrapper.is-settled .alo-carousel {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: none;
}

@media ( prefers-reduced-motion: reduce ) {
    .alo-carousel {
        transition: none;
    }

    .alo-carousel-wrapper.is-looping .alo-carousel,
    .alo-carousel-wrapper.is-settled .alo-carousel {
        opacity: 1;
        transform: none;
        filter: none;
    }
}

/* ── Wrapper + boutons de navigation ─────────────────────────────────────── */

.alo-carousel-wrapper {
    position: relative;
}

/* NOTE : Le dégradé blanc sur mobile a été supprimé ici */

.alo-nav-prev,
.alo-nav-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #ffffff;
    border: none;
    box-shadow: 0 4px 14px rgba(45, 37, 28, 0.14);
    cursor: pointer;
    display: none; /* Géré par JS */
    align-items: center;
    justify-content: center;
    color: var(--alo-text-muted);
    padding: 0;
    z-index: 10;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.alo-nav-prev:hover,
.alo-nav-next:hover {
    box-shadow: 0 8px 22px rgba(45, 37, 28, 0.18);
    color: var(--alo-primary);
    transform: translateY(-50%) scale(1.05);
}

.alo-nav-prev { left: 5px; }
.alo-nav-next { right: 5px; }

.alo-slider-section:not(.alo-slider-section--blog) .alo-nav-prev { left: -14px; }
.alo-slider-section:not(.alo-slider-section--blog) .alo-nav-next { right: -14px; }

.alo-nav-prev svg,
.alo-nav-next svg {
    width: 16px;
    height: 16px;
    display: block;
}

/* Affichées sur mobile avec un style adapté (si JS actif) */
@media ( max-width: 767px ) {
    .alo-nav-prev,
    .alo-nav-next {
        width: 32px;
        height: 32px;
        background: rgba(255, 255, 255, 0.95);
        box-shadow: 0 4px 14px rgba(45, 37, 28, 0.16);
    }
    .alo-nav-prev { left: 0px; }
    .alo-nav-next { right: 0px; }
    
    .alo-carousel {
        padding-left: 20px;
        padding-right: 20px;
    }
}

/* ── Carte ───────────────────────────────────────────────────────────────── */

.alo-card {
    display: flex;
    flex-direction: row !important;
    align-items: center;
    gap: 17px;
    min-height: 150px;
    background:
        linear-gradient(180deg, rgba(255, 254, 250, 0.98) 0%, rgba(255, 255, 255, 0.99) 100%),
        var(--alo-card-bg, #fffefa);
    border: 1px solid var(--alo-border-green-soft, rgba(39, 103, 73, 0.14));
    border-radius: 16px;
    padding: var(--alo-card-padding);
    box-shadow: var(--alo-shadow-sm, 0 1px 2px rgba(45, 37, 28, 0.035), 0 10px 24px rgba(45, 37, 28, 0.06));
    width: var(--alo-card-width);
    max-width: 85vw;
    flex-shrink: 0;
    scroll-snap-align: start;
    box-sizing: border-box;
    text-decoration: none;
    color: inherit;
    position: relative;
    isolation: isolate;
    overflow: hidden;
    transition: border-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease, opacity 0.2s ease, background 0.22s ease;
}

.alo-card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    border-radius: inherit;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.94);
}

@media ( max-width: 767px ) {
    .alo-card {
        width: var(--alo-card-width-mobile); /* Permet de voir l'amorce de la carte suivante */
        min-height: 142px;
        gap: 12px;
    }
    .alo-card__content {
        align-items: var(--alo-card-meta-align-mobile) !important;
    }
}

.alo-card:hover {
    border-color: rgba(39, 103, 73, 0.22);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, rgba(255, 253, 248, 1) 100%),
        var(--alo-card-bg, #fffefa);
    box-shadow: var(--alo-shadow-md, 0 2px 6px rgba(45, 37, 28, 0.045), 0 18px 44px rgba(45, 37, 28, 0.085));
    transform: translateY(-3px);
}

.alo-card:focus-within {
    outline: 3px solid rgba(39, 103, 73, 0.20);
    outline-offset: 3px;
}

.alo-card:active {
    transform: scale(0.98);
    opacity: 0.95;
}

/* ── Image ────────────────────────────────────────────────────────────────── */

.alo-card__image-link {
    display: block;
    position: relative;
    z-index: 1;
    flex-shrink: 0;
    width: clamp(118px, var(--alo-card-image-size), 132px);
    height: clamp(118px, var(--alo-card-image-size), 132px);
    border-radius: 12px;
    overflow: hidden;
    line-height: 0;
    background: #f0ebe3;
    box-shadow: inset 0 0 0 1px rgba(39, 103, 73, 0.08);
}

.alo-card__image-link::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    border: 1px solid rgba(255, 255, 255, 0.44);
    border-radius: inherit;
    box-shadow: inset 0 0 0 1px rgba(39, 103, 73, 0.07);
}

.alo-card__image {
    width: 100%;
    height: 100%;
    flex-shrink: 0;
    object-fit: cover;
    border-radius: inherit;
    display: block;
    filter: saturate(0.98) contrast(1.03);
    transition: filter 0.22s ease, transform 0.32s ease;
}

.alo-card:hover .alo-card__image {
    filter: saturate(1.08) contrast(1.05);
    transform: scale(1.045);
}

.alo-card__image--placeholder {
    width: 100%;
    height: 100%;
    flex-shrink: 0;
    border-radius: inherit;
    background-color: #e8e8e8;
    background-image: linear-gradient(135deg, #ececec 25%, #e0e0e0 100%);
}

/* ── Contenu ──────────────────────────────────────────────────────────────── */

.alo-card__content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 6px;
    min-width: 0;
    flex: 1;
    position: relative;
    z-index: 2;
}

/* ── Titre ────────────────────────────────────────────────────────────────── */

.alo-card__title {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 900;
    color: var(--alo-primary, #276749);
    line-height: 1.18;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    white-space: normal;
}

.alo-card__main-link::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 3;
}

.alo-card__title a {
    color: inherit;
    text-decoration: none;
    outline: none;
}

.alo-card__title a:hover,
.alo-card__title a:focus {
    color: #1f563b;
    text-decoration: none;
}

/* ── Meta (date / ville / catégorie) — Style Badge ─────────────────────── */

.alo-card__meta {
    display: grid;
    grid-template-columns: 14px minmax(0, 1fr);
    align-items: center;
    column-gap: 7px;
    min-height: 25px;
    font-size: min(var(--alo-card-meta-size, 13px), 13px);
    font-weight: 700;
    color: #4b463e;
    background: transparent;
    border: 0;
    padding: 3px 9px;
    border-radius: 0;
    line-height: 1.18;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    box-shadow: none;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.alo-card__title + .alo-card__meta {
    margin-top: 2px;
}

.alo-card__meta .alo-icon {
    justify-self: center;
}

.alo-card__meta span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

.alo-card__meta--date {
    grid-template-columns: 14px minmax(0, 1fr) auto;
    color: var(--alo-primary, #276749);
    background: rgba(39, 103, 73, 0.075);
    border: 1px solid rgba(39, 103, 73, 0.11);
    border-radius: 999px;
    padding: 3px 9px;
    font-weight: 850;
}

.alo-card__meta .alo-card__date-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 19px;
    padding: 0 7px;
    border-radius: 999px;
    background: #ffffff;
    color: #1f563b;
    font-size: 12px;
    font-weight: 950;
    line-height: 1;
    overflow: visible;
    text-overflow: clip;
    box-shadow: inset 0 0 0 1px rgba(39, 103, 73, 0.16);
}

.alo-card__meta--ville {
    color: #2f342e;
    background: var(--alo-page-bg, #f0eadf);
    border: 1px solid rgba(222, 212, 198, 0.72);
    border-radius: 999px;
    font-weight: 700;
}

.alo-card__meta--categorie {
    grid-template-columns: 12px minmax(0, 1fr) auto;
    align-self: flex-start;
    align-items: center;
    column-gap: 6px;
    width: fit-content;
    max-width: 100%;
    margin-top: 2px;
    color: #6f531b;
    background: rgba(255, 243, 214, 0.52);
    border: 1px solid rgba(169, 121, 36, 0.13);
    border-radius: 8px;
    padding: 4px 8px;
    font-size: 12px;
    font-weight: 850;
    line-height: 1.13;
    box-shadow: none;
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
}

.alo-card__meta--categorie .alo-icon {
    width: 12px;
    height: 12px;
    margin-top: 1px;
    opacity: 0.76;
}

.alo-card__meta--categorie span {
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
    word-break: normal;
    overflow-wrap: normal;
}

.alo-card__category-primary {
    min-width: 0;
    line-height: 1.15;
}

.alo-card__category-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    justify-self: end;
    align-self: center;
    min-width: 23px;
    height: 18px;
    padding: 0 6px;
    border-radius: 999px;
    background: rgba(39, 103, 73, 0.11);
    color: #276749;
    font-size: 10.5px;
    font-weight: 950;
    line-height: 1;
    white-space: nowrap;
}

@media ( max-width: 767px ) {
    .alo-card__meta--categorie {
        column-gap: 5px;
        padding: 4px 7px;
        border-radius: 7px;
        font-size: 11.75px;
        line-height: 1.13;
    }
}

/* ── Icônes SVG ───────────────────────────────────────────────────────────── */

.alo-icon {
    width: 13px;
    height: 13px;
    flex-shrink: 0;
    fill: currentColor;
    opacity: 0.78;
    vertical-align: middle;
}

/* ── Message vide ─────────────────────────────────────────────────────────── */

.alo-no-events {
    color: var(--alo-text-muted);
    font-size: 14px;
    text-align: center;
    padding: 20px 0;
}


/* ==========================================================================
   Grille archive
   ========================================================================== */

.alo-grid {
    display: grid;
    grid-template-columns: repeat(var(--alo-archive-columns), 1fr);
    gap: max(var(--alo-grid-gap), 24px);
}

/* Dans la grille : override largeur fixe + snap du carousel */
.alo-grid .alo-card {
    flex-direction: column !important;
    align-items: stretch;
    width: 100%;
    max-width: none;
    min-height: 100%;
    padding: 0;
    flex-shrink: 1;
    scroll-snap-align: none;
}

.alo-grid .alo-card::before {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.alo-grid .alo-card__image-link {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 10;
    border-radius: 0;
}

.alo-grid .alo-card__content {
    justify-content: flex-start;
    padding: 16px 16px 17px;
}

.alo-grid .alo-card__title {
    min-height: 2.52em;
    font-size: 18px;
}

.alo-grid .alo-card__meta {
    max-width: 100%;
}

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

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


/* ==========================================================================
   Page Archive
   ========================================================================== */

.alo-archive {
    padding: 40px 20px;
}

.alo-archive__inner {
    max-width: 1200px;
    margin: 0 auto;
}

.alo-archive__header {
    max-width: 760px;
    margin: 0 auto 30px;
    text-align: center;
}

.alo-archive__title {
    position: relative;
    display: inline-block;
    margin: 0;
    padding-bottom: 14px;
    color: #1f4f38;
    font-size: clamp(2.25rem, 4vw, 3.45rem) !important;
    font-weight: 900;
    line-height: 1.04;
    letter-spacing: 0;
    text-wrap: balance;
}

.alo-archive__title::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    width: min(190px, 44%);
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(169, 121, 36, 0), rgba(169, 121, 36, 0.78), rgba(169, 121, 36, 0));
    transform: translateX(-50%);
}

.alo-category-landing__actions,
.alo-event-category-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-top: 18px;
}

.alo-category-landing__actions a,
.alo-event-category-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 9px 15px;
    border: 1px solid rgba(39, 103, 73, 0.18);
    border-radius: 999px;
    background: #fffefa;
    color: var(--alo-primary, #276749);
    font-size: 13px;
    font-weight: 850;
    line-height: 1.2;
    text-decoration: none;
}

.alo-category-landing__actions a:hover,
.alo-category-landing__actions a:focus-visible,
.alo-event-category-links a:hover,
.alo-event-category-links a:focus-visible {
    border-color: rgba(39, 103, 73, 0.34);
    background: rgba(39, 103, 73, 0.07);
    color: #174d35;
}

.alo-category-landing__actions .alo-category-landing__primary {
    border-color: var(--alo-primary, #276749);
    background: var(--alo-primary, #276749);
    color: #ffffff;
}

.alo-category-landing__actions .alo-category-landing__primary:hover,
.alo-category-landing__actions .alo-category-landing__primary:focus-visible {
    background: #1f543a;
    color: #ffffff;
}

.alo-event-category-links {
    max-width: 1020px;
    margin: 0 auto 28px;
}

.alo-category-landing {
    max-width: 860px;
    margin: -12px auto 32px;
    padding: 22px 24px;
    border: 1px solid rgba(39, 103, 73, 0.13);
    border-radius: 8px;
    background: rgba(255, 254, 250, 0.82);
}

.alo-category-landing h2 {
    margin: 0 0 10px;
    color: #1f4f38;
    font-size: 1.25rem;
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: 0;
}

.alo-category-landing p {
    margin: 0;
    color: var(--alo-card-meta-color, #4b463e);
    font-size: 15px;
    line-height: 1.65;
}

.alo-category-landing p + p {
    margin-top: 8px;
}

@media ( max-width: 767px ) {
    .alo-archive {
        padding: 24px 15px;
    }

    .alo-archive__title {
        font-size: 2.15rem !important;
    }

    .alo-category-landing__actions a,
    .alo-event-category-links a {
        width: 100%;
    }

    .alo-category-landing {
        padding: 18px;
    }
}


/* ==========================================================================
   Page Single Événement
   ========================================================================== */

.alo-single {
    padding: 40px 20px;
}

.alo-single__container {
    max-width: 760px;
    margin: 0 auto;
}

.alo-single__top-back {
    display: flex;
    margin: 0 0 18px;
}

.alo-single__back-button {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 0 17px;
    border: 1px solid rgba(39, 103, 73, 0.2);
    border-radius: 999px;
    background: #fffdf8;
    box-shadow: 0 1px 2px rgba(45, 37, 28, 0.035), 0 10px 24px rgba(45, 37, 28, 0.06);
    color: var(--alo-primary, #276749);
    font-size: 14px;
    font-weight: 900;
    line-height: 1;
    text-decoration: none;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.alo-single__back-button:hover,
.alo-single__back-button:focus-visible {
    border-color: rgba(39, 103, 73, 0.34);
    background: #ffffff;
    box-shadow: 0 2px 6px rgba(45, 37, 28, 0.045), 0 16px 34px rgba(39, 103, 73, 0.13);
    color: #1f563b;
    transform: translateY(-1px);
    outline: none;
}

.alo-single__image-wrapper {
    border-radius: 12px;
    overflow: hidden;
    line-height: 0;
    margin-bottom: 28px;
    background-color: var(--alo-page-bg-strong, #ece2d2);
    text-align: center;
}

.alo-single__image {
    width: 100%;
    max-height: 70vh;
    object-fit: contain;
    height: auto;
    display: block;
    margin: 0 auto;
}

@media ( max-width: 767px ) {
    .alo-single__image-wrapper {
        max-height: 42vh;
    }

    .alo-single__image {
        height: min(42vh, 360px);
        max-height: none;
        object-fit: cover;
        object-position: center;
    }
}

/* Badge catégorie */
.alo-single__badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background-color: var(--alo-badge-bg);
    color: var(--alo-badge-color);
    font-size: 13px;
    font-weight: 600;
    padding: 5px 14px;
    border-radius: 20px;
    letter-spacing: 0.01em;
    width: fit-content;
    margin-bottom: 12px;
    text-decoration: none;
}

a.alo-single__badge:hover,
a.alo-single__badge:focus-visible {
    color: var(--alo-badge-color);
    background-color: rgba(39, 103, 73, 0.14);
}

.alo-single__category-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: -2px 0 14px;
}

.alo-single__category-list span,
.alo-single__category-list a {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 5px 10px;
    border: 1px solid rgba(39, 103, 73, 0.16);
    border-radius: 999px;
    background: rgba(39, 103, 73, 0.06);
    color: #276749;
    font-size: 12px;
    font-weight: 850;
    line-height: 1.2;
    text-decoration: none;
}

.alo-single__category-list a:hover,
.alo-single__category-list a:focus-visible {
    border-color: rgba(39, 103, 73, 0.34);
    background: rgba(39, 103, 73, 0.11);
    color: #174d35;
}

/* En-tête */
.alo-single__header {
    margin-bottom: 24px;
}

/* Titre */
.alo-single__title {
    margin: 0 0 16px;
    font-size: 28px;
    font-weight: 800;
    color: var(--alo-card-title-color);
    line-height: 1.25;
}

/* Metas */
.alo-single__metas {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.alo-single__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    color: var(--alo-card-meta-color);
    line-height: 1.4;
}

.alo-single__meta .alo-icon {
    width: 16px;
    height: 16px;
    opacity: 0.7;
    fill: var(--alo-primary);
    flex-shrink: 0;
}

/* Contenu éditorial */
.alo-single__content {
    font-size: 15px;
    line-height: 1.8;
    color: #444444;
    margin-bottom: 28px;
}

.alo-single__content p { margin-bottom: 1em; }

.alo-single__content a {
    color: var(--alo-primary);
    text-decoration: underline;
}

.alo-single__related-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: -6px 0 28px;
}

.alo-single__related-links a {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 8px 14px;
    border: 1px solid rgba(39, 103, 73, 0.18);
    border-radius: 999px;
    background: #fffefa;
    color: var(--alo-primary);
    font-size: 13px;
    font-weight: 850;
    line-height: 1.2;
    text-decoration: none;
}

.alo-single__related-links a:hover,
.alo-single__related-links a:focus-visible {
    border-color: rgba(39, 103, 73, 0.34);
    background: rgba(39, 103, 73, 0.07);
}

.alo-single__dates {
    margin: -4px 0 28px;
    padding: 18px 20px;
    border: 1px solid var(--alo-border-green-soft, rgba(39, 103, 73, 0.14));
    border-radius: 14px;
    background: rgba(39, 103, 73, 0.055);
}

.alo-single__dates h2 {
    margin: 0 0 12px;
    color: var(--alo-primary, #276749);
    font-size: 18px;
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: 0;
}

.alo-single__dates ul {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.alo-single__dates li {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: #ffffff;
    color: #2f342e;
    font-size: 14px;
    font-weight: 800;
    box-shadow: inset 0 0 0 1px rgba(39, 103, 73, 0.12);
}

/* CTA */
.alo-single__cta {
    margin-bottom: 28px;
}

/* Signalement public */
.alo-signalement {
    margin: 30px 0 22px;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
}

.alo-signalement__details {
    border-top: 1px solid rgba(222, 212, 198, 0.9);
    border-bottom: 1px solid rgba(222, 212, 198, 0.72);
    padding: 16px 0;
}

.alo-signalement__toggle {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 14px;
    border: 1px solid rgba(39, 103, 73, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--alo-primary, #276749);
    font-size: 14px;
    font-weight: 850;
    line-height: 1;
    cursor: pointer;
    list-style: none;
    transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.alo-signalement__toggle::-webkit-details-marker {
    display: none;
}

.alo-signalement__toggle:hover,
.alo-signalement__toggle:focus-visible {
    border-color: rgba(39, 103, 73, 0.28);
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(39, 103, 73, 0.1);
    outline: none;
}

.alo-signalement__panel {
    margin-top: 16px;
    padding: clamp(18px, 3vw, 24px);
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(255, 254, 250, 0.98), rgba(255, 255, 255, 0.98)),
        #ffffff;
    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-signalement__head {
    margin-bottom: 16px;
}

.alo-signalement__head h2 {
    margin: 0 0 5px;
    color: var(--alo-primary, #276749);
    font-size: 19px;
    font-weight: 920;
    line-height: 1.2;
    letter-spacing: 0;
}

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

.alo-signalement__event {
    display: grid;
    gap: 3px;
    margin: 0 0 18px;
    padding: 12px 14px;
    border: 1px solid var(--alo-border-green-soft, rgba(39, 103, 73, 0.14));
    border-radius: 12px;
    background: rgba(39, 103, 73, 0.055);
}

.alo-signalement__event span {
    color: var(--alo-muted-warm, #6f675c);
    font-size: 12px;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0;
}

.alo-signalement__event strong {
    color: #202018;
    font-size: 15px;
    font-weight: 850;
    line-height: 1.3;
}

.alo-signalement__feedback {
    margin: 0 0 16px;
    padding: 13px 15px;
    border-radius: 13px;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.45;
}

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

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

.alo-signalement-form {
    display: grid;
    gap: 16px;
}

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

.alo-signalement-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.alo-signalement-form__field label {
    display: block;
    margin: 0 0 7px;
    color: #2d342e;
    font-size: 13px;
    font-weight: 850;
    line-height: 1.25;
}

.alo-signalement-form__field label span:not(.required) {
    color: var(--alo-muted-warm, #6f675c);
    font-weight: 650;
}

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

.alo-signalement-form input[type="email"],
.alo-signalement-form input[type="file"],
.alo-signalement-form select,
.alo-signalement-form textarea {
    width: 100%;
    min-height: 48px;
    padding: 12px 14px;
    border: 1px solid var(--alo-border-medium, rgba(120, 92, 58, 0.22));
    border-radius: 13px;
    outline: none;
    background: #fffdf8;
    color: var(--alo-ink, #202018);
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 15px;
    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-signalement-form textarea {
    min-height: 122px;
    resize: vertical;
}

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

.alo-signalement-form input[type="file"]::file-selector-button {
    margin-right: 10px;
    padding: 9px 13px;
    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-signalement-form input:focus,
.alo-signalement-form select:focus,
.alo-signalement-form textarea:focus {
    border-color: var(--alo-primary, #276749);
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(39, 103, 73, 0.11);
}

.alo-signalement-form__actions {
    display: flex;
    justify-content: flex-start;
}

.alo-signalement-form button[type="submit"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 22px;
    border: 0;
    border-radius: 999px;
    background: var(--alo-primary, #276749);
    box-shadow: var(--alo-shadow-green, 0 10px 24px rgba(39, 103, 73, 0.18));
    color: #ffffff;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 15px;
    font-weight: 900;
    line-height: 1;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

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

/* Lien retour */
.alo-single__back {
    margin-top: 8px;
}

.alo-single__back-link {
    font-size: 14px;
    color: var(--alo-card-meta-color);
    text-decoration: none;
    transition: color 0.2s ease;
}

.alo-single__back-link:hover {
    color: var(--alo-primary);
}

@media ( max-width: 767px ) {
    .alo-single {
        padding: 24px 16px;
    }

    .alo-single__top-back {
        margin-bottom: 16px;
    }

    .alo-single__back-button {
        width: 100%;
        justify-content: center;
    }

    .alo-single__title {
        font-size: 22px;
    }

    .alo-signalement__panel {
        border-radius: 16px;
    }

    .alo-signalement-form__grid {
        grid-template-columns: 1fr;
    }

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


/* ==========================================================================
   Barre de filtres — Page archive
   ========================================================================== */

.alo-filter-bar {
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: #ffffff;
    border-radius: var(--alo-card-radius);
    padding: 18px 20px;
    box-shadow: var(--alo-card-shadow);
    margin-bottom: 32px;
}

.alo-filter-form {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: flex-end;
}

.alo-filter-group {
    display: flex;
    flex-direction: column;
    gap: 5px;
    flex: 1;
    min-width: 200px;
}

.alo-filter-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--alo-card-meta-color);
}

.alo-filter-select,
.alo-filter-date {
    width: 100%;
    padding: 10px 36px 10px 14px;
    border: 1.5px solid var(--alo-card-border-color);
    border-radius: 8px;
    font-size: 14px;
    font-family: inherit;
    color: var(--alo-text);
    background-color: #fff;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z' fill='%23999'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 11px;
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    box-sizing: border-box;
}

.alo-filter-date {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z' fill='%23999'/%3E%3C/svg%3E");
    cursor: pointer;
}

.alo-filter-select:focus,
.alo-filter-date:focus {
    outline: none;
    border-color: var(--alo-primary);
    box-shadow: 0 0 0 3px rgba(39, 103, 73, 0.12);
}

.alo-filter-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.alo-filter-submit {
    padding: 10px 20px;
    background-color: var(--alo-primary);
    color: #ffffff;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: background-color 0.2s ease;
    white-space: nowrap;
}

.alo-filter-submit:hover {
    background-color: var(--alo-hover);
}

.alo-filter-reset {
    font-size: 13px;
    color: var(--alo-card-meta-color);
    text-decoration: none;
    white-space: nowrap;
    transition: color 0.2s ease;
}

.alo-filter-reset:hover {
    color: var(--alo-primary);
    text-decoration: underline;
}

.alo-filter-active-info {
    font-size: 13px;
    color: var(--alo-primary);
    font-weight: 500;
    padding: 6px 14px;
    background: var(--alo-badge-bg);
    border-radius: 20px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: fit-content;
}

.alo-no-results {
    text-align: center;
    padding: 48px 20px;
    color: var(--alo-card-meta-color);
    font-size: 15px;
}

@media ( max-width: 600px ) {
    .alo-filter-form {
        flex-direction: column;
    }
    .alo-filter-group {
        min-width: 0;
        width: 100%;
    }
    .alo-filter-actions {
        width: 100%;
    }
    .alo-filter-submit {
        flex: 1;
        text-align: center;
    }
}


/* ==========================================================================
   Barre de recherche hero — Shortcode [alo_filtres_home]
   ========================================================================== */

.alo-filter-hero {
    display: flex;
    justify-content: center;
    width: 100%;
}

.alo-filter-hero__form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    width: 100%;
    max-width: 1040px;
    background: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: 20px;
    box-shadow: 0 10px 34px rgba(16, 31, 22, 0.16);
    padding: 14px;
    gap: 10px;
}

.alo-filter-hero__group--cat,
.alo-filter-hero__group--date,
.alo-filter-hero__group--ville {
    flex-basis: 180px;
}

.alo-filter-hero__group--search {
    flex: 1.4 1 260px;
    min-width: min(100%, 230px);
}

.alo-filter-hero__group--rayon {
    flex: 0 1 132px;
    min-width: 126px;
}

.alo-archive .alo-filter-hero {
    margin-bottom: 44px !important;
}

.alo-archive .alo-filter-hero__form {
    max-width: 1180px;
    background: #ffffff;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 18px;
    box-shadow: var(--alo-shadow-sm, 0 1px 2px rgba(45, 37, 28, 0.035), 0 10px 24px rgba(45, 37, 28, 0.06));
    padding: 12px;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.alo-archive .alo-filter-hero__group {
    background: #f8f2e8;
    border: 1px solid var(--alo-border-subtle, rgba(120, 92, 58, 0.14));
    border-radius: 12px;
}

.alo-archive .alo-filter-hero__group:hover,
.alo-archive .alo-filter-hero__group:focus-within {
    background: #fffdf9;
    border-color: var(--alo-border-medium, rgba(120, 92, 58, 0.22));
    box-shadow: var(--alo-shadow-xs, 0 1px 2px rgba(45, 37, 28, 0.035));
}

.alo-archive .alo-filter-hero__label {
    color: #1f4f38;
}

.alo-archive .alo-filter-hero__input,
.alo-archive .alo-filter-hero__select,
.alo-archive .alo-filter-hero__date {
    background-color: #ffffff !important;
    border-color: #e5dac9 !important;
}

.alo-archive .alo-filter-hero__btn {
    box-shadow: var(--alo-shadow-green, 0 10px 24px rgba(39, 103, 73, 0.18));
}

.alo-archive .alo-filter-hero__group--cat,
.alo-archive .alo-filter-hero__group--date,
.alo-archive .alo-filter-hero__group--ville {
    flex-basis: 190px;
    min-width: 190px;
}

.alo-archive .alo-filter-hero__group--search {
    flex: 1.35 1 250px;
    min-width: min(100%, 230px);
}

.alo-archive .alo-filter-hero__group--rayon {
    flex: 0 1 135px;
    min-width: 130px;
}

.alo-archive .alo-filter-hero__reset {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: stretch;
    padding: 0 16px;
    margin-left: auto;
    color: #6f675d;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    border-radius: 12px;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.alo-archive .alo-filter-hero__reset:hover,
.alo-archive .alo-filter-hero__reset:focus-visible {
    background: var(--alo-page-bg-strong, #ece2d2);
    color: var(--alo-primary, #276749);
    text-decoration: none;
}

/* Chaque groupe = chip blanche individuelle */
.alo-filter-hero__group {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
    min-width: 150px;
    padding: 14px 20px;
    background: rgba(255, 255, 255, 0.7);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.5);
    transition: all 0.3s ease;
}

.alo-filter-hero__group:hover,
.alo-filter-hero__group:focus-within {
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 4px 12px rgba(39, 103, 73, 0.05);
}

.alo-filter-hero__label {
    display: inline-flex;
    align-items: center;
    min-height: 16px;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.3;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--alo-primary, #276749);
    white-space: nowrap;
    overflow: visible;
}

.alo-filter-hero__select,
.alo-filter-hero__date,
.alo-filter-hero__input {
    border: 1.5px solid transparent;
    background-color: #ffffff !important; /* Forcer le fond blanc pour la lisibilité */
    border-radius: 8px; /* Petit arrondi pour le champ interne */
    font-size: 14px;
    font-family: inherit;
    line-height: 1.35;
    color: #111111;
    padding: 8px 12px; /* Plus d'espace interne */
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    width: 100%;
    outline: none;
    box-sizing: border-box;
    transition: all 0.2s ease;
}

.alo-filter-hero__group--search .alo-filter-hero__input {
    cursor: text;
}

.alo-filter-hero__select:focus,
.alo-filter-hero__date:focus,
.alo-filter-hero__input:focus {
    border-color: var(--alo-primary, #276749);
    box-shadow: 0 0 0 3px rgba(39, 103, 73, 0.1);
}

.alo-filter-hero__select,
select.alo-filter-hero__input {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z' fill='%23276749'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 11px;
    padding-right: 30px;
}

.alo-filter-hero__group--ville,
.alo-filter-hero__group--category-multi,
.alo-filter-hero__group:focus-within {
    position: relative;
}

.alo-filter-hero__group:focus-within {
    z-index: 25;
}

.alo-city-select--enhanced,
.alo-filter-select--enhanced {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    clip-path: inset(50%) !important;
    border: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.alo-city-combobox,
.alo-select-menu,
.alo-category-multiselect {
    position: relative;
    width: 100%;
}

.alo-select-menu__button,
.alo-category-multiselect__summary {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 40px;
    text-align: left;
    font-weight: 750;
    letter-spacing: 0;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset, 0 8px 18px rgba(45, 37, 28, 0.06);
}

.alo-category-multiselect__summary {
    list-style: none;
}

.alo-category-multiselect__summary::-webkit-details-marker {
    display: none;
}

.alo-select-menu__button::after,
.alo-category-multiselect__summary::after {
    content: "";
    flex: 0 0 auto;
    width: 10px;
    height: 10px;
    background-color: var(--alo-primary, #276749);
    transform: rotate(0deg);
    transition: transform 0.18s ease;
    -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4.1 6.2 8 10.1l3.9-3.9 1.1 1.1-5 5-5-5 1.1-1.1Z'/%3E%3C/svg%3E") center / contain no-repeat;
    mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4.1 6.2 8 10.1l3.9-3.9 1.1 1.1-5 5-5-5 1.1-1.1Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.alo-select-menu.is-open .alo-select-menu__button::after,
.alo-category-multiselect[open] .alo-category-multiselect__summary::after {
    transform: rotate(180deg);
}

.alo-select-menu__value,
.alo-category-multiselect__summary-text {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alo-city-combobox__input {
    cursor: text;
    padding-right: 34px;
}

.alo-city-combobox::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 12px;
    width: 14px;
    height: 14px;
    pointer-events: none;
    transform: translateY(-50%);
    background-color: var(--alo-primary, #276749);
    -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8.5 3a5.5 5.5 0 0 1 4.37 8.84l3.15 3.15a.73.73 0 0 1-1.03 1.03l-3.15-3.15A5.5 5.5 0 1 1 8.5 3Zm0 1.45a4.05 4.05 0 1 0 0 8.1 4.05 4.05 0 0 0 0-8.1Z'/%3E%3C/svg%3E") center / contain no-repeat;
    mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8.5 3a5.5 5.5 0 0 1 4.37 8.84l3.15 3.15a.73.73 0 0 1-1.03 1.03l-3.15-3.15A5.5 5.5 0 1 1 8.5 3Zm0 1.45a4.05 4.05 0 1 0 0 8.1 4.05 4.05 0 0 0 0-8.1Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.alo-city-combobox__list,
.alo-city-combobox__empty,
.alo-select-menu__list,
.alo-category-multiselect__panel {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    z-index: 40;
    margin: 0;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 253, 249, 0.98)),
        #ffffff;
    border: 1px solid rgba(120, 92, 58, 0.18);
    border-radius: 14px;
    box-shadow: 0 18px 42px rgba(38, 30, 21, 0.16), 0 2px 8px rgba(38, 30, 21, 0.05);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.alo-city-combobox__list,
.alo-select-menu__list,
.alo-category-multiselect__panel {
    max-height: 240px;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 6px !important;
    list-style: none;
}

.alo-city-combobox__list {
    max-height: min(360px, 52vh);
}

.alo-filter-hero__group--cat .alo-select-menu__list {
    min-width: min(280px, calc(100vw - 32px));
}

.alo-filter-hero__group--cat .alo-category-multiselect__panel {
    min-width: min(320px, calc(100vw - 32px));
}

.alo-filter-hero__group--ville .alo-city-combobox__list {
    min-width: min(250px, calc(100vw - 32px));
}

.alo-filter-hero__group--rayon .alo-select-menu__list {
    min-width: min(150px, calc(100vw - 32px));
}

.alo-city-combobox__list::-webkit-scrollbar,
.alo-select-menu__list::-webkit-scrollbar,
.alo-category-multiselect__panel::-webkit-scrollbar {
    width: 8px;
}

.alo-city-combobox__list::-webkit-scrollbar-track,
.alo-select-menu__list::-webkit-scrollbar-track,
.alo-category-multiselect__panel::-webkit-scrollbar-track {
    background: transparent;
}

.alo-city-combobox__list::-webkit-scrollbar-thumb,
.alo-select-menu__list::-webkit-scrollbar-thumb,
.alo-category-multiselect__panel::-webkit-scrollbar-thumb {
    background: rgba(39, 103, 73, 0.22);
    border: 2px solid rgba(255, 255, 255, 0.95);
    border-radius: 999px;
}

.alo-city-combobox__option,
.alo-select-menu__option {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    margin: 0;
    min-height: 38px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 34px 9px 12px;
    color: #2f2a24;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 650;
    line-height: 1.25;
    cursor: pointer;
    transition: background-color 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.alo-category-multiselect__choice {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    min-height: 40px;
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 9px 12px;
    color: #2f2a24;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 650;
    line-height: 1.25;
    cursor: pointer;
    transition: background-color 0.16s ease, color 0.16s ease;
}

.alo-category-multiselect__choice:hover,
.alo-category-multiselect__choice:focus-within {
    background: linear-gradient(135deg, rgba(245, 243, 239, 0.94), rgba(236, 226, 210, 0.82));
    color: var(--alo-primary, #276749);
}

.alo-category-multiselect__choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.alo-category-multiselect__box {
    position: relative;
    flex: 0 0 auto;
    width: 17px;
    height: 17px;
    border: 1.5px solid rgba(39, 103, 73, 0.38);
    border-radius: 5px;
    background: #ffffff;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
    transition: background-color 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.alo-category-multiselect__choice input:checked + .alo-category-multiselect__box {
    border-color: var(--alo-primary, #276749);
    background: var(--alo-primary, #276749);
}

.alo-category-multiselect__choice input:checked + .alo-category-multiselect__box::after {
    content: "";
    position: absolute;
    inset: 3px;
    background: #ffffff;
    -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7.7 14.4 3.8 10.5l1.2-1.2 2.7 2.7 7.2-7.2 1.2 1.2-8.4 8.4Z'/%3E%3C/svg%3E") center / contain no-repeat;
    mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7.7 14.4 3.8 10.5l1.2-1.2 2.7 2.7 7.2-7.2 1.2 1.2-8.4 8.4Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.alo-category-multiselect__choice input:focus-visible + .alo-category-multiselect__box {
    box-shadow: 0 0 0 3px rgba(39, 103, 73, 0.16);
}

.alo-category-multiselect__choice-label {
    min-width: 0;
}

.alo-category-multiselect__empty {
    margin: 0;
    padding: 11px 12px;
    color: #6f675d;
    font-size: 13px;
    font-weight: 650;
}

.alo-city-combobox__option:hover,
.alo-city-combobox__option.is-active,
.alo-select-menu__option:hover,
.alo-select-menu__option.is-active {
    background: linear-gradient(135deg, rgba(245, 243, 239, 0.94), rgba(236, 226, 210, 0.82));
    color: var(--alo-primary, #276749);
}

.alo-select-menu__option.is-selected {
    color: var(--alo-primary, #276749);
    font-weight: 800;
}

.alo-select-menu__option.is-selected::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 12px;
    width: 14px;
    height: 14px;
    background-color: var(--alo-primary, #276749);
    transform: translateY(-50%);
    -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7.7 14.4 3.8 10.5l1.2-1.2 2.7 2.7 7.2-7.2 1.2 1.2-8.4 8.4Z'/%3E%3C/svg%3E") center / contain no-repeat;
    mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7.7 14.4 3.8 10.5l1.2-1.2 2.7 2.7 7.2-7.2 1.2 1.2-8.4 8.4Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.alo-city-combobox__empty {
    padding: 11px 12px;
    color: #6f675d;
    font-size: 13px;
    font-weight: 650;
}

@media ( max-width: 640px ) {
    .alo-filter-hero .alo-city-combobox__list,
    .alo-filter-hero .alo-city-combobox__empty,
    .alo-filter-hero .alo-select-menu__list,
    .alo-filter-hero .alo-category-multiselect__panel {
        position: static;
        width: 100%;
        min-width: 0;
        max-height: 220px;
        margin-top: 8px;
    }

    .alo-filter-hero .alo-city-combobox__list {
        max-height: min(320px, 48vh);
    }

    .alo-city-combobox__option,
    .alo-select-menu__option {
        min-height: 42px;
        padding-top: 10px;
        padding-bottom: 10px;
    }
}

.alo-filter-hero__date::placeholder {
    color: #888888;
}

.alo-filter-hero__btn {
    background-color: var(--alo-primary);
    color: #ffffff !important; /* Force le texte blanc */
    border: none;
    border-radius: 12px;
    padding: 14px 24px;
    font-size: 15px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.3s ease;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    align-self: stretch;
    display: flex;
    align-items: center;
}

.alo-filter-hero__btn:hover {
    background-color: var(--alo-primary) !important;
    transform: scale(1.05);
    box-shadow: 0 4px 15px rgba(39, 103, 73, 0.2);
}

@media ( max-width: 640px ) {
    .alo-filter-hero__form {
        flex-direction: column;
        padding: 10px;
        gap: 8px;
    }
    .alo-filter-hero__group {
        flex: 0 1 auto;
        flex-basis: auto;
        min-width: 0;
        width: 100%;
    }
    .alo-filter-hero__group--cat,
    .alo-filter-hero__group--date,
    .alo-filter-hero__group--ville,
    .alo-filter-hero__group--search,
    .alo-filter-hero__group--rayon {
        flex: 0 1 auto;
        flex-basis: auto;
        min-width: 0;
        min-height: 0;
    }
    .alo-archive .alo-filter-hero__group,
    .alo-archive .alo-filter-hero__group--cat,
    .alo-archive .alo-filter-hero__group--date,
    .alo-archive .alo-filter-hero__group--ville,
    .alo-archive .alo-filter-hero__group--search,
    .alo-archive .alo-filter-hero__group--rayon {
        flex: 0 1 auto;
        flex-basis: auto;
        min-height: 0;
        padding: 12px 14px;
    }
    .alo-filter-hero__btn {
        width: 100%;
        justify-content: center;
        border-radius: 10px;
        padding: 14px;
    }
    .alo-archive .alo-filter-hero__group--rayon {
        flex: 0 1 auto;
        min-width: 0;
    }
    .alo-archive .alo-filter-hero__reset {
        width: 100%;
        min-height: 44px;
        margin-left: 0;
    }
}


/* ==========================================================================
   Flatpickr — overrides visuels ALO
   ========================================================================== */

.flatpickr-calendar {
    font-family: inherit;
    overflow: hidden;
    border: 1px solid rgba(120, 92, 58, 0.18);
    border-radius: 14px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(255, 253, 249, 0.99)),
        #ffffff;
    box-shadow: 0 18px 42px rgba(38, 30, 21, 0.16), 0 2px 8px rgba(38, 30, 21, 0.05);
}

.flatpickr-months,
.flatpickr-weekdays {
    background: #fffdf9;
}

.flatpickr-months .flatpickr-month,
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
    color: var(--alo-primary, #276749);
    font-weight: 800;
}

.flatpickr-weekday {
    color: #6f675d !important;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.flatpickr-day {
    border-radius: 8px;
    font-weight: 650;
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
    background: var(--alo-primary);
    border-color: var(--alo-primary);
    color: #ffffff;
}

.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover {
    background: var(--alo-hover);
    border-color: var(--alo-hover);
}

.flatpickr-day.inRange {
    background: var(--alo-badge-bg);
    border-color: var(--alo-badge-bg);
    box-shadow: -5px 0 0 var(--alo-badge-bg), 5px 0 0 var(--alo-badge-bg);
    color: var(--alo-primary);
}

.flatpickr-day:hover:not(.selected):not(.startRange):not(.endRange) {
    background: var(--alo-badge-bg);
    border-color: transparent;
}

.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
    fill: var(--alo-primary);
}

.flatpickr-current-month .numInputWrapper span.arrowUp:after {
    border-bottom-color: var(--alo-primary);
}
.flatpickr-current-month .numInputWrapper span.arrowDown:after {
    border-top-color: var(--alo-primary);
}

/* Input altInput stylé comme les filtres */
.alo-filter-select ~ .flatpickr-input.flatpickr-input,
input.flatpickr-input.alo-filter-date,
.alo-datepicker.alo-filter-date + .flatpickr-input {
    background: transparent;
}


/* ==========================================================================
   Bouton CTA principal
   ========================================================================== */

.alo-final-button {
    display: inline-block;
    background-color: var(--alo-primary);
    color: #ffffff !important;
    font-size: 16px;
    font-weight: 800 !important;
    font-family: inherit;
    line-height: 1.4;
    padding: 14px 30px;
    border-radius: var(--alo-radius);
    text-decoration: none !important;
    transition: background-color 0.3s ease;
}

.alo-final-button:hover,
.alo-final-button:focus {
    background-color: var(--alo-hover);
    color: #ffffff !important;
    text-decoration: none !important;
}


/* ==========================================================================
   Formulaire Brevo — overrides globaux (pop-up et blocs embarqués)
   ========================================================================== */

/* ── Centrage et largeur ─────────────────────────────────────────────────── */

.sib-form,
.sib-container,
.sib-form .sib-form-block,
.sib-form .sib-form-block__button,
.sib-form .entry__field,
.sib-form p {
    width: 100% !important;
    text-align: center !important;
    box-sizing: border-box !important;
}

/* ── Champ email ─────────────────────────────────────────────────────────── */

.sib-form input[type="email"],
.sib-form input[type="text"] {
    width: 100% !important;
    padding: 12px 16px !important;
    border-radius: var(--alo-radius) !important;
    border: 1.5px solid rgba(39, 103, 73, 0.2) !important;
    font-size: 15px !important;
    font-family: inherit !important;
    box-sizing: border-box !important;
    outline: none !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    background-color: rgba(245, 243, 239, 0.5) !important;
}

.sib-form input[type="email"]:focus,
.sib-form input[type="text"]:focus {
    border-color: var(--alo-primary) !important;
    box-shadow: 0 0 0 3px rgba(39, 103, 73, 0.15) !important;
    background-color: #ffffff !important;
}

/* ── Bouton de validation ────────────────────────────────────────────────── */

.sib-default-btn,
.sib-btn-primary,
.sib-form input[type="submit"],
.sib-form button[type="submit"] {
    display: block !important;
    margin: 25px auto 0 !important;
    background-color: var(--alo-primary) !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    font-family: inherit !important;
    font-size: 16px !important;
    border: none !important;
    border-radius: var(--alo-radius) !important;
    padding: 15px 40px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    text-decoration: none !important;
}


.sib-default-btn:hover,
.sib-default-btn:focus,
.sib-btn-primary:hover,
.sib-btn-primary:focus,
.sib-form input[type="submit"]:hover,
.sib-form input[type="submit"]:focus,
.sib-form button[type="submit"]:hover,
.sib-form button[type="submit"]:focus {
    background-color: var(--alo-hover) !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 16px rgba(39, 103, 73, 0.25) !important;
}

/* ── Texte du conteneur pop-up ───────────────────────────────────────────── */

.sib-container p {
    color: var(--alo-text, #111111) !important;
    font-weight: 500 !important;
}

/* ── Skeleton Screen & Placeholder Animation ────────────────────────────── */

@keyframes alo-skeleton-loading {
    0% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

.alo-card__image--placeholder,
.alo-single__image-wrapper {
    background: linear-gradient(90deg, #f0ede9 25%, #f9f8f6 50%, #f0ede9 75%);
    background-size: 400% 100%;
    animation: alo-skeleton-loading 1.5s infinite;
}

.alo-card__image.loaded,
.alo-single__image.loaded {
    animation: alo-fade-in 0.6s ease forwards;
}

@keyframes alo-fade-in {
    from { opacity: 0; transform: scale(0.98); filter: blur(10px); }
    to { opacity: 1; transform: scale(1); filter: blur(0); }
}

/* ── Pagination archive ────────────────────────────────────────────────── */
.alo-pagination {
    margin: 34px auto 0;
}

.alo-pagination .page-numbers {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.alo-pagination .page-numbers li {
    margin: 0;
}

.alo-pagination .page-numbers a,
.alo-pagination .page-numbers span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    min-height: 42px;
    padding: 0 14px;
    border: 1px solid rgba(39, 103, 73, 0.18);
    border-radius: 999px;
    background: #ffffff;
    color: var(--alo-primary, #276749);
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 14px;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
    box-shadow: 0 8px 22px rgba(45, 37, 28, 0.055);
}

.alo-pagination .page-numbers .current {
    background: var(--alo-primary, #276749);
    border-color: var(--alo-primary, #276749);
    color: #ffffff;
}

.alo-pagination .page-numbers a:hover,
.alo-pagination .page-numbers a:focus-visible {
    border-color: var(--alo-primary, #276749);
    background: #eef3ed;
    color: var(--alo-primary, #276749);
}

/* ── Message Aucun Résultat ── */
.alo-no-results .alo-filter-submit {
    display: inline-block !important;
    margin-top: 15px;
    color: #ffffff !important;
    font-weight: 800 !important;
    background-color: var(--alo-primary);
    padding: 12px 24px;
    border-radius: 10px;
    text-decoration: none;
    font-size: 15px;
    transition: background-color 0.2s ease;
}

.alo-no-results .alo-filter-submit:hover {
    background-color: var(--alo-hover);
}

/* ── Unification des inputs Hero Filter ── */
.alo-filter-hero__select,
.alo-filter-hero__date,
.alo-filter-hero__input {
    border: 1.5px solid #e2e8f0 !important; /* Bordure visible par défaut */
    background-color: #ffffff !important;
    border-radius: 8px;
    font-size: 14px;
    font-family: var(--alo-font-main), sans-serif !important;
    line-height: 1.35 !important;
    color: #111111 !important;
    padding: 9px 14px;
    height: 42px; /* Hauteur fixe pour alignement parfait */
    box-sizing: border-box;
}

/* ── Micro-animations Filtres ───────────────────────────────────────────── */

.alo-filter-hero__group:hover .alo-filter-hero__label {
    transform: translateX(4px);
    transition: transform 0.3s ease;
}

body.home .alo-filter-hero {
    margin-top: 0 !important;
}

body.home .alo-filter-hero__form {
    align-items: stretch !important;
    max-width: min(1080px, 100%) !important;
    padding: 12px !important;
    gap: 10px !important;
    border: 1px solid rgba(255, 255, 255, 0.36) !important;
    border-radius: 18px !important;
    background: rgba(245, 243, 239, 0.22) !important;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
    font-family: "DM Sans", sans-serif !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
}

body.home .alo-filter-hero__group {
    min-width: 152px !important;
    padding: 13px 18px !important;
    gap: 6px !important;
    border: 1px solid rgba(255, 255, 255, 0.58) !important;
    border-radius: 10px !important;
    background: rgba(255, 254, 250, 0.86) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.42) !important;
}

body.home .alo-filter-hero__group:hover,
body.home .alo-filter-hero__group:focus-within {
    background: rgba(255, 254, 250, 0.96) !important;
    border-color: rgba(255, 255, 255, 0.76) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.48), 0 8px 22px rgba(0, 0, 0, 0.08) !important;
}

body.home .alo-filter-hero__group--cat,
body.home .alo-filter-hero__group--date,
body.home .alo-filter-hero__group--ville {
    flex-basis: 190px !important;
}

body.home .alo-filter-hero__group--rayon {
    flex: 0 1 138px !important;
    min-width: 132px !important;
}

body.home .alo-filter-hero__label {
    min-height: 17px !important;
    color: #1f5b3f !important;
    font-weight: 900 !important;
    line-height: 1.3 !important;
    letter-spacing: 0 !important;
}

body.home .alo-filter-hero__select,
body.home .alo-filter-hero__date,
body.home .alo-filter-hero__input {
    height: 42px !important;
    min-height: 42px !important;
    border: 1px solid rgba(213, 223, 216, 0.95) !important;
    border-radius: 8px !important;
    color: #17231d !important;
    font-family: "DM Sans", sans-serif !important;
    font-weight: 650 !important;
    line-height: 1.35 !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
}

body.home .alo-filter-hero__btn {
    min-width: 148px !important;
    justify-content: center !important;
    padding: 0 24px !important;
    border-radius: 12px !important;
    font-family: "DM Sans", sans-serif !important;
    font-weight: 900 !important;
    box-shadow: 0 14px 30px rgba(16, 31, 22, 0.18) !important;
}

body.home .alo-filter-hero__btn:hover,
body.home .alo-filter-hero__btn:focus-visible {
    transform: translateY(-1px) !important;
    box-shadow: 0 18px 38px rgba(16, 31, 22, 0.24) !important;
}

@media ( max-width: 767px ) {
    body.home .alo-filter-hero__form {
        width: min(100%, 360px) !important;
        padding: 10px !important;
        gap: 8px !important;
        border-radius: 16px !important;
        background: rgba(245, 243, 239, 0.26) !important;
    }

    body.home .alo-filter-hero__group,
    body.home .alo-filter-hero__group--cat,
    body.home .alo-filter-hero__group--date,
    body.home .alo-filter-hero__group--ville,
    body.home .alo-filter-hero__group--rayon {
        flex: 0 1 auto !important;
        flex-basis: auto !important;
        min-width: 0 !important;
        min-height: 0 !important;
        width: 100% !important;
        padding: 11px 13px !important;
        border-radius: 10px !important;
    }

    body.home .alo-filter-hero__label {
        font-size: 10.5px !important;
        min-height: 16px !important;
        line-height: 1.32 !important;
    }

    body.home .alo-filter-hero__select,
    body.home .alo-filter-hero__date,
    body.home .alo-filter-hero__input {
        height: 42px !important;
        min-height: 42px !important;
        padding: 8px 12px !important;
        font-size: 14px !important;
        line-height: 1.35 !important;
    }

    body.home .alo-filter-hero__btn {
        min-height: 44px !important;
        padding: 13px 14px !important;
    }
}

@media ( max-width: 767px ) {
    .sib-default-btn,
    .sib-btn-primary,
    .sib-form input[type="submit"],
    .sib-form button[type="submit"],
    .sib-form input[type="email"],
    .sib-form input[type="text"] {
        width: 100% !important;
        padding: 15px 20px !important;
    }

    .sib-form,
    .sib-container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    .pum-container {
        padding: 25px !important;
    }
}

/* ─────────────────────────────────────────
   Bons Plans
   ───────────────────────────────────────── */

.alo-bon-plan {
    background: var(--alo-page-bg-strong, #ece2d2);
}

.alo-bon-plan__header {
    max-width: 820px;
    margin-right: auto;
    margin-left: auto;
}

.alo-bon-plan__eyebrow {
    margin: 0 0 10px;
    color: #8a5a16;
    font-family: var(--alo-font-main);
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.alo-bon-plan__intro {
    max-width: 680px;
    margin: 14px auto 0;
    color: var(--alo-text-muted, #666666);
    font-family: var(--alo-font-main);
    font-size: 17px;
    line-height: 1.65;
}

.alo-bon-plan__filters {
    margin-bottom: 36px;
}

.alo-bp-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 360px));
    justify-content: center;
    gap: 22px;
}

.alo-bp-card {
    display: flex;
    min-width: 0;
    overflow: hidden;
    flex-direction: column;
    border: 1px solid var(--alo-border-green-soft, rgba(39, 103, 73, 0.14));
    border-radius: 8px;
    background: #fffefa;
    box-shadow: var(--alo-card-shadow);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.alo-bp-card:hover,
.alo-bp-card:focus-within {
    border-color: rgba(39, 103, 73, 0.24);
    box-shadow: var(--alo-card-hover-shadow);
    transform: translateY(-2px);
}

.alo-bp-card__media,
.alo-bp-single__media {
    display: block;
    overflow: hidden;
    background: #eef3ed;
}

.alo-bp-card__media {
    aspect-ratio: 16 / 10;
}

.alo-bp-media__image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.alo-bp-media__fallback {
    display: flex;
    width: 100%;
    height: 100%;
    min-height: 180px;
    align-items: center;
    justify-content: center;
    border-bottom: 1px solid rgba(39, 103, 73, 0.12);
    background: #eef3ed;
    color: var(--alo-primary, #276749);
    font-family: var(--alo-font-heading);
    font-size: 34px;
    font-weight: 900;
}

.alo-bp-card__body {
    display: flex;
    min-height: 300px;
    flex: 1;
    flex-direction: column;
    gap: 12px;
    padding: 18px;
}

.alo-bp-card__deal {
    align-self: flex-start;
    margin: 0;
    padding: 7px 11px;
    border: 1px solid rgba(138, 90, 22, 0.22);
    border-radius: 999px;
    background: #fff3d6;
    color: #6b4e13;
    font-family: var(--alo-font-main);
    font-size: 13px;
    font-weight: 900;
    line-height: 1.2;
}

.alo-bp-card__title {
    margin: 0;
    color: var(--alo-primary, #276749);
    font-family: var(--alo-font-heading);
    font-size: 22px;
    font-weight: 900;
    line-height: 1.16;
    letter-spacing: 0;
}

.alo-bp-card__title a {
    color: inherit;
    text-decoration: none;
}

.alo-bp-card__title a:hover,
.alo-bp-card__title a:focus-visible {
    color: var(--alo-hover, #38a169);
}

.alo-bp-card__metas {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    color: var(--alo-card-meta-color, #4b463e);
    font-family: var(--alo-font-main);
    font-size: 13px;
    font-weight: 800;
}

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

.alo-bp-card__metas .alo-icon {
    width: 14px;
    height: 14px;
}

.alo-bp-card__excerpt {
    margin: 0;
    color: var(--alo-text-muted, #666666);
    font-family: var(--alo-font-main);
    font-size: 15px;
    line-height: 1.55;
}

.alo-bp-card__button {
    display: inline-flex;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    margin-top: auto;
    padding: 10px 16px;
    border-radius: var(--alo-btn-radius, 50px);
    background: var(--alo-primary, #276749);
    color: #ffffff !important;
    font-family: var(--alo-font-main);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.2;
    text-decoration: none;
}

.alo-bp-card__button:hover,
.alo-bp-card__button:focus-visible {
    background: var(--alo-hover, #38a169);
    color: #ffffff !important;
}

.alo-bp-empty {
    margin-bottom: 32px;
}

.alo-bp-empty__button {
    display: inline-flex;
    margin-top: 12px;
    color: #ffffff !important;
    text-decoration: none;
}

.alo-bp-pro-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin-top: 44px;
    padding: 26px;
    border-radius: 8px;
    background: var(--alo-primary, #276749);
    color: #ffffff;
}

.alo-bp-pro-cta__content {
    max-width: 700px;
}

.alo-bp-pro-cta__eyebrow {
    margin: 0 0 7px;
    color: #f7d98b;
    font-family: var(--alo-font-main);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.alo-bp-pro-cta h2 {
    margin: 0;
    color: #ffffff;
    font-family: var(--alo-font-heading);
    font-size: 28px;
    font-weight: 900;
    line-height: 1.15;
    letter-spacing: 0;
}

.alo-bp-pro-cta p {
    margin: 8px 0 0;
    color: rgba(255, 255, 255, 0.86);
    font-family: var(--alo-font-main);
    font-size: 15px;
    line-height: 1.55;
}

.alo-bp-pro-cta__button {
    display: inline-flex;
    min-height: 46px;
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
    padding: 12px 18px;
    border-radius: var(--alo-btn-radius, 50px);
    background: #ffffff;
    color: var(--alo-primary, #276749) !important;
    font-family: var(--alo-font-main);
    font-size: 14px;
    font-weight: 900;
    text-decoration: none;
}

.alo-bp-pro-cta__button:hover,
.alo-bp-pro-cta__button:focus-visible {
    background: #fff3d6;
    color: #1f513a !important;
}

.alo-bp-single__container {
    max-width: 1180px;
}

.alo-bp-single__top-back {
    margin-bottom: 20px;
}

.alo-bp-single__hero {
    margin-bottom: 24px;
}

.alo-bp-single__hero-content {
    max-width: 920px;
}

.alo-bp-single__badge {
    margin-bottom: 14px;
}

.alo-bp-single__title {
    margin-bottom: 14px;
}

.alo-bp-single__deal {
    position: relative;
    overflow: hidden;
    padding: 20px 18px 19px 20px;
    border: 1px solid rgba(39, 103, 73, 0.16);
    border-left: 4px solid #d6a03d;
    border-radius: 8px;
    background: #fffefa;
    box-shadow: 0 12px 28px rgba(39, 103, 73, 0.08);
}

.alo-bp-single__deal-label {
    display: inline-flex;
    margin: 0 0 10px;
    color: #8a5a16;
    font-family: var(--alo-font-main);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.alo-bp-single__deal-value {
    margin: 0;
    color: var(--alo-primary, #276749);
    font-family: var(--alo-font-heading);
    font-size: 26px;
    font-weight: 900;
    line-height: 1.16;
    letter-spacing: 0;
}

.alo-bp-single__media {
    aspect-ratio: 16 / 7;
    margin-bottom: 30px;
    border-radius: 8px;
}

.alo-bp-single__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 32px;
    align-items: start;
}

.alo-bp-single__content {
    color: var(--alo-text, #111111);
}

.alo-bp-single__content > *:first-child {
    margin-top: 0;
}

.alo-bp-single__aside {
    display: grid;
    gap: 14px;
}

.alo-bp-info {
    padding: 18px;
    border: 1px solid rgba(39, 103, 73, 0.14);
    border-radius: 8px;
    background: #fffefa;
}

.alo-bp-info.alo-bp-single__deal {
    border-color: rgba(39, 103, 73, 0.18);
    border-left-color: #d6a03d;
    background: #ffffff;
}

.alo-bp-info h2 {
    margin: 0 0 8px;
    color: var(--alo-primary, #276749);
    font-family: var(--alo-font-heading);
    font-size: 18px;
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: 0;
}

.alo-bp-info p {
    margin: 0;
    color: var(--alo-text-muted, #666666);
    font-family: var(--alo-font-main);
    font-size: 15px;
    line-height: 1.6;
}

.alo-bp-info .alo-bp-single__deal-label {
    display: inline-flex;
    margin: 0 0 10px;
    color: #8a5a16;
    font-family: var(--alo-font-main);
    font-size: 12px;
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: 0;
    text-transform: uppercase;
}

.alo-bp-info .alo-bp-single__deal-value {
    margin: 0;
    color: var(--alo-primary, #276749);
    font-family: var(--alo-font-heading);
    font-size: 26px;
    font-weight: 900;
    line-height: 1.16;
    letter-spacing: 0;
}

.alo-bp-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}

.alo-bp-links a {
    display: inline-flex;
    min-height: 38px;
    align-items: center;
    padding: 8px 12px;
    border: 1px solid rgba(39, 103, 73, 0.16);
    border-radius: 999px;
    background: #ffffff;
    color: var(--alo-primary, #276749);
    font-family: var(--alo-font-main);
    font-size: 13px;
    font-weight: 900;
    text-decoration: none;
}

.alo-bp-links a:hover,
.alo-bp-links a:focus-visible {
    border-color: var(--alo-primary, #276749);
    background: #eef3ed;
    color: var(--alo-primary, #276749);
}

.alo-bp-single__back {
    margin-top: 30px;
}

@media (max-width: 900px) {
    .alo-bp-single__layout {
        grid-template-columns: 1fr;
    }

    .alo-bp-pro-cta {
        align-items: flex-start;
        flex-direction: column;
    }

    .alo-bp-pro-cta__button {
        width: 100%;
    }

    .alo-bp-single__media {
        aspect-ratio: 4 / 3;
    }
}

@media (max-width: 640px) {
    .alo-bon-plan__intro {
        font-size: 15px;
    }

    .alo-bp-card__body {
        min-height: 260px;
        padding: 16px;
    }

    .alo-bp-card__title {
        font-size: 20px;
    }

    .alo-bp-pro-cta {
        padding: 20px;
    }

    .alo-bp-pro-cta h2 {
        font-size: 24px;
    }

    .alo-bp-info .alo-bp-single__deal-value {
        font-size: 24px;
    }
}

/* ─────────────────────────────────────────
   Localisation douce de la home
   ───────────────────────────────────────── */

html.alo-local-modal-is-open {
    overflow: hidden;
}

body.home .alo-local-pill {
    position: fixed;
    left: 18px;
    right: auto;
    bottom: 18px;
    z-index: 1002;
    display: inline-flex;
    max-width: min(360px, calc(100vw - 36px));
    min-height: 44px;
    align-items: center;
    justify-content: center;
    padding: 11px 16px;
    border: 1px solid rgba(39, 103, 73, 0.18);
    border-radius: 999px;
    background: #fffefa;
    color: var(--alo-primary, #276749);
    box-shadow: 0 16px 42px rgba(23, 35, 29, 0.16);
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 13px;
    font-weight: 900;
    line-height: 1.15;
    letter-spacing: 0;
    text-align: center;
    cursor: pointer;
}

body.home .alo-local-pill:hover,
body.home .alo-local-pill:focus-visible {
    background: #f5f3ef;
    color: #1f513a;
    outline: 3px solid rgba(39, 103, 73, 0.22);
    outline-offset: 3px;
}

.alo-local-modal[hidden] {
    display: none !important;
}

.alo-local-modal {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: grid;
    place-items: center;
    padding: 20px;
}

.alo-local-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 31, 22, 0.48);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.alo-local-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(480px, 100%);
    max-height: min(720px, calc(100vh - 40px));
    padding: 24px;
    overflow: auto;
    border: 1px solid rgba(39, 103, 73, 0.16);
    border-radius: 8px;
    background: #fffefa;
    box-shadow: 0 30px 90px rgba(16, 31, 22, 0.26);
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
}

.alo-local-modal__dialog:focus {
    outline: none;
}

.alo-local-modal__close {
    position: absolute;
    top: 12px;
    right: 12px;
    display: inline-flex;
    width: 36px;
    height: 36px;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(39, 103, 73, 0.14);
    border-radius: 999px;
    background: #ffffff;
    color: #26372f;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
}

.alo-local-modal__close:hover,
.alo-local-modal__close:focus-visible {
    background: #eef3ed;
    color: var(--alo-primary, #276749);
    outline: 3px solid rgba(39, 103, 73, 0.18);
    outline-offset: 2px;
}

.alo-local-modal__eyebrow {
    margin: 0 0 8px;
    color: #8a5a16;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.alo-local-modal h2 {
    margin: 0 40px 10px 0;
    color: var(--alo-primary, #276749);
    font-family: var(--alo-font-heading, "DM Sans", sans-serif);
    font-size: 26px;
    font-weight: 900;
    line-height: 1.1;
    letter-spacing: 0;
}

.alo-local-modal__intro {
    margin: 0;
}

.alo-local-modal p {
    color: #5f6f66;
    font-size: 15px;
    line-height: 1.5;
}

.alo-local-modal .alo-local-modal__eyebrow {
    color: #8a5a16;
}

.alo-local-modal__form {
    display: grid;
    gap: 12px;
    margin-top: 16px;
}

.alo-local-modal__field {
    display: grid;
    gap: 7px;
}

.alo-local-modal__field > label,
.alo-local-modal__field-label {
    color: #1f513a;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.alo-local-modal__geo-panel {
    display: grid;
    gap: 8px;
    padding: 12px;
    border: 1px solid rgba(39, 103, 73, 0.14);
    border-radius: 8px;
    background: #f8f6f1;
}

.alo-local-modal__privacy {
    margin: 0;
    color: #66756c;
    font-size: 12.5px;
    font-weight: 700;
}

.alo-local-modal__combobox {
    position: relative;
}

.alo-local-modal__city-search {
    width: 100%;
    min-height: 46px;
    padding: 10px 13px;
    border: 1px solid rgba(39, 103, 73, 0.18);
    border-radius: 8px;
    background: #ffffff;
    color: #17231d;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 15px;
    font-weight: 750;
}

.alo-local-modal__city-search:focus-visible {
    border-color: var(--alo-primary, #276749);
    outline: 3px solid rgba(39, 103, 73, 0.18);
    outline-offset: 2px;
}

.alo-local-modal__city-results {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    z-index: 2;
    max-height: 210px;
    margin: 0;
    padding: 6px;
    overflow: auto;
    border: 1px solid rgba(39, 103, 73, 0.16);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 16px 36px rgba(23, 35, 29, 0.16);
    list-style: none;
}

.alo-local-modal__city-results[hidden],
.alo-local-modal__city-results li[hidden],
.alo-local-modal__city-option[hidden],
.alo-local-modal__city-empty[hidden] {
    display: none !important;
}

.alo-local-modal__city-option {
    display: flex;
    width: 100%;
    min-height: 38px;
    align-items: center;
    padding: 9px 10px;
    border: 0;
    border-radius: 7px;
    background: transparent;
    color: #17231d;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 14px;
    font-weight: 800;
    line-height: 1.2;
    text-align: left;
    cursor: pointer;
}

.alo-local-modal__city-option:hover,
.alo-local-modal__city-option:focus-visible,
.alo-local-modal__city-option[aria-selected="true"] {
    background: #eef3ed;
    color: #1f513a;
    outline: none;
}

.alo-local-modal__city-empty {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    z-index: 2;
    margin: 0;
    padding: 11px 12px;
    border: 1px solid rgba(39, 103, 73, 0.14);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 12px 28px rgba(23, 35, 29, 0.12);
}

.alo-local-modal__radius-options {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.alo-local-modal__radius-choice {
    position: relative;
    display: inline-flex;
}

.alo-local-modal__radius-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.alo-local-modal__radius-choice span {
    display: inline-flex;
    min-height: 40px;
    align-items: center;
    justify-content: center;
    padding: 10px 13px;
    border: 1px solid rgba(39, 103, 73, 0.18);
    border-radius: 999px;
    background: #ffffff;
    color: #26372f;
    font-size: 13px;
    font-weight: 900;
    line-height: 1.1;
    cursor: pointer;
}

.alo-local-modal__radius-choice:hover span,
.alo-local-modal__radius-choice input:focus-visible + span {
    border-color: rgba(39, 103, 73, 0.34);
    background: #eef3ed;
    color: #1f513a;
    outline: 3px solid rgba(39, 103, 73, 0.14);
    outline-offset: 2px;
}

.alo-local-modal__radius-choice input:checked + span,
.alo-local-modal__radius-choice.is-active span {
    border-color: var(--alo-primary, #276749);
    background: var(--alo-primary, #276749);
    color: #ffffff;
}

.alo-local-modal__actions {
    display: grid;
    margin-top: 2px;
}

.alo-local-modal__geo,
.alo-local-modal__submit,
.alo-local-modal__later {
    display: inline-flex;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    padding: 11px 14px;
    border-radius: 999px;
    font-family: var(--alo-font-main, "DM Sans", sans-serif);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.1;
    letter-spacing: 0;
    cursor: pointer;
}

.alo-local-modal__geo {
    border: 1px solid rgba(39, 103, 73, 0.18);
    background: #ffffff;
    color: var(--alo-primary, #276749);
    gap: 8px;
    width: 100%;
}

.alo-local-modal__geo-icon {
    display: inline-flex;
    width: 18px;
    height: 18px;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.alo-local-modal__geo-icon .alo-icon {
    display: block;
    width: 16px;
    height: 16px;
    fill: currentColor;
}

.alo-local-modal__submit {
    width: 100%;
    border: 1px solid var(--alo-primary, #276749);
    background: var(--alo-primary, #276749);
    color: #ffffff;
    box-shadow: 0 12px 26px rgba(39, 103, 73, 0.18);
}

.alo-local-modal__later {
    width: fit-content;
    min-height: 38px;
    margin: 0 auto;
    padding: 8px 12px;
    border: 1px solid rgba(39, 103, 73, 0.12);
    background: #ffffff;
    color: #456052;
    font-size: 13.5px;
}

.alo-local-modal__geo:hover,
.alo-local-modal__geo:focus-visible,
.alo-local-modal__later:hover,
.alo-local-modal__later:focus-visible {
    background: #eef3ed;
    color: #1f513a;
    outline: 3px solid rgba(39, 103, 73, 0.16);
    outline-offset: 2px;
}

.alo-local-modal__submit:hover,
.alo-local-modal__submit:focus-visible {
    background: #1f513a;
    color: #ffffff;
    outline: 3px solid rgba(39, 103, 73, 0.2);
    outline-offset: 2px;
}

.alo-local-modal__geo:disabled,
.alo-local-modal__submit:disabled {
    cursor: progress;
    opacity: 0.72;
}

.alo-local-modal__status {
    min-height: 20px;
    margin: 2px 0 0;
    color: #5f6f66;
    font-size: 13px;
    font-weight: 750;
}

@media (max-width: 767px) {
    body.home .alo-local-pill {
        left: 12px;
        right: auto;
        bottom: 12px;
        max-width: calc(100vw - 24px);
        min-height: 42px;
        padding: 10px 13px;
        font-size: 12.5px;
    }

    .alo-local-modal {
        align-items: end;
        padding: 10px;
    }

    .alo-local-modal__dialog {
        width: 100%;
        max-height: calc(100vh - 20px);
        padding: 18px;
    }

    .alo-local-modal h2 {
        margin-right: 38px;
        font-size: 22px;
    }

    .alo-local-modal p {
        font-size: 14px;
    }

    .alo-local-modal__form {
        gap: 9px;
        margin-top: 12px;
    }

    .alo-local-modal__geo-panel {
        gap: 6px;
        padding: 10px;
    }

    .alo-local-modal__city-search {
        min-height: 43px;
    }

    .alo-local-modal__city-results {
        max-height: 160px;
    }

    .alo-local-modal__radius-options {
        gap: 6px;
    }

    .alo-local-modal__radius-choice span {
        min-height: 38px;
        padding: 9px 11px;
        font-size: 12.5px;
    }

    .alo-local-modal__later {
        width: 100%;
        min-height: 38px;
    }
}
