/*
 Theme Name:   Destination Touristique (scTheme Child)
 Theme URI:    https://softiconic.com
 Description:  Thème enfant de scTheme
 Author:       Roberto Mas
 Author URI:   https://robertomas.com
 Template:     scTheme
 Version:      2.19.9
 Text Domain:  sctheme-child
*/

@import url("../scTheme/style.css");


.leaflet-bottom {
    bottom: 75px !important;
}

/* ==========================================================================
   Claim Listing — Bouton « Réclamer cette fiche » (v2.9)
   ========================================================================== */

.dt-claim-section {
    padding: 20px 16px;
    margin-top: 16px;
    border-top: 1px solid var(--dt-border, #e9ecef);
    background: linear-gradient(135deg, #f0f7ff 0%, #fafbfc 100%);
    border-radius: 8px;
    text-align: center;
}

.dt-claim-section .dt-sidebar__section-title {
    font-size: 0.95rem;
    text-transform: none;
    letter-spacing: 0;
    color: var(--dt-primary, #1a5276);
    margin: 0 0 6px;
    font-weight: 700;
}

.dt-claim-section p {
    font-size: 0.85em !important;
    color: var(--dt-text-light, #7f8c8d) !important;
    margin: 0 0 14px !important;
    line-height: 1.4;
}

/* Le bouton généré par GeoDir Claim Widget */
.dt-claim-section .gd-post-claim-wrap {
    margin: 0;
}

.dt-claim-section .gd-post-claim-wrap .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 12px 24px;
    font-size: 0.95rem;
    font-weight: 600;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.25s ease;
    background: var(--dt-accent, #27ae60);
    color: #fff;
    box-shadow: 0 2px 8px rgba(39, 174, 96, 0.2);
    line-height: 1.4;
}

.dt-claim-section .gd-post-claim-wrap .btn:hover {
    background: var(--dt-accent-hover, #219a52);
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(39, 174, 96, 0.35);
    color: #fff;
}

.dt-claim-section .gd-post-claim-wrap .btn:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(39, 174, 96, 0.2);
}

/* ==========================================================================
   Claim Modal — Popup « Connexion requise » (v2.9)
   ========================================================================== */

.dt-claim-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    animation: dtClaimFadeIn 0.2s ease;
}

@keyframes dtClaimFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.dt-claim-modal-box {
    position: relative;
    background: #fff;
    border-radius: 12px;
    padding: 36px 32px 28px;
    max-width: 400px;
    width: 90%;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    text-align: center;
    animation: dtClaimSlideUp 0.25s ease;
}

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

.dt-claim-modal-close {
    position: absolute;
    top: 12px;
    right: 16px;
    background: none;
    border: none;
    font-size: 1.6rem;
    color: #999;
    cursor: pointer;
    line-height: 1;
    padding: 4px 8px;
    transition: color 0.2s;
}

.dt-claim-modal-close:hover {
    color: #333;
}

.dt-claim-modal-icon {
    margin-bottom: 16px;
}

.dt-claim-modal-title {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--dt-primary, #1a5276);
    margin: 0 0 8px;
}

.dt-claim-modal-text {
    font-size: 0.9rem !important;
    color: var(--dt-text-light, #7f8c8d) !important;
    margin: 0 0 24px !important;
    line-height: 1.5;
}

.dt-claim-modal-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dt-claim-modal-btn {
    display: block;
    padding: 12px 24px;
    border-radius: 6px;
    font-size: 0.95rem;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    transition: all 0.25s ease;
    line-height: 1.4;
}

.dt-claim-modal-btn--primary {
    background: var(--dt-accent, #27ae60);
    color: #fff;
    box-shadow: 0 2px 8px rgba(39, 174, 96, 0.2);
}

.dt-claim-modal-btn--primary:hover {
    background: var(--dt-accent-hover, #219a52);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(39, 174, 96, 0.35);
    text-decoration: none;
}

.dt-claim-modal-btn--secondary {
    background: transparent;
    color: var(--dt-primary-light, #2980b9);
    border: 1.5px solid var(--dt-border, #e9ecef);
}

.dt-claim-modal-btn--secondary:hover {
    background: var(--dt-bg, #f8f9fa);
    color: var(--dt-primary, #1a5276);
    border-color: var(--dt-primary-light, #2980b9);
    text-decoration: none;
}

/* ==========================================================================
   UsersWP — Pages Login & Register (v2.9)
   ========================================================================== */

.uwp_page .site-main {
    display: flex;
    justify-content: center;
    padding: 60px 20px;
    min-height: 60vh;
    background: var(--dt-bg, #f8f9fa);
}

.uwp_page .site-main > article {
    max-width: 480px;
    width: 100%;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
    padding: 40px 36px;
}

/* Titres — cacher le titre WP en anglais, garder le titre UWP */
.uwp_page .site-main article > h1,
.uwp_page .site-main article > .entry-title {
    display: none;
}

.uwp_page .site-main .uwp_form h2,
.uwp_page .site-main article > h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--dt-primary, #1a5276);
    text-align: center;
    margin: 0 0 28px;
}

/* Champs de formulaire */
.uwp_page .uwp_form .form-control,
.uwp_page .uwp_form input[type="text"],
.uwp_page .uwp_form input[type="email"],
.uwp_page .uwp_form input[type="password"] {
    width: 100%;
    padding: 12px 16px;
    border: 1.5px solid var(--dt-border, #e9ecef);
    border-radius: 8px;
    font-size: 0.95rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    background: #fff;
    box-sizing: border-box;
}

.uwp_page .uwp_form .form-control:focus,
.uwp_page .uwp_form input[type="text"]:focus,
.uwp_page .uwp_form input[type="email"]:focus,
.uwp_page .uwp_form input[type="password"]:focus {
    outline: none;
    border-color: var(--dt-primary-light, #2980b9);
    box-shadow: 0 0 0 3px rgba(41, 128, 185, 0.12);
}

/* Labels */
.uwp_page .uwp_form label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--dt-text, #2c3e50);
    margin-bottom: 6px;
}

/* Espacement des rangées */
.uwp_page .uwp_form .uwp_form_row,
.uwp_page .uwp_form .form-group {
    margin-bottom: 18px;
}

/* Bouton submit */
.uwp_page .uwp_form button[type="submit"],
.uwp_page .uwp_form input[type="submit"] {
    display: block;
    width: 100%;
    padding: 14px 24px;
    border: none;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    background: var(--dt-accent, #27ae60);
    color: #fff;
    box-shadow: 0 2px 8px rgba(39, 174, 96, 0.2);
    transition: all 0.25s ease;
    margin-top: 8px;
}

.uwp_page .uwp_form button[type="submit"]:hover,
.uwp_page .uwp_form input[type="submit"]:hover {
    background: var(--dt-accent-hover, #219a52);
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(39, 174, 96, 0.35);
}

/* Liens bas de formulaire (Créer un compte / Mot de passe oublié) */
.uwp_page .site-main article > a,
.uwp_page .uwp_form ~ a,
.uwp_page .uwp-login-links a,
.uwp_page .uwp-footer-links a {
    display: inline-block;
    margin-top: 12px;
    font-size: 0.9rem;
    color: var(--dt-primary-light, #2980b9);
    text-decoration: none;
}

.uwp_page .site-main article > a:hover,
.uwp_page .uwp_form ~ a:hover,
.uwp_page .uwp-login-links a:hover,
.uwp_page .uwp-footer-links a:hover {
    color: var(--dt-primary, #1a5276);
    text-decoration: underline;
}

/* Checkbox "Se souvenir de moi" */
.uwp_page .uwp_form .form-check,
.uwp_page .uwp_form .uwp-remember-me {
    font-size: 0.85rem;
    color: var(--dt-text-light, #7f8c8d);
    margin-bottom: 16px;
}

/* Responsive */
@media (max-width: 540px) {
    .uwp_page .site-main > article {
        padding: 28px 20px;
        border-radius: 0;
        box-shadow: none;
    }

    .uwp_page .site-main {
        padding: 30px 0;
    }
}

/* ==========================================================================
   Header — Fix menu responsive (v2.19.4)
   Stratégie simple : menu horizontal ≥1561px, hamburger partout en-dessous.
   On utilise le header tablet (c19ca81) pour TOUT ce qui est <1561px
   car il a Logo + Zone membre + Hamburger.
   ========================================================================== */

/* 1. Contraindre le container logo */
.scheader > .e-con.e-child:first-child {
    flex-shrink: 1 !important;
    min-width: 0 !important;
    max-width: 250px !important;
}
.scheader > .e-con.e-child:last-child {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

/* 2. Empêcher le header flex de wrap */
.scheader > .elementor-container,
.scheader > .e-con {
    flex-wrap: nowrap !important;
}

/* 3. En-dessous de 1481px : cacher le header desktop + mobile,
   forcer le header tablet (c19ca81) qui a hamburger + Zone membre. */
@media (max-width: 1560px) {
    /* Cacher le header desktop (39aec2be) — spécificité max pour battre Elementor */
    body .elementor .elementor-element.elementor-element-39aec2be.e-con.e-parent {
        display: none !important;
    }
    /* Cacher le header mobile (43500c15) — pas de Zone membre */
    body .elementor .elementor-element.elementor-element-43500c15.e-con.e-parent {
        display: none !important;
    }
    /* Forcer le header tablet (c19ca81) visible partout */
    body .elementor .elementor-element.elementor-element-c19ca81.e-con.e-parent {
        display: flex !important;
    }
    /* Forcer hamburger sur le header tablet — cacher le menu horizontal */
    .elementor-element-c19ca81 .elementor-nav-menu--main {
        display: none !important;
    }
    .elementor-element-c19ca81 .elementor-menu-toggle {
        display: flex !important;
    }
    /* Zone membre + hamburger alignés à droite */
    .elementor-element-c19ca81 > .e-con:last-child {
        justify-content: flex-end !important;
    }
    /* Hamburger après Zone membre */
    .elementor-element-710b7e96 {
        order: 10 !important;
    }

    /* 4. Override Elementor's rule: @media(min-width:1201px) { .elementor-nav-menu--dropdown-tablet_extra .elementor-nav-menu--dropdown { display:none } }
       Le widget 710b7e96 a la classe dropdown-tablet_extra, donc Elementor cache le toggle+dropdown au dessus de 1200px.
       On force le toggle visible (déjà fait ligne 389) et on force le dropdown à apparaitre quand toggle est actif. */

    /* Override Elementor: autoriser le toggle à rester visible */
    body .elementor-nav-menu--dropdown-tablet_extra .elementor-menu-toggle {
        display: flex !important;
    }
    /* Override Elementor: style le dropdown */
    body .elementor-element-c19ca81 .elementor-nav-menu--dropdown-tablet_extra .elementor-nav-menu--dropdown,
    body .elementor-nav-menu--dropdown-tablet_extra .elementor-nav-menu--dropdown {
        position: absolute;
        top: 100%;
        right: 0;
        left: auto;
        width: 280px;
        background: #fff;
        box-shadow: 0 4px 20px rgba(0,0,0,0.12);
        z-index: 9999;
        padding: 10px 0;
        border-radius: 0 0 8px 8px;
    }
    /* Quand le toggle est aria-expanded=true, afficher le dropdown */
    body .elementor-element-710b7e96 .elementor-menu-toggle[aria-expanded="true"] ~ nav.elementor-nav-menu--dropdown,
    body .elementor-element-c19ca81 .elementor-menu-toggle[aria-expanded="true"] ~ nav.elementor-nav-menu--dropdown {
        display: block !important;
    }
    /* Quand le toggle n'est pas actif, cacher le dropdown */
    body .elementor-element-710b7e96 .elementor-menu-toggle[aria-expanded="false"] ~ nav.elementor-nav-menu--dropdown,
    body .elementor-element-c19ca81 .elementor-menu-toggle[aria-expanded="false"] ~ nav.elementor-nav-menu--dropdown {
        display: none !important;
    }
    /* Style des liens du dropdown */
    body .elementor-element-c19ca81 .elementor-nav-menu--dropdown li {
        display: block !important;
        width: 100% !important;
    }
    body .elementor-element-c19ca81 .elementor-nav-menu--dropdown li a {
        display: block !important;
        padding: 12px 24px !important;
        color: #333 !important;
        font-size: 15px !important;
        border-bottom: 1px solid #f0f0f0;
    }
    body .elementor-element-c19ca81 .elementor-nav-menu--dropdown li a:hover {
        background: #f5f5f5 !important;
        color: #0073aa !important;
    }
}

/* 5. Fix hamburger icon invisible sur fond blanc :
   Le SVG embarque <style>.st0{fill:#FFF}</style> qui bat nos sélecteurs.
   On cible .st0 dans le contexte du toggle + svg path en fallback. */
.scheader .elementor-menu-toggle {
    color: #333 !important;
}
.scheader .elementor-menu-toggle svg,
.scheader .elementor-menu-toggle svg path,
.scheader .elementor-menu-toggle svg .st0,
.scheader .elementor-menu-toggle .e-font-icon-svg,
.scheader .elementor-menu-toggle i {
    fill: #333 !important;
    color: #333 !important;
}
/* Quand sticky (fond blanc confirmé), hamburger aussi visible */
.sticky .elementor-menu-toggle svg,
.sticky .elementor-menu-toggle svg path,
.sticky .elementor-menu-toggle svg .st0,
.sticky .elementor-menu-toggle .e-font-icon-svg,
.sticky .elementor-menu-toggle i {
    fill: #333 !important;
    color: #333 !important;
}