/* --- Components Styles --- */

/* Logo */
.custom-logo-link img {
    max-width: 250px; /* max-width for larger screens */
    height: auto;
    transition: transform 0.3s ease;
    display: block;
}

.custom-logo-link:hover img {
    transform: scale(1.02); /* Slight scale-up effect on hover */
}

@media screen and (max-width: 830px) {
    .custom-logo-link img {
        max-width: 200px; /* max-width for smaller screens */
    }
}

/* Base styles for buttons (custom or Gutenberg) */
.button,
.wp-block-button__link { /* Apply common styles to both */
    display: inline-block;
    cursor: pointer;
    padding: 13px 20px 10px 20px;
    border-radius: 5px;
    font-family: var(--button-font-family);
    text-decoration: none;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease; 
    font-size: 13px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

/* Default button colors (for .button if no specific color class, or for default Gutenberg button) */
.button,
.wp-block-button__link {
     color: var(--button-tertiary-text-color);
    background-color: var(--button-tertiary-bg-color);
    border: 1.5px solid var(--button-tertiary-border-color);
}
.button:hover,
.wp-block-button__link:hover {
    color: var(--button-tertiary-text-hover-color);
    background-color: var(--button-tertiary-bg-hover-color);
    border-color: var(--button-tertiary-border-hover-color);
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.button-primary,
.wp-block-button.is-style-primary-button .wp-block-button__link {
    color: var(--button-primary-text-color);
    background-color: var(--button-primary-bg-color);
    border: 1.5px solid var(--button-primary-border-color);
}
.button-primary:hover,
.wp-block-button.is-style-primary-button .wp-block-button__link:hover {
    background-color: var(--button-primary-bg-hover-color);
    color: var(--button-primary-text-hover-color);
    border-color: var(--button-primary-border-hover-color);
}

.button-secondary,
.wp-block-button.is-style-secondary-button .wp-block-button__link {
    background-color: var(--button-secondary-bg-color);
    color: var(--button-secondary-text-color);
    border: 1.5px solid var(--button-secondary-border-color);
}
.button-secondary:hover,
.wp-block-button.is-style-secondary-button .wp-block-button__link:hover {
    background-color: var(--button-secondary-bg-hover-color);
    color: var(--button-secondary-text-hover-color);
    border-color: var(--button-secondary-border-hover-color);
}
.button-tertiary,
.wp-block-button.is-style-tertiary-button .wp-block-button__link {
    color: var(--button-tertiary-text-color);
    background-color: var(--button-tertiary-bg-color);
    border: 1.5px solid var(--button-tertiary-border-color);
}
.button-tertiary:hover,
.wp-block-button.is-style-tertiary-button .wp-block-button__link:hover {
    color: var(--button-tertiary-text-hover-color);
    background-color: var(--button-tertiary-bg-hover-color);
    border-color: var(--button-tertiary-border-hover-color);
}

@media screen and (max-width: 830px) {
    .button {
        font-size: 14px;
    }
}

/* Back to Top Button */
.back-to-top-button {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 999;
    background-color: var(--color-brand);
    color: var(--color-text-light);
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    text-align: center;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out, transform 0.3s ease-in-out, background-color 0.3s ease;
}

.back-to-top-button svg {
    display: block;
    width: 60%;
    height: 60%;
    margin: 20% auto;
}

.back-to-top-button.show {
    opacity: 0.8;
    visibility: visible;
    transform: translateY(0);
}

.back-to-top-button:hover,
.back-to-top-button:active,
.back-to-top-button:focus {
    color: var(--color-text-light); /* Ensure the arrow stays white */
    opacity: 1; /* Make the button fully opaque on interaction */
}

/* Apply hover styles only if the device supports hover */
/* This ensures that hover effects are not applied on touch devices */
@media (hover: hover) and (pointer: fine) {
    .back-to-top-button:hover {
        background-color: var(--color-tertiary);
    }
}

/* Responsive Map */
.map-responsive {
    overflow: hidden;
    padding-bottom: 56.25%;
    position: relative;
    height: 0;
    margin-top: 2em;
    margin-bottom: 2em;
}

.map-responsive iframe {
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    max-width: 100%; /* Ensure iframe does not exceed its container's width */
    position: absolute;
    border: 0;
}

/* Search Widget (WordPress Block) */
.widget_block.widget_search {
    margin-bottom: 1.5em;
}

.widget_block.widget_search .wp-block-search__label {
    display: block;
    font-size: 1em;
    color: var(--color-text-dark);
    /* margin-top: 2.5em;  */
    margin-bottom: 0.8em;
    font-weight: bold;
    text-align: left;
}

.widget_block.widget_search .wp-block-search__inside-wrapper {
    width: 100% !important;
    border: 1px solid var(--color-text-dark);
    border-radius: 5px;
    background-color: var(--color-background-light);
    padding: 0;
}

.widget_block.widget_search .wp-block-search__input {
    width: 100%;
    padding: 10px 12px;
    border: none;
    font-family: var(--font-body);
    font-size: 0.95em;
    color: var(--color-text-dark);
    /* background-color: transparent; */
    box-sizing: border-box;
    border-radius: 5px;
}

.widget_block.widget_search .wp-block-search__input:focus {
    outline: none;
}

/* H3 Titles in Sidebar Widgets */
#sidebar .widget_block h3 {
    font-size: 1em;
    /* color: var(--color-brand); */
    margin-bottom: 0.8em;
    font-weight: bold;
}

/* Categories List in Block Widget */
.widget_block .wp-block-categories-list.wp-block-categories {
    list-style-type: none;
    padding-left: 0;
}

#sidebar .wp-block-column {
    padding: 0;
}

#sidebar ul {
    padding-left: 0;
}

/* --- Special Info Message --- */
.special-info-message {
    background-color: var(--color-brand);
    color: var(--color-text-dark); 
    padding: 0.25em 0.25em;
    margin-bottom: 1em; 
    /* border-radius: 5px; */
    text-align: center;
    font-size: 0.9em;
    /* line-height: 1.6; */
    width: 100%;
    box-sizing: border-box;
    margin-left: -20px;
    margin-right: -20px;
    width: calc(100% + 40px); 
}

.special-info-message .container {
    /* max-width: 960px; */
    margin-left: 0;
    margin-right: 0;;
}

.special-info-message p {
    margin: 0; /* Resets paragraph margins */
}

/* Styles for links inside the message */
.special-info-message a {
    color: var(--color-primary);
    text-decoration: underline;
    font-weight: bold;
}

.special-info-message a:hover {
    text-decoration: none;
}

/* --- CORRECTION MAILPOET --- */

/* Correction des champs de saisie (Email Input) et style de base */
.mailpoet_form input[type="email"],
.mailpoet_form .mailpoet_text {
    /* Annulation des styles 'inline' qui définissent la taille/padding */
    width: 100% !important; 
    box-sizing: border-box !important;
    
    /* Styles pour rendre l'input cohérent avec le reste du thème */
    padding: 10px 12px !important; 
    height: auto !important;
    margin: 0 0 10px 0 !important; 
    
    /* Correction de la police et taille (pour les grands écrans) */
    font-family: inherit !important; 
    font-size: 0.95em !important; 
    line-height: 1.5 !important;
    
    /* Application des styles visuels de base (cadre) */
    /* Utilisez une couleur de bordure par défaut de votre thème si elle existe */
    border: 1px solid var(--color-border-default, #ccc) !important; 
    border-radius: 5px !important; 
}

/* Correction du bouton "Je m'inscris" (pour qu'il n'occupe pas 100% de la largeur) */
.mailpoet_submit {
    /* Annule la largeur 100% de MailPoet et le force à prendre la largeur de son contenu */
    width: auto !important;
    margin: 15px auto 0 auto !important;
    
    /* Styles spécifiques du .button-tertiary (pour écraser l'inline) */
    display: inline-block !important;
    cursor: pointer !important;
    font-family: var(--button-font-family) !important;
    font-weight: bold !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    font-size: 13px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2) !important;
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease !important; 
    
    padding: 13px 20px 10px 20px !important;
    border-radius: 5px !important; 

    color: var(--button-tertiary-text-color) !important;
    background-color: var(--button-tertiary-bg-color) !important;
    border: 1.5px solid var(--button-tertiary-border-color) !important;
}

/* Style HOVER du bouton */
.mailpoet_submit:hover {
    color: var(--button-tertiary-text-hover-color) !important;
    background-color: var(--button-tertiary-bg-hover-color) !important;
    border-color: var(--button-tertiary-border-hover-color) !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2) !important; 
}

.mailpoet_form .mailpoet_paragraph {
    /* pour le centrage des éléments 'inline-block' à l'intérieur */
    text-align: center; 
}


@media screen and (max-width: 830px) {
    .mailpoet_form input[type="email"],
    .mailpoet_submit {
        /* Force la taille de police à 1em sur mobile, comme demandé */
        font-size: 1em !important;
    }
}
/* --- FIN CORRECTION MAILPOET --- */