/* ==========================================================================
   LORD PARK — REDESIGN 2026
   Override file loaded after style.css for modern UI refresh.
   Keeps red dominant color, adds glass morphism, better cards, modern hero.
   ========================================================================== */

/* ---------- Design Tokens ---------- */
:root {
    --gris: #13151A;
    --gris-card: #1C1E26;
    --gris-light: #282B35;
    --blanc: #F5F5F7;
    --rouge-dark: #B91C1C;
    --rouge-glow: rgba(225, 37, 35, 0.3);
    --monte: #22C55E;
    --descend: #EF4444;
    --stagne: #F59E0B;
    --glass-bg: rgba(255,255,255,0.05);
    --glass-border: rgba(255,255,255,0.08);
    --glass-strong: rgba(0,0,0,0.50);
    --radius-sm: 8px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 28px;
    --shadow-card: 0 4px 24px rgba(0,0,0,0.40);
    --shadow-hover: 0 12px 40px rgba(0,0,0,0.55);
    --tr: 0.35s cubic-bezier(.4,0,.2,1);
}

/* ---------- Global ---------- */
body {
    background-color: var(--gris) !important;
}

#main-content {
    background-color: transparent;
}

/* ---------- Header / Nav ---------- */
.menu_header {
    height: 56px;
    background-color: var(--gris);
    border-bottom: 1px solid var(--glass-border);
}

.logo {
    font-size: 28px;
    letter-spacing: 1.5px;
    transition: color var(--tr);
}

.logo:hover {
    color: var(--rouge);
}

.menu_header ul li a {
    transition: color var(--tr) !important;
    font-size: 11px !important;
    letter-spacing: 0.8px;
}

/* ---------- HERO ---------- */
.home_header {
    height: 85vh;
    height: 85dvh;
    min-height: 520px;
    max-height: none;
    padding: 0;
    overflow: visible;
    justify-content: center;
    align-items: center;
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
}

.home_header_video {
    z-index: 0;
    filter: brightness(0.35) saturate(1.2);
}

.home_header::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        radial-gradient(ellipse 80% 60% at 50% 40%, rgba(225,37,35,0.08) 0%, transparent 70%),
        linear-gradient(180deg, rgba(19,21,26,0.4) 0%, transparent 30%, rgba(19,21,26,0.7) 75%, var(--gris) 100%);
    pointer-events: none;
}

/* --- Hero Content Block --- */
.hero_content {
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 24px;
    max-width: 800px;
    padding: 0 24px;
    overflow: visible;
}

.hero_badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 18px;
    border-radius: 50px;
    background: rgba(225,37,35,0.15);
    border: 1px solid rgba(225,37,35,0.3);
    color: var(--rouge);
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    animation: fadeInDown 0.8s ease-out both;
}

.hero_title {
    color: var(--blanc_pur) !important;
    font-family: var(--font-title) !important;
    font-size: 90px !important;
    font-weight: 700;
    line-height: 84% !important;
    letter-spacing: -2px;
    text-transform: uppercase;
    text-shadow: 0 4px 60px rgba(0,0,0,0.4);
    margin: 0;
    padding: 0;
    animation: fadeInUp 0.8s ease-out 0.15s both;
}

.hero_title:after {
    display: none !important;
}

.hero_title span {
    color: var(--rouge) !important;
    text-shadow: 0 0 80px var(--rouge-glow);
}

.hero_subtitle {
    color: rgba(245,245,247,0.65);
    font-family: 'Inter', sans-serif;
    font-size: 17px;
    font-weight: 400;
    line-height: 1.6;
    max-width: 540px;
    margin: 0;
    animation: fadeInUp 0.8s ease-out 0.3s both;
}

/* --- Hero Stats --- */
.hero_stats {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--glass-strong);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid var(--glass-border);
    border-radius: 60px;
    padding: 16px 40px;
    animation: fadeInUp 0.8s ease-out 0.45s both;
}

.hero_stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 0 28px;
}

.hero_stat_number {
    color: var(--blanc_pur);
    font-family: var(--font-title);
    font-size: 48px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -1px;
}

.hero_stat_label {
    color: rgba(245,245,247,0.5);
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
}

.hero_stat_sep {
    width: 1px;
    height: 40px;
    background: rgba(255,255,255,0.12);
    flex-shrink: 0;
}

/* --- Hero CTAs --- */
.hero_cta_row {
    display: flex;
    gap: 14px;
    align-items: center;
    animation: fadeInUp 0.8s ease-out 0.6s both;
}

.hero_cta_primary {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 32px;
    background: var(--rouge);
    color: var(--blanc_pur) !important;
    font-family: var(--font-title);
    font-size: 20px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 50px;
    transition: all var(--tr);
    box-shadow: 0 4px 30px rgba(225,37,35,0.35);
    text-decoration: none;
}

.hero_cta_primary svg {
    transition: transform var(--tr);
}

.hero_cta_primary:hover {
    background: var(--blanc_pur);
    color: var(--rouge) !important;
    box-shadow: 0 4px 40px rgba(255,255,255,0.15);
    transform: translateY(-2px);
}

.hero_cta_primary:hover svg {
    transform: translateX(4px);
    stroke: var(--rouge);
}

.hero_cta_ghost {
    display: inline-flex;
    align-items: center;
    padding: 14px 28px;
    background: transparent;
    color: var(--blanc_pur) !important;
    font-family: var(--font-title);
    font-size: 20px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 50px;
    border: 1px solid rgba(255,255,255,0.2);
    transition: all var(--tr);
    text-decoration: none;
}

.hero_cta_ghost:hover {
    border-color: var(--blanc_pur);
    background: rgba(255,255,255,0.06);
    transform: translateY(-2px);
}

/* --- Hero Search --- */
.hero_search {
    width: 100%;
    max-width: 520px;
    animation: fadeInUp 0.8s ease-out 0.75s both;
    position: relative;
    z-index: 50;
}

.hero_search .recherche_header {
    background: var(--glass-strong);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 50px;
    overflow: visible;
    position: relative;
    display: flex;
    align-items: center;
    margin: 0;
}

.hero_search input.input_recherche {
    background: transparent;
    height: 48px;
    font-size: 14px;
    padding: 0 22px;
    border: none;
    border-radius: 50px 0 0 50px;
    flex: 1;
    min-width: 0;
}

.hero_search input.input_recherche::placeholder {
    color: rgba(255,255,255,0.4);
}

.hero_search button.btn_recherche {
    background: var(--rouge);
    height: 48px;
    width: 52px;
    border-radius: 0 50px 50px 0;
    flex-shrink: 0;
}

.hero_search button.btn_recherche:hover {
    background: var(--rouge-dark);
}

/* --- Spinner (pure CSS) --- */
.hero_search div#spinner {
    position: absolute;
    right: 60px;
    top: 50%;
    transform: translateY(-50%);
    width: 22px;
    height: 22px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s;
}

.hero_search div#spinner.loading {
    opacity: 1;
}

.hero_search div#spinner::after {
    content: '';
    display: block;
    width: 22px;
    height: 22px;
    border: 2px solid rgba(255,255,255,0.15);
    border-top-color: var(--rouge);
    border-radius: 50%;
    animation: spinLoader 0.7s linear infinite;
}

.hero_search div#spinner img {
    display: none !important;
}

@keyframes spinLoader {
    to { transform: rotate(360deg); }
}

/* --- Search Results Dropdown --- */
.hero_search #search-results {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    background: var(--gris-card);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    box-shadow: 0 16px 48px rgba(0,0,0,0.7);
    z-index: 9999;
    max-height: 320px;
    overflow-y: auto;
    margin-top: 0;
    max-width: none;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

.hero_search #search-results ul {
    list-style: none;
    margin: 0;
    padding: 6px;
    background-color: transparent;
}

.hero_search #search-results ul li {
    padding: 0;
    border-bottom: none;
    border-radius: var(--radius-sm);
    transition: background var(--tr);
}

.hero_search #search-results ul li:hover {
    background: rgba(225,37,35,0.1);
}

.hero_search #search-results ul li a {
    color: var(--blanc);
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    font-size: 14px;
    font-family: 'Inter', sans-serif;
}

.hero_search #search-results ul li a .sr_title {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--blanc);
}

.hero_search #search-results ul li a .sr_type {
    flex-shrink: 0;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    padding: 3px 10px;
    border-radius: 50px;
    background: rgba(225,37,35,0.15);
    color: var(--rouge);
    border: 1px solid rgba(225,37,35,0.25);
}

/* Scrollbar for results */
.hero_search #search-results::-webkit-scrollbar { width: 4px; }
.hero_search #search-results::-webkit-scrollbar-track { background: transparent; }
.hero_search #search-results::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 10px; }
.hero_search #search-results::-webkit-scrollbar-thumb:hover { background: var(--rouge); }

/* --- Scroll Hint --- */
.hero_scroll_hint {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    color: rgba(255,255,255,0.35);
    animation: bounceDown 2s ease-in-out infinite;
}

@keyframes bounceDown {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50% { transform: translateX(-50%) translateY(8px); }
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeInDown {
    from { opacity: 0; transform: translateY(-20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ---------- Top Ranking Section (below parcs grid) ---------- */
.home_top_ranking {
    margin-top: 40px;
    padding-bottom: 50px;
}

.home_top_ranking .titre:after {
    display: block;
}

.top_ranking_grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 6px;
    margin-top: 20px;
}

/* Ranking item (horizontal row) */
.ranking_item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 6px 14px 6px 6px;
    border-radius: var(--radius-sm);
    background: var(--gris-card);
    border: 1px solid var(--glass-border);
    transition: all var(--tr);
    text-decoration: none;
    height: 48px;
}

.ranking_item:hover {
    background: rgba(225,37,35,0.06);
    border-color: rgba(225,37,35,0.25);
    transform: translateX(3px);
}

.ranking_item_image {
    width: 36px;
    height: 36px;
    border-radius: 6px;
    overflow: hidden;
    flex-shrink: 0;
}

.ranking_item_image img {
    width: 36px !important;
    height: 36px !important;
    object-fit: cover !important;
    border-radius: 6px !important;
    aspect-ratio: 1 !important;
    animation: none !important;
}

.ranking_item_title {
    font-family: var(--font-title);
    font-size: 13px;
    color: var(--blanc_pur);
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
}

.ranking_item_parc {
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 400;
    color: rgba(245,245,247,0.35);
    white-space: nowrap;
    flex-shrink: 0;
}

.ranking_item_vues {
    display: flex;
    align-items: center;
    gap: 4px;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 500;
    color: rgba(245,245,247,0.3);
    flex-shrink: 0;
    min-width: 55px;
    justify-content: flex-end;
}

.ranking_item_vues svg {
    width: 12px;
    height: 12px;
    opacity: 0.4;
}

/* Hide old ranking elements */
.top_parc_liste_item {
    display: none !important;
}

/* ---------- Section Titles ---------- */
.titre,
.titre span,
.wp-block-heading,
.wp-block-heading strong,
.wp-block-heading a,
.comment-reply-title span,
.page_title,
.entry-title,
.et_pb_contact_main_titl,
.contenu h2 {
    text-shadow: none;
    font-size: 40px;
    letter-spacing: 0.5px;
    color: var(--blanc_pur);
}

.titre:after,
.wp-block-heading:after,
.entry-title:after,
.et_pb_contact_main_title:after {
    max-width: 70px;
    height: 3px;
    border-radius: 3px;
    background: linear-gradient(90deg, var(--rouge) 0%, transparent 100%);
    margin-top: 10px;
}

/* ---------- Search Bar ---------- */
.recherche_header {
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--glass-border);
    background: var(--gris-card);
}

input.input_recherche {
    background-color: transparent;
    height: 52px;
    font-size: 15px;
    font-weight: 400;
}

input.input_recherche:focus {
    background-color: rgba(255,255,255,0.04);
}

input.input_recherche::placeholder {
    color: rgba(255,255,255,0.3);
}

button.btn_recherche {
    background-color: var(--rouge);
    height: 52px;
    width: 58px;
    transition: background var(--tr);
}

button.btn_recherche:hover {
    background-color: var(--rouge-dark);
}

#search-results {
    border-radius: var(--radius-md);
    border: 1px solid var(--glass-border);
}

#search-results ul {
    background-color: var(--gris-card);
}

/* ---------- Actualité Cards ---------- */
.actualite_component {
    gap: 0;
    border-radius: var(--radius-lg);
    background: var(--gris-card);
    box-shadow: var(--shadow-card);
    border: 1px solid var(--glass-border);
    position: relative;
    overflow: hidden;
    transition: all var(--tr);
    display: flex;
    flex-direction: column;
}

.actualite_component:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--shadow-hover);
    border-color: rgba(225,37,35,0.25);
}

.actualite_component:hover .actualite_component_image img {
    transform: scale(1.06);
}

.actualite_component_image {
    position: relative;
    overflow: hidden;
}

.actualite_component_image img {
    transition: transform var(--tr);
}

.actualite_component_image::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 40%;
    background: linear-gradient(to top, var(--gris-card) 0%, transparent 100%);
    pointer-events: none;
    z-index: 1;
}

/* Category badge */
.actu_cat {
    display: inline-block;
    font-family: 'Inter', sans-serif;
    font-size: 10px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: rgba(245,245,247,0.35);
    width: fit-content;
}

.actualite_component_meta {
    padding: 16px 18px 18px;
    height: auto;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
    background: var(--gris-card);
    min-height: auto;
}

.actualite_component_titre {
    font-size: 20px;
    line-height: 24px;
    max-height: none;
    color: var(--blanc_pur);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin: 0;
}

/* Excerpt */
.actu_excerpt {
    color: rgba(245,245,247,0.45);
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.55;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.actualite_component_meta_bottom {
    margin-top: auto;
    padding-top: 8px;
    border-top: 1px solid rgba(255,255,255,0.05);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.actu_meta_left {
    display: flex;
    align-items: center;
    gap: 8px;
}

.actualite_component_date {
    color: rgba(245,245,247,0.35);
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 500;
}

.actu_reading_time {
    color: rgba(245,245,247,0.3);
    font-family: 'Inter', sans-serif;
    font-size: 10px;
    font-weight: 500;
    padding: 1px 6px;
    border-radius: 50px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
    line-height: 1.4;
}

.actualite_component_vues {
    color: rgba(245,245,247,0.25);
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 4px;
}

.actualite_component_vues svg {
    width: 14px;
    height: 14px;
    opacity: 0.5;
}

.home_actualites_liste {
    gap: 26px;
}

/* ---------- "Voir plus" Links ---------- */
.home_actualites_voir_plus {
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 500;
    text-shadow: none;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    gap: 10px;
    margin-top: 20px;
    margin-left: auto;
    margin-bottom: 10px;
    transition: all var(--tr);
    float: none;
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 10px 22px;
    border-radius: 50px;
    border: 1px solid rgba(255,255,255,0.1);
    background: rgba(255,255,255,0.03);
}

.home_actualites_voir_plus svg {
    width: 16px;
    height: 16px;
    transition: transform var(--tr);
    stroke: var(--blanc_pur);
}

.home_actualites_voir_plus svg path {
    fill: none !important;
}

.home_actualites_voir_plus:hover {
    color: var(--rouge) !important;
    border-color: rgba(225,37,35,0.3);
    background: rgba(225,37,35,0.08);
}

.home_actualites_voir_plus:hover svg {
    transform: translateX(4px);
    stroke: var(--rouge);
}

/* ---------- Top Parks Grid ---------- */
section.home_top_attractions {
    margin-top: 50px;
    padding-bottom: 30px;
}

.attraction_top_component {
    gap: 0;
    border-radius: var(--radius-lg);
    background: var(--gris-card);
    box-shadow: var(--shadow-card);
    border: 1px solid var(--glass-border);
    overflow: hidden;
    transition: all var(--tr);
    display: flex;
    flex-direction: column;
}

.attraction_top_component:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--shadow-hover);
    border-color: rgba(225,37,35,0.25);
}

/* --- Override old style.css rules on .attraction_top_component --- */
.attraction_top_component img {
    border-radius: 0 !important;
    aspect-ratio: auto !important;
    animation: none !important;
}

.attraction_top_component:hover img {
    animation: none !important;
}

.attraction_top_component:hover {
    transform: translateY(-6px) !important;
}

/* --- Parc Card Image --- */
.parc_card_image {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16/10;
}

.parc_card_image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform var(--tr) !important;
    border-radius: 0 !important;
    aspect-ratio: auto !important;
}

.attraction_top_component:hover .parc_card_image img {
    transform: scale(1.06) !important;
}

.parc_card_overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 50%;
    background: linear-gradient(to top, var(--gris-card) 0%, transparent 100%);
    pointer-events: none;
}

/* --- Flag on image --- */
.parc_card_flag_wrap {
    position: absolute;
    bottom: 10px;
    right: 10px;
    z-index: 2;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid rgba(255,255,255,0.8);
    box-shadow: 0 2px 8px rgba(0,0,0,0.4);
}

.parc_card_flag {
    width: 30px !important;
    height: 30px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    aspect-ratio: 1 !important;
    display: block !important;
}

/* --- Parc Card Meta --- */
.parc_card_meta {
    padding: 14px 16px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}

.parc_card_title {
    font-family: var(--font-title);
    font-size: 18px;
    line-height: 20px;
    color: var(--blanc_pur);
    text-transform: uppercase;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin: 0;
}

/* Parc card info list (vertical with icons) */
.parc_card_infos {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 5px;
    flex: 1;
}

.parc_card_infos li {
    display: flex;
    align-items: center;
    gap: 7px;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 400;
    color: rgba(245,245,247,0.45);
    line-height: 1.3;
    margin: 0;
    padding: 0;
}

.parc_card_infos li::before {
    display: none !important;
}

.parc_card_infos li svg {
    width: 13px;
    height: 13px;
    flex-shrink: 0;
    opacity: 0.4;
    stroke: rgba(245,245,247,0.6);
}

.parc_card_infos li:first-child {
    color: rgba(245,245,247,0.55);
    font-weight: 500;
}

.parc_card_infos li:first-child svg {
    opacity: 0.6;
    stroke: var(--rouge);
}

/* Hide old cached meta elements */
.attraction_top_component_meta,
.attraction_top_component_meta_top,
.attraction_top_component_meta_bottom,
.attraction_top_component_tendance,
.attraction_top_component_title,
.attraction_top_component_vues,
.attraction_top_component_parc,
.drapeau_pays_attraction {
    display: none !important;
}

/* Show new parc card elements */
.parc_card_meta,
.parc_card_title,
.parc_card_location,
.parc_card_bottom,
.parc_card_vues {
    display: flex !important;
}

.parc_card_title {
    display: -webkit-box !important;
}

.parc_card_bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    padding-top: 8px;
    border-top: 1px solid rgba(255,255,255,0.05);
}

.parc_card_vues {
    display: flex;
    align-items: center;
    gap: 4px;
    color: rgba(245,245,247,0.35);
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    font-weight: 500;
}

.parc_card_vues svg {
    width: 14px;
    height: 14px;
    opacity: 0.5;
}

.home_attractions_liste {
    gap: 22px;
}

/* ---------- Pagination ---------- */
.pagination > .page-numbers {
    border-radius: var(--radius-sm);
    background-color: var(--gris-card);
    border: 1px solid var(--glass-border);
    transition: all var(--tr);
    font-size: 14px;
}

.pagination > .page-numbers:hover {
    background-color: var(--rouge);
    border-color: var(--rouge);
}

span.page-numbers.current {
    background-color: var(--rouge);
    border-color: var(--rouge);
}

/* ---------- Footer ---------- */
.lp_footer {
    background-color: #0A0B0E !important;
    margin-top: 0 !important;
    width: 100vw;
    position: relative;
    left: 50%;
    margin-left: -50vw;
}

.lp_footer_inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 70px 40px 0;
}

.lp_footer_top {
    display: flex;
    gap: 60px;
    padding-bottom: 50px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

/* --- Brand Column --- */
.lp_footer_brand {
    flex: 0 0 280px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.lp_footer_logo {
    font-family: var(--font-title);
    font-size: 32px;
    font-weight: 700;
    color: var(--blanc_pur) !important;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    transition: color var(--tr);
}

.lp_footer_logo:hover {
    color: var(--rouge) !important;
}

.lp_footer_tagline {
    color: rgba(245,245,247,0.4);
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    line-height: 1.7;
    margin: 0;
}

.lp_footer_socials {
    display: flex;
    gap: 10px;
    margin-top: 4px;
}

.lp_footer_socials a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.5);
    transition: all var(--tr);
    text-decoration: none;
}

.lp_footer_socials a:hover {
    background: var(--rouge);
    border-color: var(--rouge);
    color: var(--blanc_pur);
    transform: translateY(-2px);
}

.lp_footer_socials a svg {
    width: 18px;
    height: 18px;
}

/* --- Nav Columns --- */
.lp_footer_nav {
    flex: 1;
    display: flex;
    gap: 40px;
    justify-content: flex-end;
}

.lp_footer_col {
    min-width: 140px;
}

.lp_footer_col_title {
    font-family: var(--font-title);
    font-size: 16px;
    font-weight: 700;
    color: var(--blanc_pur);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin: 0 0 16px;
}

.lp_footer_col ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.lp_footer_col ul li {
    margin: 0;
    padding: 0;
}

.lp_footer_col ul li::before {
    display: none !important;
}

.lp_footer_col ul li a {
    color: rgba(245,245,247,0.45);
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 400;
    text-decoration: none;
    transition: all var(--tr);
    display: inline-block;
}

.lp_footer_col ul li a:hover {
    color: var(--blanc_pur);
    transform: translateX(3px);
}

/* --- Bottom Bar --- */
.lp_footer_bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 24px 0;
    color: rgba(245,245,247,0.25);
    font-family: 'Inter', sans-serif;
    font-size: 12px;
}

.lp_footer_bottom_tagline {
    font-size: 12px;
}

.lp_heart {
    color: var(--rouge);
    font-size: 14px;
}

/* --- Hide old Divi footer elements --- */
#footer-widgets,
#footer-bottom,
#et-footer-nav,
#main-footer .container {
    display: none !important;
}

/* ---------- Buttons ---------- */
.et_pb_button {
    border-radius: var(--radius-sm);
    font-size: 22px;
    transition: all var(--tr);
}

a.reservation {
    border-radius: var(--radius-sm);
    transition: all var(--tr);
}

/* ---------- Banners ---------- */
.banniere {
    border-radius: 0;
}

/* ---------- Sections home ---------- */
section.home_actualites {
    padding-top: 10px;
}

/* ---------- Responsive: ≤ 1280px ---------- */
@media screen and (max-width: 1280px) {
    .home_header {
        height: 85dvh !important;
        padding: 0 !important;
        width: 100vw !important;
        margin-left: -50vw !important;
        left: 50% !important;
    }

    .hero_title {
        font-size: 72px !important;
    }

}

/* ---------- Responsive: ≤ 1024px ---------- */
@media screen and (max-width: 1024px) {
    .home_header {
        height: 85dvh !important;
        min-height: 520px !important;
        padding: 0 !important;
        flex-direction: column !important;
        gap: 0 !important;
    }

    .hero_title {
        font-size: 60px !important;
    }

    .hero_stat_number {
        font-size: 38px;
    }

    .hero_stat {
        padding: 0 20px;
    }

    .hero_stats {
        padding: 14px 28px;
    }

    .attraction_top_component_title {
        font-size: 15px;
    }

    .top_ranking_grid {
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    }
}

/* ---------- Responsive: ≤ 768px ---------- */
@media screen and (max-width: 768px) {
    .home_header {
        height: 85dvh !important;
        min-height: 520px !important;
        padding: 0 !important;
    }

    .hero_title {
        font-size: 52px !important;
    }

    .hero_subtitle {
        font-size: 15px;
    }

    .hero_search {
        max-width: 100%;
    }

    .hero_stats {
        flex-wrap: wrap;
        border-radius: var(--radius-lg);
        padding: 16px 20px;
        justify-content: center;
    }

    .hero_stat {
        padding: 8px 16px;
    }

    .hero_stat_sep {
        display: none;
    }

    .hero_stat_number {
        font-size: 34px;
    }

    .hero_cta_row {
        flex-direction: column;
        width: 100%;
    }

    .hero_cta_primary,
    .hero_cta_ghost {
        width: 100%;
        justify-content: center;
        font-size: 18px;
    }

    .actualite_component_titre {
        font-size: 20px;
        line-height: 22px;
    }

    .titre,
    .wp-block-heading,
    .wp-block-heading strong,
    .wp-block-heading a,
    .comment-reply-title span,
    .page_title,
    .entry-title {
        font-size: 32px !important;
    }

    .titre:after,
    .wp-block-heading:after {
        max-width: 60px;
    }

    .top_ranking_grid {
        grid-template-columns: 1fr;
    }

    .lp_footer_inner {
        padding: 50px 24px 0;
    }

    .lp_footer_top {
        flex-direction: column;
        gap: 40px;
    }

    .lp_footer_brand {
        flex: none;
        align-items: center;
        text-align: center;
    }

    .lp_footer_nav {
        justify-content: center;
        flex-wrap: wrap;
        gap: 30px;
    }

    .lp_footer_col {
        min-width: 120px;
    }

    .lp_footer_bottom {
        flex-direction: column;
        gap: 6px;
        text-align: center;
        padding: 20px 0;
    }
}

/* ---------- Responsive: ≤ 425px ---------- */
@media screen and (max-width: 425px) {
    .hero_title {
        font-size: 42px !important;
        letter-spacing: -1px;
    }

    .hero_badge {
        font-size: 11px;
        padding: 5px 14px;
    }

    .hero_stat_number {
        font-size: 30px;
    }

    .hero_stat_label {
        font-size: 10px;
    }

    .actualite_component_titre {
        font-size: 18px;
        line-height: 20px;
    }

    .titre,
    .wp-block-heading,
    .wp-block-heading strong,
    .wp-block-heading a,
    .comment-reply-title span,
    .page_title,
    .entry-title {
        font-size: 28px !important;
    }
}

/* ==========================================================================
   SINGLE POST REDESIGN
   ========================================================================== */

/* ---------- Post Hero ---------- */
.sp_hero {
    position: relative;
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    min-height: 65vh;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: flex-end;
    margin-bottom: 0;
}

.sp_hero_overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(19,21,26,1) 0%,
        rgba(19,21,26,0.85) 25%,
        rgba(19,21,26,0.4) 55%,
        rgba(19,21,26,0.2) 100%
    );
    z-index: 1;
}

.sp_hero_content {
    position: relative;
    z-index: 2;
    max-width: 900px;
    padding: 60px 40px 50px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.sp_hero_cat {
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--rouge);
    width: fit-content;
}

.sp_hero_title {
    font-family: var(--font-title) !important;
    font-size: 52px !important;
    line-height: 1.05 !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase;
    text-shadow: 0 4px 30px rgba(0,0,0,0.4);
    margin: 0 !important;
    padding: 0 !important;
    max-width: 100%;
}

.sp_hero_meta {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    color: rgba(245,245,247,0.5);
}

.sp_hero_author {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 500;
    color: rgba(245,245,247,0.7);
}

.sp_hero_avatar {
    width: 30px !important;
    height: 30px !important;
    border-radius: 50% !important;
    object-fit: cover;
    border: 2px solid rgba(255,255,255,0.15);
}

.sp_hero_sep {
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: rgba(245,245,247,0.25);
    flex-shrink: 0;
}

.sp_hero_views {
    display: flex;
    align-items: center;
    gap: 5px;
}

.sp_hero_views svg {
    opacity: 0.5;
}

.sp_hero_liaison {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px 8px 8px;
    border-radius: 50px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transition: all var(--tr);
    width: fit-content;
    margin-top: 4px;
    color: rgba(245,245,247,0.7) !important;
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
}

.sp_hero_liaison img {
    width: 28px !important;
    height: 28px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}

.sp_hero_liaison svg {
    width: 14px;
    height: 14px;
    opacity: 0.4;
    transition: transform var(--tr);
}

.sp_hero_liaison:hover {
    background: rgba(225,37,35,0.1);
    border-color: rgba(225,37,35,0.3);
    color: var(--blanc_pur) !important;
}

.sp_hero_liaison:hover svg {
    transform: translateX(3px);
}

/* Hide old banner */
.banniere.banniere_post {
    display: none !important;
}

/* ========== Single Attraction Hero ========== */
.attraction_hero {
    position: relative !important;
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    min-height: 520px !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    display: flex !important;
    align-items: flex-end !important;
    overflow: hidden !important;
}

/* Video background */
.attraction_hero_video_wrap {
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    overflow: hidden !important;
    pointer-events: none !important;
}

.attraction_hero_video_wrap iframe {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    width: 180% !important;
    height: 180% !important;
    transform: translate(-50%, -50%) !important;
    border: none !important;
    object-fit: cover !important;
}

.attraction_hero_overlay {
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(
        180deg,
        rgba(10,10,14,0.15) 0%,
        rgba(10,10,14,0.35) 35%,
        rgba(10,10,14,0.88) 75%,
        rgba(10,10,14,1) 100%
    ) !important;
    z-index: 1 !important;
}

.attraction_hero_content {
    position: relative !important;
    z-index: 2 !important;
    max-width: 900px !important;
    padding: 0 60px 50px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

/* Park badge */
.attraction_hero_parc {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 5px 14px 5px 5px !important;
    border-radius: 50px !important;
    background: rgba(255,255,255,0.08) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(255,255,255,0.1) !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
    width: fit-content !important;
}

.attraction_hero_parc:hover {
    background: rgba(255,255,255,0.14) !important;
    border-color: rgba(255,255,255,0.2) !important;
    transform: translateY(-1px) !important;
}

.attraction_hero_parc img {
    width: 28px !important;
    height: 28px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    background: #fff !important;
}

.attraction_hero_parc span {
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: rgba(245,245,247,0.85) !important;
    letter-spacing: 0.3px !important;
}

/* Title */
.attraction_hero_title {
    font-family: var(--font-title) !important;
    font-size: 52px !important;
    font-weight: 900 !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
    line-height: 1.05 !important;
    text-shadow: 0 2px 20px rgba(0,0,0,0.4) !important;
    margin: 0 !important;
}

/* Meta row */
.attraction_hero_meta {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
    margin-top: 4px !important;
}

/* Views badge */
.attraction_hero_views {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.5) !important;
    padding: 5px 12px !important;
    border-radius: 50px !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
}

.attraction_hero_views svg {
    width: 14px !important;
    height: 14px !important;
    stroke: rgba(245,245,247,0.4) !important;
    flex-shrink: 0 !important;
}

/* Meta tags (pills) */
.attraction_hero_tag {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    color: rgba(245,245,247,0.7) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    padding: 5px 12px !important;
    border-radius: 50px !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
}

.attraction_hero_tag svg {
    width: 12px !important;
    height: 12px !important;
    flex-shrink: 0 !important;
}

a.attraction_hero_tag:hover {
    background: rgba(255,255,255,0.12) !important;
    border-color: rgba(255,255,255,0.18) !important;
    color: var(--blanc_pur) !important;
}

.attraction_hero_tag_accent {
    background: rgba(225,37,35,0.15) !important;
    border-color: rgba(225,37,35,0.3) !important;
    color: #ff6b6b !important;
}

/* ---------- Attraction Content ---------- */
.single-attractions .attraction_content {
    max-width: 820px !important;
    margin: 0 auto !important;
    padding: 40px 30px 60px !important;
    font-family: 'Inter', sans-serif !important;
}

.single-attractions .attraction_content p {
    font-size: 15px !important;
    line-height: 1.75 !important;
    color: rgba(245,245,247,0.65) !important;
}

.single-attractions .attraction_content h2,
.single-attractions .attraction_content h3 {
    font-family: var(--font-title) !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
}

.single-attractions .attraction_content .video {
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    margin-bottom: 30px !important;
}

.single-attractions .attraction_content .video iframe {
    width: 100% !important;
    aspect-ratio: 16/9 !important;
    border: none !important;
    border-radius: var(--radius-lg) !important;
}

.single-attractions .attraction_content .liaison {
    padding: 14px 20px !important;
    border-radius: var(--radius-lg) !important;
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 12px !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
    margin-top: 20px !important;
}

.single-attractions .attraction_content .liaison:hover {
    border-color: rgba(225,37,35,0.25) !important;
    background: rgba(225,37,35,0.05) !important;
}

.single-attractions .attraction_content .liaison img {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    margin: 0 !important;
}

.single-attractions .attraction_content .liaison .liaison_title {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--blanc_pur) !important;
}

/* Hide old meta wrapper on attraction pages */
.single-attractions .et_post_meta_wrapper:first-child {
    display: none !important;
}

/* ========== Single Land Hero ========== */
.land_hero {
    position: relative !important;
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    min-height: 520px !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    display: flex !important;
    align-items: flex-end !important;
    overflow: hidden !important;
}

.land_hero_overlay {
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(
        180deg,
        rgba(10,10,14,0) 0%,
        rgba(10,10,14,0.25) 35%,
        rgba(10,10,14,0.85) 75%,
        rgba(10,10,14,1) 100%
    ) !important;
    z-index: 1 !important;
}

.land_hero_content {
    position: relative !important;
    z-index: 2 !important;
    max-width: 900px !important;
    padding: 0 60px 50px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

/* Park badge */
.land_hero_parc {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 5px 14px 5px 5px !important;
    border-radius: 50px !important;
    background: rgba(255,255,255,0.08) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(255,255,255,0.1) !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
    width: fit-content !important;
}

.land_hero_parc:hover {
    background: rgba(255,255,255,0.14) !important;
    border-color: rgba(255,255,255,0.2) !important;
    transform: translateY(-1px) !important;
}

.land_hero_parc img {
    width: 28px !important;
    height: 28px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    background: #fff !important;
}

.land_hero_parc span {
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: rgba(245,245,247,0.85) !important;
    letter-spacing: 0.3px !important;
}

/* Title */
.land_hero_title {
    font-family: var(--font-title) !important;
    font-size: 52px !important;
    font-weight: 900 !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
    line-height: 1.05 !important;
    text-shadow: 0 2px 20px rgba(0,0,0,0.4) !important;
    margin: 0 !important;
}

/* Meta row */
.land_hero_meta {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
    margin-top: 4px !important;
}

/* Views badge */
.land_hero_views {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.5) !important;
    padding: 5px 12px !important;
    border-radius: 50px !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
}

.land_hero_views svg {
    width: 14px !important;
    height: 14px !important;
    stroke: rgba(245,245,247,0.4) !important;
    flex-shrink: 0 !important;
}

/* Tags */
.land_hero_tag {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    color: rgba(245,245,247,0.7) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    padding: 5px 12px !important;
    border-radius: 50px !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    text-decoration: none !important;
}

/* ---------- Land Content ---------- */
.single-land .land_content {
    max-width: 1100px !important;
    margin: 0 auto !important;
    padding: 40px 30px 60px !important;
    font-family: 'Inter', sans-serif !important;
}

.single-land .land_content p {
    font-size: 15px !important;
    line-height: 1.75 !important;
    color: rgba(245,245,247,0.65) !important;
}

.single-land .land_content h2.titre {
    font-family: var(--font-title) !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
    font-size: 24px !important;
    margin: 40px 0 20px !important;
}

.single-land .land_content .grid_template {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
    gap: 20px !important;
    margin-bottom: 30px !important;
}

.single-land .land_content .liaison {
    padding: 14px 20px !important;
    border-radius: var(--radius-lg) !important;
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 12px !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
    margin-top: 20px !important;
}

.single-land .land_content .liaison:hover {
    border-color: rgba(225,37,35,0.25) !important;
    background: rgba(225,37,35,0.05) !important;
}

.single-land .land_content .liaison img {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    margin: 0 !important;
}

.single-land .land_content .liaison .liaison_title {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--blanc_pur) !important;
}

/* Hide old meta wrapper on land pages */
.single-land .et_post_meta_wrapper:first-child {
    display: none !important;
}

/* ---------- Land Comments ---------- */
.single-land section#comment-wrap {
    max-width: 820px !important;
    margin: 0 auto !important;
    padding: 40px 30px 60px !important;
    border-top: 1px solid rgba(255,255,255,0.05) !important;
}

.single-land #comment-wrap h3#reply-title,
.single-land #comment-wrap .comment-reply-title {
    font-family: var(--font-title) !important;
    font-size: 24px !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
    margin-bottom: 20px !important;
}

.single-land #comment-wrap .comment-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

.single-land #comment-wrap .comment-form p {
    margin: 0 !important;
}

.single-land #comment-wrap .comment-form label {
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.45) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    display: block !important;
    margin-bottom: 4px !important;
}

.single-land #commentform input[type="text"],
.single-land #commentform input[type="email"],
.single-land #commentform input[type="url"],
.single-land #commentform textarea {
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    padding: 12px 16px !important;
    width: 100% !important;
    transition: border-color var(--tr) !important;
}

.single-land #commentform input:focus,
.single-land #commentform textarea:focus {
    border-color: var(--rouge) !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(225,37,35,0.12) !important;
}

.single-land #commentform textarea {
    min-height: 120px !important;
    resize: vertical !important;
}

.single-land #comment-wrap .form-submit .et_pb_button,
.single-land #comment-wrap .form-submit input[type="submit"] {
    background: var(--rouge) !important;
    color: var(--blanc_pur) !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 12px 28px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all var(--tr) !important;
}

.single-land #comment-wrap .form-submit .et_pb_button:hover,
.single-land #comment-wrap .form-submit input[type="submit"]:hover {
    background: #c72235 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(225,37,35,0.25) !important;
}

.single-land #comment-wrap .form-submit .et_pb_button:after {
    display: none !important;
}

.single-land #comment-wrap .comment-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 30px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.single-land #comment-wrap li.comment {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.single-land #comment-wrap .comment-body {
    position: relative !important;
    padding: 18px 22px !important;
    margin-bottom: 0 !important;
    background: var(--gris-card) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius-lg) !important;
    transition: border-color var(--tr) !important;
}

.single-land #comment-wrap .comment-body:hover {
    border-color: rgba(255,255,255,0.1) !important;
}

.single-land #comment-wrap .comment_avatar {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    float: none !important;
    display: inline-flex !important;
    margin-bottom: 6px !important;
}

.single-land #comment-wrap .comment_avatar img {
    width: 32px !important;
    height: 32px !important;
    max-width: 32px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}

.single-land #comment-wrap .comment_postinfo {
    margin-bottom: 4px !important;
}

.single-land #comment-wrap span.fn,
.single-land #comment-wrap span.fn a {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--blanc_pur) !important;
    text-decoration: none !important;
}

.single-land #comment-wrap span.comment_date {
    font-family: 'Inter', sans-serif !important;
    font-size: 10px !important;
    font-weight: 400 !important;
    color: rgba(245,245,247,0.25) !important;
}

.single-land #comment-wrap .comment_area {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: rgba(245,245,247,0.6) !important;
}

.single-land #comment-wrap .comment_area p {
    margin-bottom: 0.5em !important;
    font-size: 13px !important;
}

.single-land #comment-wrap a.comment-reply-link,
.single-land #comment-wrap a.comment-reply-link.et_pb_button {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.3) !important;
    background: none !important;
    border: none !important;
    padding: 4px 0 0 !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    display: inline-block !important;
}

.single-land #comment-wrap a.comment-reply-link:after,
.single-land #comment-wrap a.comment-reply-link.et_pb_button:after {
    display: none !important;
}

.single-land #comment-wrap a.comment-reply-link:hover {
    color: var(--rouge) !important;
}

.single-land #comment-wrap .comment .children {
    margin-left: 20px !important;
    padding-left: 16px !important;
    border-left: 2px solid rgba(255,255,255,0.04) !important;
    margin-top: 12px !important;
}

/* ---------- Attraction Comments ---------- */
.single-attractions .commentaires {
    max-width: 820px !important;
    margin: 0 auto !important;
    padding: 0 30px 60px !important;
}

.single-attractions section#comment-wrap {
    max-width: none !important;
    margin: 0 !important;
    padding: 40px 0 0 !important;
    border-top: 1px solid rgba(255,255,255,0.05) !important;
}

.single-attractions #comment-wrap h3#reply-title,
.single-attractions #comment-wrap .comment-reply-title {
    font-family: var(--font-title) !important;
    font-size: 24px !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
    margin-bottom: 20px !important;
}

.single-attractions #comment-wrap .comment-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

.single-attractions #comment-wrap .comment-form p {
    margin: 0 !important;
}

.single-attractions #comment-wrap .comment-form label {
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.45) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    display: block !important;
    margin-bottom: 4px !important;
}

.single-attractions #commentform input[type="text"],
.single-attractions #commentform input[type="email"],
.single-attractions #commentform input[type="url"],
.single-attractions #commentform textarea {
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    padding: 12px 16px !important;
    width: 100% !important;
    transition: border-color var(--tr) !important;
}

.single-attractions #commentform input:focus,
.single-attractions #commentform textarea:focus {
    border-color: var(--rouge) !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(225,37,35,0.12) !important;
}

.single-attractions #commentform textarea {
    min-height: 120px !important;
    resize: vertical !important;
}

.single-attractions #comment-wrap .form-submit .et_pb_button,
.single-attractions #comment-wrap .form-submit input[type="submit"] {
    background: var(--rouge) !important;
    color: var(--blanc_pur) !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 12px 28px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all var(--tr) !important;
}

.single-attractions #comment-wrap .form-submit .et_pb_button:hover,
.single-attractions #comment-wrap .form-submit input[type="submit"]:hover {
    background: #c72235 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(225,37,35,0.25) !important;
}

.single-attractions #comment-wrap .form-submit .et_pb_button:after {
    display: none !important;
}

.single-attractions #comment-wrap .comment-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 30px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.single-attractions #comment-wrap li.comment {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.single-attractions #comment-wrap .comment-body {
    position: relative !important;
    padding: 18px 22px !important;
    margin-bottom: 0 !important;
    background: var(--gris-card) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius-lg) !important;
    transition: border-color var(--tr) !important;
}

.single-attractions #comment-wrap .comment-body:hover {
    border-color: rgba(255,255,255,0.1) !important;
}

.single-attractions #comment-wrap .comment_avatar {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    float: none !important;
    display: inline-flex !important;
    margin-bottom: 6px !important;
}

.single-attractions #comment-wrap .comment_avatar img {
    width: 32px !important;
    height: 32px !important;
    max-width: 32px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}

.single-attractions #comment-wrap .comment_postinfo {
    margin-bottom: 4px !important;
}

.single-attractions #comment-wrap span.fn,
.single-attractions #comment-wrap span.fn a {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--blanc_pur) !important;
    text-decoration: none !important;
}

.single-attractions #comment-wrap span.comment_date {
    font-family: 'Inter', sans-serif !important;
    font-size: 10px !important;
    font-weight: 400 !important;
    color: rgba(245,245,247,0.25) !important;
}

.single-attractions #comment-wrap .comment_area {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: rgba(245,245,247,0.6) !important;
}

.single-attractions #comment-wrap .comment_area p {
    margin-bottom: 0.5em !important;
    font-size: 13px !important;
}

.single-attractions #comment-wrap a.comment-reply-link,
.single-attractions #comment-wrap a.comment-reply-link.et_pb_button {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.3) !important;
    background: none !important;
    border: none !important;
    padding: 4px 0 0 !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    display: inline-block !important;
}

.single-attractions #comment-wrap a.comment-reply-link:after,
.single-attractions #comment-wrap a.comment-reply-link.et_pb_button:after {
    display: none !important;
}

.single-attractions #comment-wrap a.comment-reply-link:hover {
    color: var(--rouge) !important;
}

.single-attractions #comment-wrap .comment .children {
    margin-left: 20px !important;
    padding-left: 16px !important;
    border-left: 2px solid rgba(255,255,255,0.04) !important;
    margin-top: 12px !important;
}

/* ---------- Article Content ---------- */
.single-post .et_pb_post .entry-content {
    max-width: 780px;
    margin: 0 auto;
    padding: 50px 30px !important;
    font-family: 'Inter', sans-serif;
    font-size: 17px;
    line-height: 1.8;
    color: rgba(245,245,247,0.8);
}

.single-post .entry-content p {
    margin-bottom: 1.5em;
    text-align: left;
}

.single-post .entry-content h2,
.single-post .entry-content h3,
.single-post .entry-content h4 {
    color: var(--blanc_pur);
    margin-top: 2em;
    margin-bottom: 0.8em;
}

.single-post .entry-content h2 {
    font-size: 28px;
    line-height: 1.2;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

.single-post .entry-content h3 {
    font-size: 22px;
    line-height: 1.3;
}

.single-post .entry-content img {
    border-radius: var(--radius-lg);
}

.single-post .entry-content > img,
.single-post .entry-content p > img,
.single-post .entry-content figure img {
    margin: 1.5em 0;
}

.single-post .entry-content a {
    color: var(--rouge);
    text-decoration: underline;
    text-decoration-color: rgba(225,37,35,0.3);
    text-underline-offset: 3px;
    transition: all var(--tr);
}

.single-post .entry-content a:hover {
    text-decoration-color: var(--rouge);
}

.single-post .entry-content blockquote {
    border-left: 3px solid var(--rouge);
    padding: 16px 24px;
    margin: 2em 0;
    background: rgba(255,255,255,0.02);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    font-style: italic;
    color: rgba(245,245,247,0.6);
}

.single-post .entry-content ul,
.single-post .entry-content ol {
    padding-left: 24px;
    margin-bottom: 1.5em;
}

.single-post .entry-content li {
    margin-bottom: 0.5em;
}

.single-post .entry-content table {
    border-radius: var(--radius-md);
    overflow: hidden;
    border-collapse: separate;
    border-spacing: 0;
    width: 100%;
    margin: 1.5em 0;
}

.single-post .entry-content thead th {
    background: var(--rouge) !important;
    padding: 12px 16px;
}

.single-post .entry-content td {
    padding: 10px 16px;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}

/* ---------- Author Box ---------- */
.single-post .aproprosauteur {
    font-family: 'Inter', sans-serif;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(245,245,247,0.25);
    display: block;
    margin-bottom: 8px;
    margin-top: 30px;
}

.single-post .auteur {
    border: 1px solid rgba(255,255,255,0.06) !important;
    border-radius: 50px !important;
    padding: 8px 16px 8px 8px !important;
    background: rgba(255,255,255,0.02);
    margin: 0 0 0 0 !important;
    display: inline-flex !important;
    width: auto !important;
}

.single-post .auteur_meta {
    gap: 10px;
}

.single-post .auteur__img img {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    border: 2px solid rgba(255,255,255,0.08);
}

.single-post .auteur__info div {
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 500;
    color: rgba(245,245,247,0.6);
}

/* ---------- Liaison Box ---------- */
.single-post .entry-content .liaison {
    padding: 12px 18px;
    border-radius: var(--radius-lg);
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    transition: all var(--tr);
    text-decoration: none;
}

.single-post .entry-content .liaison:hover {
    border-color: rgba(225,37,35,0.25);
    background: rgba(225,37,35,0.05);
    transform: none;
}

.single-post .entry-content .liaison img {
    margin: 0;
    border-radius: 50% !important;
}

/* ---------- Comments Section ---------- */
.single-post section#comment-wrap {
    max-width: 780px !important;
    margin: 0 auto !important;
    padding: 40px 30px 60px !important;
    border-top: 1px solid rgba(255,255,255,0.05);
}

.single-post #comment-wrap h3#reply-title,
.single-post #comment-wrap .comment-reply-title {
    font-family: var(--font-title) !important;
    font-size: 24px !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase;
    margin-bottom: 20px !important;
}

.single-post #comment-wrap .comment-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

.single-post #comment-wrap .comment-form p {
    margin: 0 !important;
}

.single-post #comment-wrap .comment-form label {
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.4) !important;
    margin-bottom: 4px !important;
    display: block !important;
}

.single-post #commentform input[type="text"],
.single-post #commentform input[type="email"],
.single-post #commentform input[type="url"],
.single-post #commentform textarea {
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    padding: 10px 14px !important;
    transition: border-color var(--tr) !important;
    width: 100% !important;
}

.single-post #commentform input:focus,
.single-post #commentform textarea:focus {
    border-color: var(--rouge) !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(225,37,35,0.12) !important;
}

.single-post #commentform textarea {
    min-height: 120px !important;
    resize: vertical !important;
}

.single-post #comment-wrap .form-submit .et_pb_button,
.single-post #comment-wrap .form-submit input[type="submit"] {
    background: var(--rouge) !important;
    color: var(--blanc_pur) !important;
    border: none !important;
    border-radius: 50px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    padding: 10px 26px !important;
    cursor: pointer !important;
    transition: all var(--tr) !important;
}

.single-post #comment-wrap .form-submit .et_pb_button:hover,
.single-post #comment-wrap .form-submit input[type="submit"]:hover {
    background: var(--rouge-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(225,37,35,0.25) !important;
}

/* Comment list — Override Divi defaults */
.single-post #comment-wrap .comment-body {
    position: relative !important;
    padding: 16px 18px !important;
    margin-bottom: 10px !important;
    min-height: auto !important;
    border-radius: var(--radius-md) !important;
    background: rgba(255,255,255,0.02) !important;
    border: 1px solid rgba(255,255,255,0.05) !important;
    transition: border-color var(--tr) !important;
}

.single-post #comment-wrap .comment-body:hover {
    border-color: rgba(255,255,255,0.1) !important;
}

/* Avatar */
.single-post #comment-wrap .comment_avatar {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    display: inline-block !important;
    vertical-align: middle !important;
    margin-right: 8px !important;
    margin-bottom: 6px !important;
}

.single-post #comment-wrap .comment_avatar img {
    width: 28px !important;
    height: 28px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
}

/* Author name + date */
.single-post #comment-wrap span.fn,
.single-post #comment-wrap span.fn a {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--blanc_pur) !important;
    text-decoration: none !important;
}

.single-post #comment-wrap span.comment_date {
    font-family: 'Inter', sans-serif !important;
    font-size: 10px !important;
    font-weight: 400 !important;
    color: rgba(245,245,247,0.25) !important;
}

.single-post #comment-wrap .comment_postinfo {
    margin-bottom: 4px !important;
}

/* Comment text */
.single-post #comment-wrap .comment_area {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: rgba(245,245,247,0.6) !important;
}

.single-post #comment-wrap .comment_area p {
    margin-bottom: 0.5em !important;
    font-size: 13px !important;
}

/* Reply button — override Divi .et_pb_button */
.single-post #comment-wrap a.comment-reply-link,
.single-post #comment-wrap a.comment-reply-link.et_pb_button {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    float: none !important;
    display: inline-block !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.3) !important;
    background: transparent !important;
    border: none !important;
    padding: 4px 0 !important;
    margin-top: 4px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    text-decoration: none !important;
    transition: color var(--tr) !important;
    cursor: pointer !important;
}

.single-post #comment-wrap a.comment-reply-link:hover,
.single-post #comment-wrap a.comment-reply-link.et_pb_button:hover {
    color: var(--rouge) !important;
    background: transparent !important;
}

.single-post #comment-wrap a.comment-reply-link:after,
.single-post #comment-wrap a.comment-reply-link.et_pb_button:after {
    display: none !important;
}

/* Nested replies */
.single-post #comment-wrap .comment .children {
    margin-left: 20px !important;
    padding-left: 0 !important;
    border-left: 2px solid rgba(255,255,255,0.04) !important;
    padding-left: 16px !important;
}

.single-post #comment-wrap li.comment {
    list-style: none !important;
    padding: 0 !important;
}

/* ==========================================================================
   ARCHIVE PAGES (Actualités, etc.)
   ========================================================================== */

/* ---------- Archive Hero ---------- */
.archive_hero {
    text-align: center;
    padding: 80px 20px 50px;
    position: relative;
    background-size: cover;
    background-position: center;
    background-image: linear-gradient(
        to top,
        rgba(19,21,26,1) 0%,
        rgba(19,21,26,0.85) 30%,
        rgba(19,21,26,0.5) 70%,
        rgba(19,21,26,0.3) 100%
    ), url('/wp-content/themes/LordPark/assets/img/actu.webp');
}

/* Per-page hero backgrounds */
.archive_hero_evenement {
    background-image: linear-gradient(
        to top, rgba(19,21,26,1) 0%, rgba(19,21,26,0.85) 30%, rgba(19,21,26,0.5) 70%, rgba(19,21,26,0.3) 100%
    ), url('/wp-content/themes/LordPark/assets/img/evenement.webp') !important;
}

.archive_hero_emploi {
    background-image: linear-gradient(
        to top, rgba(19,21,26,1) 0%, rgba(19,21,26,0.85) 30%, rgba(19,21,26,0.5) 70%, rgba(19,21,26,0.3) 100%
    ), url('/wp-content/themes/LordPark/assets/img/emploi.webp') !important;
}

.archive_hero_constructeurs {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 40%, #0f3460 70%, #533483 100%) !important;
    overflow: hidden;
}

.archive_hero_deco {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

.archive_hero_deco_gear {
    position: absolute;
    stroke: rgba(255,255,255,.07);
}

.archive_hero_deco_gear--1 {
    width: 200px;
    height: 200px;
    top: -30px;
    right: 80px;
    animation: cpt_gear_spin 30s linear infinite;
}

.archive_hero_deco_gear--2 {
    width: 140px;
    height: 140px;
    bottom: -20px;
    left: 50px;
    animation: cpt_gear_spin_reverse 25s linear infinite;
}

.archive_hero_constructeurs .archive_hero_content {
    position: relative;
    z-index: 1;
}

.archive_hero_projet {
    background-image: linear-gradient(
        to top, rgba(19,21,26,1) 0%, rgba(19,21,26,0.85) 30%, rgba(19,21,26,0.5) 70%, rgba(19,21,26,0.3) 100%
    ), url('/wp-content/themes/LordPark/assets/img/projet.webp') !important;
}

.archive_hero_attractions {
    background-image: linear-gradient(
        to top, rgba(19,21,26,1) 0%, rgba(19,21,26,0.85) 30%, rgba(19,21,26,0.5) 70%, rgba(19,21,26,0.3) 100%
    ), url('/wp-content/themes/LordPark/assets/img/attractions.webp') !important;
    background-position: center 47% !important;
}

.archive_hero_aquatiques {
    background-image: linear-gradient(
        to top, rgba(19,21,26,1) 0%, rgba(19,21,26,0.85) 30%, rgba(19,21,26,0.5) 70%, rgba(19,21,26,0.3) 100%
    ), url('/wp-content/themes/LordPark/assets/img/aquatique.webp') !important;
}

.archive_hero_attractions_single {
    background-image: linear-gradient(
        to top, rgba(19,21,26,1) 0%, rgba(19,21,26,0.85) 30%, rgba(19,21,26,0.5) 70%, rgba(19,21,26,0.3) 100%
    ), url('/wp-content/themes/LordPark/assets/img/attractions-single.webp') !important;
    background-position: center 47% !important;
}

/* ---------- Parcs Filters (countries + search) ---------- */
.parcs_filters {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 20px 30px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
}

.parcs_countries {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
}

.country_chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 50px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    cursor: pointer;
    transition: all var(--tr);
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    color: rgba(245,245,247,0.5);
}

.country_chip input[type="checkbox"] {
    display: none;
}

.country_chip img {
    width: 18px !important;
    height: 18px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}

.country_chip .country_count {
    font-size: 10px;
    opacity: 0.4;
}

.country_chip:hover {
    border-color: rgba(225,37,35,0.3);
    background: rgba(225,37,35,0.06);
    color: rgba(245,245,247,0.7);
}

.country_chip.selected {
    background: rgba(225,37,35,0.12);
    border-color: rgba(225,37,35,0.4);
    color: var(--blanc_pur);
}

.country_chip.selected .country_count {
    opacity: 0.7;
}

/* ---------- Parc List Card (archive /parcs/) ---------- */
.parc_list_card {
    display: flex;
    flex-direction: column;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--gris-card);
    border: 1px solid var(--glass-border);
    transition: all var(--tr);
    text-decoration: none;
}

.parc_list_card:hover {
    transform: translateY(-4px);
    border-color: rgba(225,37,35,0.25);
    box-shadow: 0 12px 30px rgba(0,0,0,0.3);
}

.parc_list_card_image {
    position: relative;
    width: 100%;
    height: 180px;
    overflow: hidden;
}

.parc_list_card_image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    aspect-ratio: auto !important;
    animation: none !important;
    transition: transform var(--tr);
}

.parc_list_card:hover .parc_list_card_image img {
    transform: scale(1.05);
}

.parc_list_card_body {
    padding: 14px 16px 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1;
}

.parc_list_card_title {
    font-family: var(--font-title);
    font-size: 16px;
    font-weight: 700;
    color: var(--blanc_pur);
    text-transform: uppercase;
    line-height: 1.2;
}

.parc_list_card_location {
    display: flex;
    align-items: center;
    gap: 5px;
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    font-weight: 500;
    color: rgba(245,245,247,0.5);
}

.parc_list_card_location svg {
    width: 13px;
    height: 13px;
    flex-shrink: 0;
    stroke: var(--rouge);
    opacity: 0.7;
}

.parc_list_card_chips {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 2px;
    flex: 1;
}

.parc_chip {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 6px;
    border-radius: 50px;
    background: rgba(255,255,255,0.05);
    font-family: 'Inter', sans-serif;
    font-size: 10px;
    font-weight: 500;
    color: rgba(245,245,247,0.4);
    white-space: nowrap;
    line-height: 1.4;
}

.parc_chip svg {
    width: 11px;
    height: 11px;
    opacity: 0.4;
}

.parc_list_card_footer {
    display: flex;
    align-items: center;
    margin-top: auto;
    padding-top: 8px;
    border-top: 1px solid rgba(255,255,255,0.04);
}

.parc_list_vues {
    display: flex;
    align-items: center;
    gap: 4px;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 500;
    color: rgba(245,245,247,0.25);
    margin-left: auto;
}

.parc_list_vues svg {
    width: 12px;
    height: 12px;
    opacity: 0.35;
}

/* Hide old form_pays */
.form_pays {
    display: none !important;
}

.archive_hero_content {
    max-width: 600px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.archive_hero_title {
    font-family: var(--font-title) !important;
    font-size: 48px !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase;
    margin: 0 !important;
    line-height: 1.05 !important;
}

.archive_hero_subtitle {
    font-family: 'Inter', sans-serif;
    font-size: 15px;
    color: rgba(245,245,247,0.4);
    margin: 0;
}

/* ---------- Archive Search ---------- */
.archive_search {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    max-width: 480px;
    margin-top: 8px;
    padding: 10px 14px;
    border-radius: 50px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    transition: border-color var(--tr);
}

.archive_search:focus-within {
    border-color: var(--rouge);
    box-shadow: 0 0 0 3px rgba(225,37,35,0.1);
}

.archive_search svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    opacity: 0.3;
    stroke: var(--blanc_pur);
}

.archive_search input[type="text"] {
    flex: 1;
    background: transparent !important;
    border: none !important;
    outline: none !important;
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    padding: 0 !important;
    box-shadow: none !important;
}

.archive_search input::placeholder {
    color: rgba(245,245,247,0.3);
}

.archive_search button {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.4;
    transition: opacity var(--tr);
}

.archive_search button:hover {
    opacity: 1;
}

.archive_search button svg {
    stroke: var(--blanc_pur);
}

/* Hide old banner on archive pages */
.section_template .banniere {
    display: none !important;
}

.section_template .recherche {
    display: none !important;
}

/* ---------- Pagination ---------- */
.pagination {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 40px 0 60px !important;
}

.pagination .page-numbers {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    padding: 8px 14px !important;
    border-radius: var(--radius-sm) !important;
    background: rgba(255,255,255,0.04) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    color: rgba(245,245,247,0.5) !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
}

.pagination .page-numbers:hover {
    background: rgba(225,37,35,0.08) !important;
    border-color: rgba(225,37,35,0.25) !important;
    color: var(--blanc_pur) !important;
}

.pagination .page-numbers.current {
    background: var(--rouge) !important;
    border-color: var(--rouge) !important;
    color: var(--blanc_pur) !important;
}

.pagination .page-numbers.dots {
    background: transparent !important;
    border: none !important;
    color: rgba(245,245,247,0.25) !important;
    padding: 8px 6px !important;
}

.pagination .page-numbers.prev,
.pagination .page-numbers.next {
    font-weight: 600 !important;
}

/* ========== SINGLE PARC PAGE ========== */

/* --- Hero banner --- */
.banniere_parc {
    height: auto !important;
    min-height: 520px !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    background-size: cover !important;
    background-position: center !important;
    position: relative !important;
    display: flex !important;
    justify-content: center !important;
    align-items: flex-end !important;
    border-radius: 0 !important;
    overflow: hidden !important;
}

/* --- YouTube video background --- */
.parc_hero_video_wrap {
    position: absolute !important;
    inset: -60px -10% !important;
    z-index: 0 !important;
    pointer-events: none !important;
    overflow: hidden !important;
}

.parc_hero_video_wrap iframe {
    width: 120% !important;
    height: 120% !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) scale(1.3) !important;
    object-fit: cover !important;
    border: none !important;
    filter: brightness(0.45) saturate(1.15) !important;
}

.banniere_parc::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(
        to top,
        rgba(19,21,26,1) 0%,
        rgba(19,21,26,0.95) 18%,
        rgba(19,21,26,0.55) 50%,
        rgba(19,21,26,0.35) 100%
    ) !important;
    z-index: 1 !important;
    border-radius: 0 !important;
    width: 100% !important;
    height: 100% !important;
}

/* --- Hero content block --- */
.parc_hero_content {
    position: relative !important;
    z-index: 2 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 18px !important;
    width: 100% !important;
    max-width: 1200px !important;
    padding: 0 50px 50px !important;
    animation: fadeInUp 0.7s ease-out both !important;
}

/* --- Badge (country) --- */
.parc_hero_badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 6px 16px 6px 8px !important;
    border-radius: 50px !important;
    background: rgba(255,255,255,0.1) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: rgba(245,245,247,0.85) !important;
}

.parc_hero_badge .drapeau_pays {
    width: 20px !important;
    height: 20px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}

/* --- Location row (under title) --- */
.parc_hero_location {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin-top: 4px !important;
    white-space: nowrap !important;
}

.parc_hero_location svg {
    width: 12px !important;
    height: 12px !important;
    stroke: rgba(245,245,247,0.35) !important;
    flex-shrink: 0 !important;
}

.parc_hero_location .parc_adresse,
.parc_hero_location .parc_adresse div {
    font-family: var(--font-title) !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    color: rgba(245,245,247,0.4) !important;
    font-style: normal !important;
    display: inline !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    white-space: nowrap !important;
    text-shadow: none !important;
    line-height: 1.3 !important;
}

/* --- Title row (logo + h1) --- */
.parc_hero_title_row {
    display: flex !important;
    align-items: center !important;
    gap: 22px !important;
}

.logo_parc {
    width: 80px !important;
    height: 80px !important;
    object-fit: contain !important;
    border-radius: var(--radius-lg) !important;
    background: #fff !important;
    padding: 8px !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.3) !important;
    flex-shrink: 0 !important;
}

/* --- Title --- */
.banniere_parc_titre h1 {
    font-family: var(--font-title) !important;
    font-size: 48px !important;
    color: var(--blanc_pur) !important;
    text-shadow: 0 2px 20px rgba(0,0,0,0.4) !important;
    line-height: 1.05 !important;
    margin: 0 !important;
    text-transform: uppercase !important;
    letter-spacing: -0.5px !important;
}

/* --- Horizontal stats bar --- */
.parc_hero_stats {
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
    padding: 16px 30px !important;
    border-radius: var(--radius-lg) !important;
    background: rgba(255,255,255,0.08) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
}

.parc_hero_stat {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    padding: 0 26px !important;
}

.parc_hero_stat_value {
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    letter-spacing: -0.3px !important;
    text-shadow: none !important;
    text-transform: none !important;
}

.parc_hero_stat_label {
    color: rgba(245,245,247,0.6) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 1.2px !important;
    margin-top: 3px !important;
}

.parc_hero_stat_sep {
    width: 1px !important;
    height: 36px !important;
    background: rgba(255,255,255,0.12) !important;
    flex-shrink: 0 !important;
}

/* --- CTA row --- */
.parc_hero_cta_row {
    display: flex !important;
    gap: 14px !important;
    align-items: center !important;
    margin-top: 6px !important;
}

.parc_hero_cta_primary {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 15px 32px !important;
    border-radius: 50px !important;
    background: var(--rouge) !important;
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
    border: none !important;
    box-shadow: 0 4px 24px rgba(225,37,35,0.35) !important;
}

.parc_hero_cta_primary svg {
    width: 18px !important;
    height: 18px !important;
    stroke: var(--blanc_pur) !important;
    flex-shrink: 0 !important;
    transition: transform var(--tr) !important;
}

.parc_hero_cta_primary:hover {
    background: #c72235 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 30px rgba(225,37,35,0.45) !important;
    color: var(--blanc_pur) !important;
}

.parc_hero_cta_primary:hover svg {
    transform: translateX(2px) !important;
}

.parc_hero_cta_ghost {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 15px 28px !important;
    border-radius: 50px !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.18) !important;
    color: rgba(245,245,247,0.8) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
}

.parc_hero_cta_ghost svg {
    width: 14px !important;
    height: 14px !important;
    stroke: rgba(245,245,247,0.6) !important;
    flex-shrink: 0 !important;
}

.parc_hero_cta_ghost:hover {
    border-color: var(--blanc_pur) !important;
    background: rgba(255,255,255,0.1) !important;
    color: var(--blanc_pur) !important;
    transform: translateY(-2px) !important;
}

.parc_hero_cta_ghost:hover svg {
    stroke: var(--blanc_pur) !important;
}

/* --- Legacy .drapeau_pays (outside badge context) --- */
.drapeau_pays {
    width: 22px !important;
    height: 22px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}

.parc_adresse,
.parc_adresse div {
    font-family: var(--font-title) !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    color: rgba(245,245,247,0.4) !important;
    font-style: normal !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    text-shadow: none !important;
    line-height: 1.3 !important;
}

/* --- Secondary nav menu --- */
.menu_parc_secondaire {
    min-width: 240px !important;
    max-width: 240px !important;
    padding: 0 !important;
    border-right: none !important;
    position: sticky !important;
    top: 80px !important;
    align-self: flex-start !important;
}

.menu_parc_secondaire ul {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    padding: 0 !important;
    margin: 0 !important;
}

.menu_parc_secondaire li {
    height: auto !important;
    padding: 0 !important;
    border-radius: var(--radius-sm) !important;
    background: transparent !important;
    border: none !important;
}

.menu_parc_secondaire li a {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.45) !important;
    text-transform: none !important;
    padding: 8px 12px !important;
    border-radius: var(--radius-sm) !important;
    transition: all var(--tr) !important;
    display: block !important;
    text-decoration: none !important;
}

.menu_parc_secondaire li a::after {
    display: none !important;
}

.menu_parc_secondaire li a:hover {
    color: rgba(245,245,247,0.8) !important;
    background: rgba(255,255,255,0.04) !important;
}

.menu_parc_secondaire li.selected {
    background: transparent !important;
}

.menu_parc_secondaire li.selected a {
    color: var(--blanc_pur) !important;
    background: rgba(225,37,35,0.12) !important;
    border-left: 2px solid var(--rouge) !important;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0 !important;
    font-weight: 600 !important;
}

.menu_parc_secondaire li:hover {
    background: transparent !important;
}

/* --- Content area (parc pages only - has .menu_parc_secondaire + .contenu) --- */
.parcs .entry-content,
.single-parc .entry-content {
    display: flex !important;
    gap: 30px !important;
}

.contenu {
    flex: 1 !important;
    min-width: 0 !important;
}

/* --- Reservation button --- */
.reservation_button,
.bouton_billet {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 10px 20px !important;
    border-radius: 50px !important;
    background: var(--rouge) !important;
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
    margin-bottom: 20px !important;
}

.reservation_button:hover,
.bouton_billet:hover {
    background: #c72235 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(225,37,35,0.3) !important;
}

/* --- Description + content text --- */
.description {
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: rgba(245,245,247,0.65) !important;
}

.description h2,
.description h3,
.contenu h2.titre,
.contenu h3.titre {
    font-family: var(--font-title) !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
    margin-top: 30px !important;
}

/* --- Sub-page intro text (attractions, etc.) --- */
.contenu > p {
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: rgba(245,245,247,0.65) !important;
}

/* --- Grids (global) --- */
.grid_template {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
    gap: 16px !important;
}

.actualites_liste.grid_template {
    padding: 0 40px !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
}

.contenu .grid_template_full {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
}

.grid_template_full .actualite_component {
    flex-direction: row !important;
    max-height: 200px !important;
    overflow: hidden !important;
}

.grid_template_full .actualite_component_image {
    width: 320px !important;
    min-width: 320px !important;
    max-width: 320px !important;
    aspect-ratio: auto !important;
    height: 100% !important;
}

.grid_template_full .actualite_component_image img {
    height: 100% !important;
    width: 100% !important;
    object-fit: cover !important;
}

.grid_template_full .actualite_component_meta {
    flex: 1 !important;
    padding: 18px 22px !important;
    justify-content: center !important;
}

.grid_template_full .actualite_component_titre {
    font-size: 18px !important;
    line-height: 22px !important;
}

.grid_template_full a.actualite_component.termine::after {
    top: 10px !important;
    right: 10px !important;
    left: auto !important;
    bottom: auto !important;
    width: auto !important;
    height: auto !important;
    padding: 6px 14px !important;
    font-size: 11px !important;
    border-radius: 50px !important;
    background: rgba(0,0,0,0.6) !important;
    backdrop-filter: blur(8px) !important;
}

/* --- Mobile menu button --- */
.menu_mobile_parc {
    z-index: 2 !important;
}

/* --- Reservation hero button (legacy, hidden) --- */
.reservation_hero {
    display: none !important;
}

/* --- Hide old reservation buttons in content --- */
.contenu > a.reservation {
    display: none !important;
}

/* --- Reservation button (all types) --- */
a.reservation {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 12px 24px !important;
    border-radius: 50px !important;
    background: var(--rouge) !important;
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: all var(--tr) !important;
    margin: 16px 0 !important;
    border: none !important;
    width: auto !important;
    justify-content: center !important;
}

a.reservation svg {
    width: 20px !important;
    height: 20px !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
}

a.reservation svg path,
a.reservation svg g {
    stroke: var(--blanc_pur) !important;
    fill: var(--blanc_pur) !important;
}

a.reservation:hover {
    background: #c72235 !important;
    color: var(--blanc_pur) !important;
    font-size: 14px !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(225,37,35,0.35) !important;
}

a.reservation:hover svg {
    transform: none !important;
}

a.reservation:hover svg path,
a.reservation:hover svg g {
    stroke: var(--blanc_pur) !important;
    fill: var(--blanc_pur) !important;
}

/* --- Terminé badge --- */
a.actualite_component.termine {
    filter: none !important;
    opacity: 0.6 !important;
}

a.actualite_component.termine::after {
    content: "Terminé" !important;
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    bottom: auto !important;
    left: auto !important;
    padding: 4px 10px !important;
    margin: 0 !important;
    border-radius: 50px !important;
    background: rgba(0,0,0,0.7) !important;
    color: rgba(245,245,247,0.7) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    text-align: center !important;
    z-index: 2 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    height: auto !important;
    padding-right: 10px !important;
    margin-right: 0 !important;
}

/* --- Temps d'attente loader --- */
.temps_attente_loader {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 18px !important;
    padding: 60px 20px !important;
    border-radius: var(--radius-lg) !important;
    background: rgba(255,255,255,0.04) !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
}

.temps_attente_loader_spinner {
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    border: 3px solid rgba(255,255,255,0.08) !important;
    border-top-color: var(--rouge) !important;
    animation: loaderSpin 0.8s linear infinite !important;
}

@keyframes loaderSpin {
    to { transform: rotate(360deg); }
}

.temps_attente_loader_text {
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.4) !important;
    letter-spacing: 0.3px !important;
    animation: loaderPulse 1.5s ease-in-out infinite !important;
}

@keyframes loaderPulse {
    0%, 100% { opacity: 0.4; }
    50% { opacity: 1; }
}

/* --- Temps d'attente table --- */
.parc_temps_attente {
    width: 100% !important;
}

.temps_attente_tab {
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    font-family: 'Inter', sans-serif !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
}

.temps_attente_tab thead tr {
    background: rgba(255,255,255,0.04) !important;
}

.temps_attente_tab th {
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: rgba(245,245,247,0.4) !important;
    padding: 12px 16px !important;
    text-align: left !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}

.temps_attente_tab td {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.65) !important;
    padding: 10px 16px !important;
    border-bottom: 1px solid rgba(255,255,255,0.03) !important;
    transition: background var(--tr) !important;
}

.temps_attente_tab tbody tr:hover td {
    background: rgba(255,255,255,0.02) !important;
}

.temps_attente_tab td a {
    color: var(--blanc_pur) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
}

.temps_attente_tab td a:hover {
    color: var(--rouge) !important;
}

.queue-times-sponso {
    margin-top: 12px !important;
    text-align: right !important;
}

.queue-times-sponso a {
    font-family: 'Inter', sans-serif !important;
    font-size: 10px !important;
    color: rgba(245,245,247,0.2) !important;
    text-decoration: none !important;
}

/* --- Dates d'ouverture --- */
.contenu .jsCalendar {
    font-family: 'Inter', sans-serif !important;
}

.contenu table {
    border-collapse: separate !important;
    border-spacing: 0 !important;
    font-family: 'Inter', sans-serif !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
    width: 100% !important;
}

.contenu table th {
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    color: rgba(245,245,247,0.4) !important;
    padding: 10px 14px !important;
    background: rgba(255,255,255,0.04) !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
    text-align: left !important;
}

.contenu table td {
    font-size: 13px !important;
    color: rgba(245,245,247,0.6) !important;
    padding: 8px 14px !important;
    border-bottom: 1px solid rgba(255,255,255,0.03) !important;
}

/* --- Dates d'ouverture parc --- */
.dates_parc_block {
    margin-top: 10px !important;
}

.dates_parc_block h2.parc_ouvert {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px 20px !important;
    border-radius: 50px !important;
    background: rgba(34,197,94,0.12) !important;
    border: 1px solid rgba(34,197,94,0.25) !important;
    color: #22c55e !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-transform: none !important;
    text-shadow: none !important;
    margin-bottom: 24px !important;
}

.dates_parc_block h2.parc_ferme {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px 20px !important;
    border-radius: 50px !important;
    background: rgba(239,68,68,0.12) !important;
    border: 1px solid rgba(239,68,68,0.25) !important;
    color: #ef4444 !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-transform: none !important;
    text-shadow: none !important;
    margin-bottom: 24px !important;
}

.dates_parc_dates {
    margin-bottom: 28px !important;
}

.dates_parc_dates h2.titre {
    font-family: var(--font-title) !important;
    font-size: 28px !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
    margin-bottom: 14px !important;
    text-shadow: none !important;
}

.dates_parc_table {
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    font-family: 'Inter', sans-serif !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    background: var(--gris-card) !important;
    border: 1px solid var(--glass-border) !important;
}

.dates_parc_thead td {
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    color: rgba(245,245,247,0.4) !important;
    padding: 14px 20px !important;
    background: rgba(255,255,255,0.04) !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}

.dates_parc_tbody tr {
    transition: background var(--tr) !important;
}

.dates_parc_tbody tr:hover {
    background: rgba(255,255,255,0.03) !important;
}

.dates_parc_tbody td {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    color: rgba(245,245,247,0.65) !important;
    padding: 14px 20px !important;
    border-bottom: 1px solid rgba(255,255,255,0.04) !important;
}

.dates_parc_tbody td:first-child {
    font-weight: 600 !important;
    color: var(--blanc_pur) !important;
}

.dates_parc_tbody tr:last-child td {
    border-bottom: none !important;
}

/* --- Access page: map + transport --- */
.map_parc {
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
}

.map_parc iframe {
    border-radius: var(--radius-lg) !important;
    height: 450px !important;
}

.bouton_map {
    display: flex !important;
    gap: 8px !important;
    padding: 12px 0 !important;
}

.bouton_map a {
    width: 44px !important;
    height: 44px !important;
    border-radius: var(--radius-sm) !important;
    background-size: 28px !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-color: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    transition: all var(--tr) !important;
}

.bouton_map a:hover {
    background-color: rgba(255,255,255,0.1) !important;
    border-color: rgba(255,255,255,0.15) !important;
    transform: translateY(-2px) !important;
}

.transport {
    margin-bottom: 16px !important;
}

.transport h3 {
    font-family: var(--font-title) !important;
    font-size: 18px !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
    margin-bottom: 6px !important;
}

.transport p {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: rgba(245,245,247,0.55) !important;
}

/* --- Avis / comments on parc pages --- */
.parc_avis section#comment-wrap {
    padding: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    border: none !important;
}

.parc_avis #comment-wrap .comment-list,
.parc_avis .comment-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.parc_avis #comment-wrap li.comment {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.parc_avis #comment-wrap .comment-body,
.parc_avis .comment-body {
    background: var(--gris-card) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius-lg) !important;
    padding: 20px 24px !important;
    margin-bottom: 0 !important;
    position: relative !important;
}

.parc_avis #comment-wrap .comment-body:hover {
    border-color: rgba(255,255,255,0.1) !important;
}

.parc_avis .comment_avatar {
    display: inline-flex !important;
    position: relative !important;
    top: auto !important;
    left: auto !important;
    float: none !important;
    margin-bottom: 8px !important;
}

.parc_avis .comment_avatar img,
.parc_avis #comment-wrap .comment_avatar img {
    width: 36px !important;
    height: 36px !important;
    max-width: 36px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
}

.parc_avis .comment_postinfo {
    margin-bottom: 6px !important;
}

.parc_avis #comment-wrap span.fn,
.parc_avis #comment-wrap span.fn a,
.parc_avis span.fn,
.parc_avis span.fn a {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--blanc_pur) !important;
    text-decoration: none !important;
}

.parc_avis #comment-wrap span.comment_date,
.parc_avis span.comment_date {
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 400 !important;
    color: rgba(245,245,247,0.3) !important;
}

.parc_avis .comment_area,
.parc_avis #comment-wrap .comment_area {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: rgba(245,245,247,0.6) !important;
}

.parc_avis .comment_area p,
.parc_avis .comment-body p,
.parc_avis .comment-content p {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: rgba(245,245,247,0.6) !important;
    margin-bottom: 0.4em !important;
}

.parc_avis #comment-wrap a.comment-reply-link,
.parc_avis #comment-wrap a.comment-reply-link.et_pb_button,
.parc_avis a.comment-reply-link {
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.35) !important;
    background: none !important;
    border: none !important;
    padding: 4px 0 0 !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    position: relative !important;
    top: auto !important;
    right: auto !important;
    display: inline-block !important;
}

.parc_avis a.comment-reply-link:after,
.parc_avis a.comment-reply-link.et_pb_button:after {
    display: none !important;
}

.parc_avis a.comment-reply-link:hover {
    color: var(--rouge) !important;
}

.parc_avis .comment .children {
    margin-left: 24px !important;
    padding-left: 16px !important;
    border-left: 2px solid rgba(255,255,255,0.05) !important;
    margin-top: 12px !important;
}

.parc_avis #respond {
    margin-top: 24px !important;
    padding: 24px !important;
    background: var(--gris-card) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--radius-lg) !important;
}

.parc_avis #respond h3#reply-title,
.parc_avis #respond .comment-reply-title {
    font-family: var(--font-title) !important;
    font-size: 20px !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
    margin-bottom: 16px !important;
}

.parc_avis #respond .comment-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.parc_avis #respond .comment-form p {
    margin: 0 !important;
}

.parc_avis #respond .comment-form label {
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: rgba(245,245,247,0.45) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    display: block !important;
    margin-bottom: 4px !important;
}

.parc_avis #commentform textarea,
.parc_avis #commentform input[type="text"],
.parc_avis #commentform input[type="email"],
.parc_avis #commentform input[type="url"],
.parc_avis #respond textarea,
.parc_avis #respond input[type="text"],
.parc_avis #respond input[type="email"],
.parc_avis #respond input[type="url"] {
    background: rgba(255,255,255,0.04) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--blanc_pur) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    padding: 12px 16px !important;
    width: 100% !important;
    transition: border-color var(--tr) !important;
}

.parc_avis #commentform textarea:focus,
.parc_avis #commentform input:focus,
.parc_avis #respond textarea:focus,
.parc_avis #respond input:focus {
    border-color: var(--rouge) !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(225,37,35,0.12) !important;
}

.parc_avis #commentform textarea,
.parc_avis #respond textarea {
    min-height: 120px !important;
    resize: vertical !important;
}

.parc_avis .form-submit .et_pb_button,
.parc_avis .form-submit input[type="submit"] {
    background: var(--rouge) !important;
    color: var(--blanc_pur) !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 12px 28px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all var(--tr) !important;
}

.parc_avis .form-submit .et_pb_button:hover,
.parc_avis .form-submit input[type="submit"]:hover {
    background: #c72235 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(225,37,35,0.25) !important;
}

.parc_avis .form-submit .et_pb_button:after {
    display: none !important;
}

/* --- FAQ: same typography as articles --- */
.contenu div > div {
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: rgba(245,245,247,0.65) !important;
}

.contenu div h2,
.contenu div h3,
.contenu div h4 {
    font-family: var(--font-title) !important;
    color: var(--blanc_pur) !important;
    text-transform: uppercase !important;
}

.contenu div p {
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: rgba(245,245,247,0.65) !important;
    margin-bottom: 12px !important;
}

/* Fréquentation calendar */
.frequentation_calendrier {
    margin-top: 16px !important;
}

/* --- Carte/plan image --- */
img.carte {
    border-radius: var(--radius-lg) !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
}

/* ---------- Single Parc Responsive ---------- */
@media screen and (max-width: 1024px) {
    .banniere_parc {
        min-height: 420px !important;
    }

    .parc_hero_content {
        padding: 0 30px 40px !important;
    }

    .banniere_parc_titre h1 {
        font-size: 36px !important;
    }

    .parc_hero_title_row {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 14px !important;
    }

    .logo_parc {
        width: 60px !important;
        height: 60px !important;
    }

    .parc_hero_stats {
        flex-wrap: wrap !important;
        padding: 12px 20px !important;
        justify-content: center !important;
    }

    .parc_hero_stat {
        padding: 6px 18px !important;
    }

    .parc_hero_stat_value {
        font-size: 24px !important;
    }

    .parc_hero_stat_sep {
        display: none !important;
    }

    .menu_parc_secondaire {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100vw !important;
        max-width: 100vw !important;
        min-width: 100vw !important;
        height: 100vh !important;
        z-index: 9999 !important;
        background: rgba(19,21,26,0.97) !important;
        backdrop-filter: blur(20px) !important;
        padding: 60px 30px 30px !important;
        display: none;
        overflow-y: auto !important;
    }

    .menu_parc_secondaire ul {
        gap: 4px !important;
    }

    .menu_parc_secondaire li a {
        font-size: 16px !important;
        padding: 12px 16px !important;
    }

    .parcs .entry-content,
    .single-parc .entry-content {
        flex-direction: column !important;
    }

    .grid_template {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)) !important;
    }
}

@media screen and (max-width: 768px) {
    .parc_hero_video_wrap {
        display: none !important;
    }

    .parc_hero_cta_row {
        flex-direction: column !important;
        width: 100% !important;
    }

    .parc_hero_cta_primary,
    .parc_hero_cta_ghost {
        width: 100% !important;
        justify-content: center !important;
    }

    .parc_hero_badge {
        font-size: 12px !important;
    }

    .parc_hero_location .parc_adresse {
        font-size: 12px !important;
    }
}

@media screen and (max-width: 425px) {
    .banniere_parc {
        min-height: 360px !important;
    }

    .parc_hero_content {
        padding: 0 20px 30px !important;
        gap: 14px !important;
    }

    .banniere_parc_titre h1 {
        font-size: 28px !important;
    }

    .logo_parc {
        width: 50px !important;
        height: 50px !important;
    }

    .parc_hero_stat_value {
        font-size: 20px !important;
    }

    .parc_hero_stat_label {
        font-size: 10px !important;
    }

    .parc_hero_location {
        display: none !important;
    }

    .grid_template {
        grid-template-columns: 1fr !important;
    }
}

/* ---------- Archive Responsive ---------- */
@media screen and (max-width: 768px) {
    .archive_hero {
        padding: 40px 20px 30px;
    }

    .archive_hero_title {
        font-size: 36px !important;
    }

    .archive_search {
        max-width: 100%;
    }
}

@media screen and (max-width: 425px) {
    .archive_hero_title {
        font-size: 28px !important;
    }

    .archive_hero_subtitle {
        font-size: 13px;
    }
}

/* ---------- Single Post Responsive ---------- */
@media screen and (max-width: 768px) {
    .sp_hero {
        min-height: 50vh;
    }

    .sp_hero_content {
        padding: 40px 20px 35px;
    }

    .sp_hero_title {
        font-size: 34px !important;
    }

    .sp_hero_meta {
        font-size: 12px;
        gap: 10px;
    }

    .single-post .et_pb_post .entry-content {
        padding: 30px 20px !important;
        font-size: 16px;
    }

    .single-post .entry-content h2 {
        font-size: 24px;
    }

    section#comment-wrap {
        padding: 0 20px 40px;
    }

    .comment-list .children {
        padding-left: 14px !important;
    }
}

@media screen and (max-width: 425px) {
    .sp_hero_title {
        font-size: 28px !important;
    }

    .sp_hero_meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
    }

    .sp_hero_sep {
        display: none;
    }

    .sp_hero_liaison {
        font-size: 12px;
    }
}

/* ---------- Single Attraction Responsive ---------- */
@media screen and (max-width: 768px) {
    .attraction_hero {
        min-height: 400px !important;
    }

    .attraction_hero_video_wrap {
        display: none !important;
    }

    .attraction_hero_content {
        padding: 0 24px 36px !important;
        gap: 10px !important;
    }

    .attraction_hero_title {
        font-size: 34px !important;
    }

    .attraction_hero_meta {
        gap: 6px !important;
    }

    .attraction_hero_tag {
        font-size: 10px !important;
        padding: 4px 10px !important;
    }

    .attraction_hero_views {
        font-size: 11px !important;
        padding: 4px 10px !important;
    }

    .single-attractions .attraction_content {
        padding: 30px 20px 50px !important;
    }

    .single-attractions .commentaires {
        padding: 0 20px 40px !important;
    }
}

@media screen and (max-width: 425px) {
    .attraction_hero {
        min-height: 340px !important;
    }

    .attraction_hero_title {
        font-size: 28px !important;
    }

    .attraction_hero_parc span {
        font-size: 11px !important;
    }

    .attraction_hero_parc img {
        width: 24px !important;
        height: 24px !important;
    }
}

/* ---------- Single Land Responsive ---------- */
@media screen and (max-width: 768px) {
    .land_hero {
        min-height: 400px !important;
    }

    .land_hero_content {
        padding: 0 24px 36px !important;
        gap: 10px !important;
    }

    .land_hero_title {
        font-size: 34px !important;
    }

    .land_hero_meta {
        gap: 6px !important;
    }

    .land_hero_tag {
        font-size: 10px !important;
        padding: 4px 10px !important;
    }

    .land_hero_views {
        font-size: 11px !important;
        padding: 4px 10px !important;
    }

    .single-land .land_content {
        padding: 30px 20px 50px !important;
    }

    .single-land .land_content .grid_template {
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
        gap: 14px !important;
    }

    .single-land section#comment-wrap {
        padding: 30px 20px 40px !important;
    }
}

@media screen and (max-width: 425px) {
    .land_hero {
        min-height: 340px !important;
    }

    .land_hero_title {
        font-size: 28px !important;
    }

    .land_hero_parc span {
        font-size: 11px !important;
    }

    .land_hero_parc img {
        width: 24px !important;
        height: 24px !important;
    }

    .single-land .land_content .grid_template {
        grid-template-columns: 1fr !important;
    }
}

/* ============================================
   CPT HERO – shared styles for boutique,
   restaurant, constructeurs, emploi, evenement,
   hotel, spectacle single pages
   ============================================ */

.cpt_hero {
    position: relative;
    width: 100%;
    min-height: 420px;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    border-radius: 0 0 18px 18px;
}

.cpt_hero_overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.72) 0%, rgba(0,0,0,.18) 55%, transparent 100%);
    z-index: 1;
}

.cpt_hero_content {
    position: relative;
    z-index: 2;
    padding: 36px 42px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
}

.cpt_hero_parc {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none !important;
    color: #fff !important;
    font-size: 13px;
    font-weight: 600;
    opacity: .9;
    transition: opacity .2s;
}

.cpt_hero_parc:hover {
    opacity: 1;
}

.cpt_hero_parc img {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(255,255,255,.5);
}

.cpt_hero_title {
    color: #fff !important;
    font-size: 38px !important;
    font-weight: 800 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.15 !important;
    text-shadow: 0 2px 12px rgba(0,0,0,.35);
}

.cpt_hero_meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
}

.cpt_hero_views {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: rgba(255,255,255,.85);
    font-size: 13px;
    font-weight: 500;
}

.cpt_hero_views svg {
    flex-shrink: 0;
}

.cpt_hero_tag {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.2);
    white-space: nowrap;
}

.cpt_hero_tag a {
    color: #fff !important;
    text-decoration: none !important;
}

.cpt_hero_tag a:hover {
    text-decoration: underline !important;
}

/* CPT hero: no-image fallback (constructeurs, etc.) */
.cpt_hero--no-image {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 40%, #0f3460 70%, #533483 100%);
}

.cpt_hero--no-image .cpt_hero_overlay {
    background: linear-gradient(to top, rgba(0,0,0,.55) 0%, rgba(0,0,0,.1) 50%, transparent 100%);
}

.cpt_hero_deco {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

.cpt_hero_deco_gear {
    position: absolute;
    stroke: rgba(255,255,255,.06);
}

.cpt_hero_deco_gear--1 {
    width: 220px;
    height: 220px;
    top: -40px;
    right: 60px;
    animation: cpt_gear_spin 30s linear infinite;
}

.cpt_hero_deco_gear--2 {
    width: 160px;
    height: 160px;
    top: 50%;
    right: -30px;
    transform: translateY(-50%);
    animation: cpt_gear_spin_reverse 25s linear infinite;
}

.cpt_hero_deco_gear--3 {
    width: 120px;
    height: 120px;
    bottom: -20px;
    left: 40px;
    animation: cpt_gear_spin 20s linear infinite;
}

@keyframes cpt_gear_spin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

@keyframes cpt_gear_spin_reverse {
    from { transform: translateY(-50%) rotate(0deg); }
    to   { transform: translateY(-50%) rotate(-360deg); }
}

/* CPT content area */
.cpt_content {
    max-width: 820px !important;
    margin: 0 auto !important;
    padding: 32px 20px !important;
    font-size: 16px;
    line-height: 1.7;
}

.cpt_content img {
    border-radius: 12px;
}

.cpt_content .galerie {
    margin: 24px 0;
}

/* CPT comments */
.single-boutique .et_post_meta_wrapper,
.single-restaurant .et_post_meta_wrapper,
.single-constructeurs .et_post_meta_wrapper,
.single-emploi .et_post_meta_wrapper,
.single-evenement .et_post_meta_wrapper,
.single-hotel .et_post_meta_wrapper,
.single-spectacle .et_post_meta_wrapper {
    max-width: 820px !important;
    margin: 0 auto !important;
    padding: 0 20px 40px !important;
}

/* Hide old banner on all CPT pages */
.single-boutique .banniere.banniere_post,
.single-restaurant .banniere.banniere_post,
.single-constructeurs .banniere.banniere_post,
.single-emploi .banniere.banniere_post,
.single-evenement .banniere.banniere_post,
.single-hotel .banniere.banniere_post,
.single-spectacle .banniere.banniere_post {
    display: none !important;
}

/* ---- Responsive: tablet ---- */
@media (max-width: 768px) {
    .cpt_hero {
        min-height: 340px;
    }

    .cpt_hero_content {
        padding: 28px 24px;
    }

    .cpt_hero_title {
        font-size: 30px !important;
    }

    .cpt_hero_meta {
        gap: 6px;
    }

    .cpt_hero_tag {
        font-size: 11px;
        padding: 3px 10px;
    }

    .cpt_content {
        padding: 24px 16px !important;
    }

    .cpt_hero_deco_gear--1 {
        width: 160px;
        height: 160px;
    }

    .cpt_hero_deco_gear--2 {
        width: 120px;
        height: 120px;
    }

    .cpt_hero_deco_gear--3 {
        width: 90px;
        height: 90px;
    }
}

/* ---- Responsive: mobile ---- */
@media (max-width: 425px) {
    .cpt_hero {
        min-height: 280px;
        border-radius: 0;
    }

    .cpt_hero_content {
        padding: 22px 16px;
    }

    .cpt_hero_title {
        font-size: 24px !important;
    }

    .cpt_hero_parc img {
        width: 24px;
        height: 24px;
    }

    .cpt_hero_parc {
        font-size: 11px;
    }

    .cpt_hero_meta {
        gap: 5px;
    }

    .cpt_hero_tag {
        font-size: 10px;
        padding: 3px 8px;
    }

    .cpt_hero_views {
        font-size: 11px;
    }

    .cpt_content {
        padding: 18px 12px !important;
    }

    .cpt_hero_deco_gear--1 {
        width: 120px;
        height: 120px;
        right: 20px;
    }

    .cpt_hero_deco_gear--2 {
        width: 90px;
        height: 90px;
    }

    .cpt_hero_deco_gear--3 {
        width: 70px;
        height: 70px;
    }
}


/* ==========================================================================
   404 PAGE
   ========================================================================== */

.page_404 {
    position: relative;
    min-height: calc(100vh - 56px);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: radial-gradient(ellipse at 50% 0%, rgba(225,37,35,0.08) 0%, transparent 60%),
                var(--gris);
}

.page_404_stars {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}

.page_404_star {
    position: absolute;
    background: #fff;
    border-radius: 50%;
    opacity: 0;
    animation: star404_pulse 4s ease-in-out infinite;
}

@keyframes star404_pulse {
    0%, 100% { opacity: 0; transform: scale(0.5); }
    50%      { opacity: 0.7; transform: scale(1); }
}

.page_404_coaster {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 0;
    opacity: 0.5;
    pointer-events: none;
}

.page_404_track {
    width: 100%;
    height: auto;
    display: block;
}

.page_404_content {
    position: relative;
    z-index: 2;
    text-align: center;
    padding: 40px 24px 80px;
    max-width: 600px;
}

.page_404_number {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 28px;
    user-select: none;
}

.page_404_digit {
    font-size: clamp(100px, 18vw, 180px);
    font-weight: 900;
    line-height: 1;
    color: transparent;
    background: linear-gradient(135deg, #e12523 0%, #ff6b6b 50%, #e12523 100%);
    background-size: 200% 200%;
    -webkit-background-clip: text;
    background-clip: text;
    animation: digit404_shimmer 4s ease-in-out infinite;
    filter: drop-shadow(0 0 40px rgba(225,37,35,0.3));
}

@keyframes digit404_shimmer {
    0%, 100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}

.page_404_wheel {
    display: flex;
    align-items: center;
    justify-content: center;
    width: clamp(80px, 14vw, 140px);
    height: clamp(80px, 14vw, 140px);
    color: #e12523;
    filter: drop-shadow(0 0 30px rgba(225,37,35,0.35));
    animation: wheel404_spin 8s linear infinite;
}

.page_404_wheel svg {
    width: 100%;
    height: 100%;
}

@keyframes wheel404_spin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

.page_404_title {
    color: var(--blanc) !important;
    font-size: clamp(22px, 4vw, 30px) !important;
    font-weight: 700 !important;
    margin: 0 0 14px !important;
    padding: 0 !important;
    line-height: 1.3 !important;
}

.page_404_text {
    color: rgba(245,245,247,0.55) !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    margin: 0 0 36px !important;
    padding: 0 !important;
}

.page_404_actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 32px;
}

.page_404_btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 26px;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none !important;
    transition: all 0.3s cubic-bezier(.4,0,.2,1);
    cursor: pointer;
}

.page_404_btn--primary {
    background: #e12523;
    color: #fff !important;
    box-shadow: 0 4px 24px rgba(225,37,35,0.35);
}

.page_404_btn--primary:hover {
    background: #c91f1d;
    box-shadow: 0 8px 32px rgba(225,37,35,0.5);
    transform: translateY(-2px);
    color: #fff !important;
}

.page_404_btn--secondary {
    background: var(--glass-bg);
    color: var(--blanc) !important;
    border: 1px solid var(--glass-border);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.page_404_btn--secondary:hover {
    background: rgba(255,255,255,0.1);
    border-color: rgba(255,255,255,0.2);
    transform: translateY(-2px);
    color: var(--blanc) !important;
}

.page_404_search form {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--gris-card);
    border: 1px solid var(--glass-border);
    border-radius: 50px;
    padding: 10px 20px;
    max-width: 400px;
    margin: 0 auto;
    transition: border-color 0.3s, box-shadow 0.3s;
}

.page_404_search form:focus-within {
    border-color: rgba(225,37,35,0.4);
    box-shadow: 0 0 0 3px rgba(225,37,35,0.1);
}

.page_404_search form svg {
    flex-shrink: 0;
    color: rgba(245,245,247,0.35);
}

.page_404_search input[type="search"] {
    background: transparent !important;
    border: none !important;
    outline: none !important;
    color: var(--blanc) !important;
    font-size: 14px !important;
    width: 100%;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
}

.page_404_search input[type="search"]::placeholder {
    color: rgba(245,245,247,0.3);
}

/* 404 responsive: tablet */
@media (max-width: 768px) {
    .page_404_number {
        gap: 4px;
    }

    .page_404_actions {
        flex-direction: column;
        gap: 10px;
    }

    .page_404_btn {
        width: 100%;
        justify-content: center;
        max-width: 280px;
    }
}

/* 404 responsive: mobile */
@media (max-width: 425px) {
    .page_404_content {
        padding: 30px 16px 60px;
    }

    .page_404_text br {
        display: none;
    }

    .page_404_coaster {
        opacity: 0.3;
    }
}
