/*
Theme Name: Youcap Child
Theme URI: https://youcap.fr/
Template: Divi
Author: Youcap
Author URI: https://youcap.fr/
Description: Smart. Flexible. Beautiful. Divi is the most powerful theme in our collection.
Version: 4.21.2.1772052251
Updated: 2026-02-25 21:44:11
*/

/* ============================================================
   VARIABLES & RESET
   ============================================================ */
:root {
    --color-gold: #c9a96e;
    --color-gold-light: #d4b980;
    --color-gold-dark: #a68c6d;
    --color-dark: #1a1a2e;
    --color-dark-lighter: #232342;
    --color-text-light: #b8b8cc;
    --color-text-muted: rgba(184, 184, 204, 0.6);
    --color-white: #ffffff;
    --color-body-bg: #f9f6f2;
    --transition-smooth: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    --shadow-nav: 0 4px 24px rgba(0, 0, 0, 0.06);
    --shadow-nav-scroll: 0 4px 30px rgba(0, 0, 0, 0.12);
}

/* ============================================================
   NAVBAR / HEADER GLOBAL
   ============================================================ */

/* --- Header section wrapper --- */
#et-pb-gf-header .et_pb_section,
.et-l--header .et_pb_section {
    background: rgba(255, 255, 255, 0.97) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: var(--shadow-nav) !important;
    border-bottom: 2px solid var(--color-gold) !important;
    transition: var(--transition-smooth);
    position: relative;
    z-index: 9999;
}

/* Subtle gold shimmer line at bottom */
.et-l--header .et_pb_section::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 2px;
    background: linear-gradient(
        90deg,
        transparent 0%,
        var(--color-gold-light) 20%,
        var(--color-gold) 50%,
        var(--color-gold-light) 80%,
        transparent 100%
    );
}

/* --- Row padding --- */
.et-l--header .et_pb_row {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    max-width: 1200px !important;
}

/* --- Logo styling --- */
.et-l--header .et_pb_menu .et_pb_menu__logo-wrap img,
.et-l--header .et_pb_menu__logo img {
    max-height: 55px !important;
    width: auto !important;
    transition: var(--transition-smooth);
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.08));
}

.et-l--header .et_pb_menu:hover .et_pb_menu__logo-wrap img {
    transform: scale(1.03);
}

/* --- Menu links styling --- */
.et-l--header .et_pb_menu ul.et-menu li a {
    color: #2d2d2d !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    padding: 10px 20px !important;
    position: relative;
    transition: var(--transition-smooth) !important;
}

/* Animated gold underline on hover */
.et-l--header .et_pb_menu ul.et-menu li a::after {
    content: '';
    position: absolute;
    bottom: 2px;
    left: 50%;
    width: 0;
    height: 2px;
    background: var(--color-gold);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    transform: translateX(-50%);
    border-radius: 2px;
}

.et-l--header .et_pb_menu ul.et-menu li a:hover::after,
.et-l--header .et_pb_menu ul.et-menu li.current-menu-item a::after {
    width: 60%;
}

.et-l--header .et_pb_menu ul.et-menu li a:hover {
    color: var(--color-gold) !important;
}

/* Active/current page */
.et-l--header .et_pb_menu ul.et-menu li.current-menu-item a {
    color: var(--color-gold-dark) !important;
}

/* --- Bouton CTA dans le menu (optionnel : ajouter un lien "Réserver" plus tard) --- */
.et-l--header .et_pb_menu ul.et-menu li.menu-cta a {
    background: var(--color-gold);
    color: var(--color-white) !important;
    border-radius: 30px;
    padding: 10px 28px !important;
}

.et-l--header .et_pb_menu ul.et-menu li.menu-cta a:hover {
    background: var(--color-gold-dark);
    transform: translateY(-1px);
    box-shadow: 0 4px 15px rgba(201, 169, 110, 0.35);
}

.et-l--header .et_pb_menu ul.et-menu li.menu-cta a::after {
    display: none;
}

/* --- Menu mobile hamburger icon --- */
.et-l--header .et_pb_menu .mobile_menu_bar::before {
    color: var(--color-gold) !important;
    font-size: 28px !important;
}

/* Mobile menu dropdown */
.et-l--header .et_pb_menu .et_mobile_menu {
    background: rgba(255, 255, 255, 0.98) !important;
    border-top: 2px solid var(--color-gold);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    border-radius: 0 0 12px 12px;
    padding: 15px 0 !important;
}

.et-l--header .et_pb_menu .et_mobile_menu li a {
    padding: 12px 25px !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.04) !important;
    font-size: 14px !important;
    letter-spacing: 1px !important;
}

.et-l--header .et_pb_menu .et_mobile_menu li:last-child a {
    border-bottom: none !important;
}

/* ============================================================
   FOOTER GLOBAL
   ============================================================ */

/* --- Hide default Divi footer completely --- */
#main-footer {
    display: none !important;
}

/* --- Footer wrapper section --- */
.et-l--footer .et_pb_section {
    background: var(--color-dark) !important;
    position: relative;
    overflow: hidden;
}

/* Subtle gradient overlay for depth */
.et-l--footer .et_pb_section:first-child::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(
        90deg,
        transparent 0%,
        var(--color-gold) 30%,
        var(--color-gold-light) 50%,
        var(--color-gold) 70%,
        transparent 100%
    );
    opacity: 0.6;
}

/* Subtle radial glow effect */
.et-l--footer .et_pb_section:first-child::after {
    content: '';
    position: absolute;
    top: -80px;
    right: -80px;
    width: 250px;
    height: 250px;
    background: radial-gradient(circle, rgba(201, 169, 110, 0.06) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

/* --- Footer row --- */
.et-l--footer .et_pb_row {
    max-width: 1200px !important;
}

/* --- Footer logo --- */
.et-l--footer .et_pb_image img {
    max-width: 160px !important;
    filter: brightness(1.1);
    transition: var(--transition-smooth);
}

.et-l--footer .et_pb_image:hover img {
    filter: brightness(1.2);
    transform: scale(1.03);
}

/* --- Footer text --- */
.et-l--footer .et_pb_text p {
    color: var(--color-text-light) !important;
    font-size: 14px !important;
    line-height: 1.75 !important;
}

/* --- Footer headings (h3) --- */
.et-l--footer .et_pb_text h3 {
    color: var(--color-gold) !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    margin-bottom: 18px !important;
    position: relative;
    padding-bottom: 12px !important;
}

/* Gold underline accent for headings */
.et-l--footer .et_pb_text h3::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 35px;
    height: 2px;
    background: var(--color-gold);
    border-radius: 2px;
}

/* --- Footer links --- */
.et-l--footer .et_pb_text a {
    color: var(--color-text-light) !important;
    text-decoration: none !important;
    transition: var(--transition-smooth) !important;
    position: relative;
    display: inline-block;
}

.et-l--footer .et_pb_text a:hover {
    color: var(--color-gold) !important;
    transform: translateX(5px);
}

/* Arrow before links on hover */
.et-l--footer .et_pb_text p a::before {
    content: '›';
    opacity: 0;
    margin-right: 0;
    transition: var(--transition-smooth);
    color: var(--color-gold);
    font-weight: bold;
}

.et-l--footer .et_pb_text p a:hover::before {
    opacity: 1;
    margin-right: 6px;
}

/* --- Footer blurbs (contact info) --- */
.et-l--footer .et_pb_blurb {
    transition: var(--transition-smooth);
}

.et-l--footer .et_pb_blurb:hover {
    transform: translateX(3px);
}

.et-l--footer .et_pb_blurb .et_pb_main_blurb_image .et-pb-icon {
    color: var(--color-gold) !important;
    font-size: 20px !important;
}

.et-l--footer .et_pb_blurb .et_pb_module_header {
    color: var(--color-text-light) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    transition: var(--transition-smooth);
}

.et-l--footer .et_pb_blurb:hover .et_pb_module_header {
    color: var(--color-gold-light) !important;
}

/* --- Footer social icons --- */
.et-l--footer .et_pb_social_media_follow li a {
    background: rgba(201, 169, 110, 0.15) !important;
    border: 1px solid rgba(201, 169, 110, 0.25) !important;
    transition: var(--transition-smooth) !important;
    border-radius: 50% !important;
}

.et-l--footer .et_pb_social_media_follow li a:hover {
    background: var(--color-gold) !important;
    border-color: var(--color-gold) !important;
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(201, 169, 110, 0.3);
}

.et-l--footer .et_pb_social_media_follow li a .et-pb-icon {
    color: var(--color-gold-light) !important;
    transition: var(--transition-smooth) !important;
}

.et-l--footer .et_pb_social_media_follow li a:hover .et-pb-icon {
    color: var(--color-white) !important;
}

/* --- Footer bottom bar (copyright) --- */
.et-l--footer .et_pb_section:first-child > .et_pb_row:last-child {
    border-top: 1px solid rgba(201, 169, 110, 0.15) !important;
}

.et-l--footer .et_pb_section:first-child > .et_pb_row:last-child .et_pb_text p {
    color: var(--color-text-muted) !important;
    font-size: 13px !important;
    letter-spacing: 0.5px;
}

/* ============================================================
   RESPONSIVE TWEAKS
   ============================================================ */

/* Tablet */
@media (max-width: 980px) {
    .et-l--header .et_pb_row {
        padding-top: 8px !important;
        padding-bottom: 8px !important;
    }

    .et-l--header .et_pb_menu .et_pb_menu__logo-wrap img,
    .et-l--header .et_pb_menu__logo img {
        max-height: 45px !important;
    }

    .et-l--footer .et_pb_row {
        padding-left: 30px !important;
        padding-right: 30px !important;
    }

    .et-l--footer .et_pb_text h3::after {
        left: 50%;
        transform: translateX(-50%);
    }
}

/* Mobile */
@media (max-width: 767px) {
    .et-l--header .et_pb_menu .et_pb_menu__logo-wrap img,
    .et-l--header .et_pb_menu__logo img {
        max-height: 40px !important;
    }

    .et-l--footer .et_pb_section {
        padding: 40px 0 20px !important;
    }

    .et-l--footer .et_pb_image img {
        max-width: 130px !important;
    }

    .et-l--footer .et_pb_text h3 {
        font-size: 15px !important;
        text-align: center;
    }

    .et-l--footer .et_pb_text h3::after {
        left: 50%;
        transform: translateX(-50%);
    }

    .et-l--footer .et_pb_text p {
        text-align: center;
    }

    .et-l--footer .et_pb_text p a:hover {
        transform: none;
    }

    .et-l--footer .et_pb_text p a::before {
        display: none;
    }

    .et-l--footer .et_pb_social_media_follow {
        text-align: center !important;
    }

    .et-l--footer .et_pb_image {
        text-align: center !important;
    }
}

/* ============================================================
   SMOOTH SCROLLBAR & GLOBAL POLISH
   ============================================================ */
html {
    scroll-behavior: smooth;
}

/* Remove Divi default footer attribution bar if somehow still visible */
#footer-bottom {
    display: none !important;
}

/* Improve body text rendering */
body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
