.site-footer {
    position: relative;
    margin-top: 30px;
    background: #00e5ff;
    color: #111827;
    padding: 64px 0 34px;
    overflow: hidden;
}

.site-footer::before,
.site-footer::after {
    content: "";
    position: absolute;
    width: 280px;
    height: 280px;
    background: radial-gradient(circle at center, rgba(255, 214, 153, 0.12) 0%, rgba(255, 214, 153, 0) 70%);
    z-index: 1;
}

.site-footer::before {
    top: -80px;
    right: -60px;
}

.site-footer::after {
    bottom: -120px;
    left: -80px;
}

.site-footer .content_wrap {
    position: relative;
    z-index: 2;
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 36px;
}

.footer-brand h5 {
    font-size: 22px;
    margin-bottom: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #111827;
    font-weight: 900;
}

.footer-brand p {
    margin: 0 0 18px;
    color: #1f2937;
    line-height: 1.6;
    font-weight: 500;
}

.footer-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 18px;
    border-radius: 999px;
    background: #111827;
    color: #00e5ff;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 14px 36px rgba(17, 24, 39, 0.2);
}

.footer-cta:hover {
    transform: translateY(-2px);
}

.site-footer h5 {
    margin: 0 0 14px;
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
   	color: #111827;
}

.site-footer ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 8px;
}

.site-footer li a {
    color: #374151;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    transition: color .2s ease;
}

.site-footer li a:hover {
    color: #ffffff;
}

.footer-contact p {
    margin: 0 0 10px;
    color: #1f2937;
    font-size: 14px;
    font-weight: 500;
}

.footer-contact span {
    display: block;
    margin-top: 6px;
    font-weight: 800;
    color: #111827;
}

.footer-newsletter p {
    margin: 0 0 14px;
    color: #1f2937;
    font-size: 14px;
    font-weight: 500;
}

.footer-newsletter form {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.footer-newsletter input[type="email"] {
    flex: 1 1 220px;
    border-radius: 12px;
    border: none;
    padding: 12px 14px;
    font-size: 14px;
    background: rgba(17,24,39,0.06);
    color: #111827;
    font-weight: 600;
}

.footer-newsletter input::placeholder {
    color: rgba(17,24,39,0.5);
}

.footer-newsletter button {
    border: none;
    border-radius: 12px;
    background: #111827;
    color: #00e5ff;
    font-weight: 700;
    padding: 12px 18px;
    cursor: pointer;
}

.footer-newsletter button:hover {
    background: rgba(255, 214, 153, 1);
}

.footer-meta {
    margin-top: 44px;
    padding-top: 24px;
    border-top: 1px solid rgba(17,24,39,0.1);
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: space-between;
    align-items: center;
    color: #374151;
    font-weight: 600;
    font-size: 13px;
}

.footer-social {
    display: flex;
    gap: 12px;
}

.footer-social a {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(17,24,39,0.08);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #111827;
    text-decoration: none;
    font-size: 16px;
    transition: transform .2s ease, background .2s ease;
}

.footer-social a:hover {
    transform: translateY(-2px);
    background: rgba(255,255,255,0.32);
}

@media (max-width: 768px) {
    .site-footer {
        padding: 48px 0 28px;
    }

    .footer-grid {
        gap: 28px;
    }

    .footer-newsletter form {
        flex-direction: column;
    }

    .footer-newsletter button {
        width: 100%;
    }
}

.copyright_wrap {
    display: none !important;
}

/* === Nouveau Style "Pill" de l'Accueil === */
.menu_user_login {
    position: absolute !important;
    bottom: 0 !important;  /* Align exactly with the bottom of the header, next to the tabs */
    right: 0 !important;
    top: auto !important;
    z-index: 99999 !important;
}
.menu_user_login a,
.top_panel_wrap .menu_user_login a {
    background: #00e5ff !important; /* Bleu cyan du filtre */
    color: #111827 !important; /* Texte noir */
    padding: 12px 24px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    border-radius: 12px 0 0 12px !important; /* Smooth corner on left to stick to the right edge */
    display: inline-block !important;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2) !important;
    white-space: nowrap !important;
    border: none !important;
}
.menu_user_login a:hover,
.top_panel_wrap .menu_user_login a:hover {
    background: #00bfe6 !important;
}

/* Hide Unused Elements (original login space, phone, address) */
.contact_field_all { display: none !important; }

/* Let the absolute/fixed items escape their containers */
.top_panel_top { height: auto !important; border: none !important; padding: 0 !important; position: static !important; overflow: visible !important; background: transparent !important; }
.top_panel_middle { height: auto !important; border: none !important; padding: 0 !important; position: static !important; overflow: visible !important; background: transparent !important; }

/* === Hero & header enhancements === */
.hero-brand {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
    flex-wrap: wrap;
}

.hero-logo-orbit {
    position: relative;
    width: 88px;
    height: 88px;
    display: grid;
    place-items: center;
}

.hero-logo-ring {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.45);
    box-shadow: 0 0 24px rgba(255, 255, 255, 0.25), inset 0 0 12px rgba(255, 255, 255, 0.18);
    animation: heroOrbit 9s linear infinite;
}

.hero-logo-icon {
    font-size: 38px;
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.25));
    animation: heroIconPulse 3s ease-in-out infinite;
}

.hero-title-text {
    text-align: left;
    color: #fff;
}

.hero-main-title {
    margin: 0;
    font-size: clamp(42px, 6vw, 64px);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: linear-gradient(120deg, #fff 0%, #ffd9b0 50%, #fff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.hero-subtitle {
    margin: 4px 0 0;
    font-size: 16px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #f7f3ef;
}

.hero-kicker {
    margin-top: 12px;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #ffe3c4;
}

.hero-background-carousel .bg-slide.active {
    animation: heroZoom 18s ease-in-out infinite alternate;
    filter: brightness(0.95);
}

.hero-details-carousel .hero-card {
    /* Glassmorphism -> White clean cards (smaller + responsive) */
    width: 280px;
    max-width: 92vw;
    border-radius: 16px;
    background: #ffffff;
    color: #111827;
    border: 1px solid rgba(17, 24, 39, 0.08);
    box-shadow: 0 18px 44px rgba(17, 24, 39, 0.16);
    backdrop-filter: none;
    overflow: hidden;

    opacity: 0;
    transform: translateY(12px) scale(0.98);
    animation: cardStaggerIn .7s cubic-bezier(0.19, 1, 0.22, 1) forwards;
    animation-delay: var(--card-delay, 0ms);

    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.hero-details-carousel .hero-card:hover {
    transform: translateY(-8px);
    border-color: rgba(255, 107, 53, 0.28);
    box-shadow: 0 26px 70px rgba(17, 24, 39, 0.22);
}

.hero-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 310px;
    transform-style: preserve-3d;
    animation: autoFlip 10s infinite;
    animation-delay: var(--card-delay, 0ms);
}

.hero-card-face {
    position: absolute;
    inset: 0;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.hero-card-front {
    padding: 16px 16px 14px;
}

.hero-card-back {
    transform: rotateY(180deg);
}

.hero-card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.hero-card-price {
    font-weight: 900;
    font-size: 18px;
    color: #00e5ff;
    margin-top: 10px;
}

.hero-card-title {
    font-weight: 800;
    font-size: 16px;
    margin-top: 8px;
    color: #0f172a;
}

.hero-card-details {
    font-size: 13px;
    line-height: 1.35;
    color: #475569;
    margin-top: 10px;
}

.hero-card-meta span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 10px;
    background: rgba(255, 107, 53, 0.10);
    color: #475569;
    font-size: 12px;
    font-weight: 700;
}

/* === Navigation entrance animation === */
.nav-animated .menu_main_nav > li {
    opacity: 0;
    transform: translateY(-10px) scale(0.94);
    filter: blur(6px);
    transform-origin: center;
    animation: navConvergeIn .9s cubic-bezier(0.19, 1, 0.22, 1) forwards;
    animation-delay: var(--item-delay, 0ms);
}

body:not(.nav-animated) .menu_main_nav > li {
    opacity: 1;
    transform: none;
    animation: none;
}

.menu_main_nav > li > a {
    position: relative;
    display: inline-flex;
    gap: 8px;
    align-items: center;
    padding: 10px 16px;
    border-radius: 999px;
}

.menu_main_nav > li > a::after {
    /* Retirer le tiret/underline */
    display: none;
}

.menu_main_nav > li > a:hover::after,
.menu_main_nav > li.menu_hover > a::after {
    display: none;
}

/* 4. Tab Bar Background */
/* "blanc cassé" for the whole header structure to replace the dark blue */
body .top_panel_wrap, 
body .top_panel_wrap_inner, 
body .top_panel_bottom {
    background: #f0f2f5 !important; /* Blanc cassé / Off-white */
    border: none !important;
    position: relative !important; /* Context for absolute positioning of login button */
    z-index: 9999 !important; /* Ensure dropdowns are above hero */
}
.top_panel_bottom {
    padding: 0 !important;
    margin-top: 55px !important; /* Space from top to clear fixed logo and login */
}
.top_panel_bottom .content_wrap {
    display: flex !important;
    justify-content: center !important; /* Center the menu */
    align-items: flex-end !important; /* Align tabs to bottom edge */
    padding: 0 200px !important; /* Space for logo and login */
    background: transparent !important;
}

/* 5. Menu / Tab Items Styling (like the filter tabs) */
.menu_main_nav_area { display: flex !important; justify-content: center !important; width: 100% !important; }
.menu_main_nav {
    justify-content: center !important;
    flex-wrap: nowrap !important;
    display: flex !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    background: transparent !important;
}
.menu_main_nav > li {
    margin: 0 !important;
    padding: 0 2px !important;
    background: transparent !important;
}
/* Force specificity against theme's a tags */
ul#menu_main > li > a,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li > a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 46px !important;
    line-height: normal !important;
    padding: 0 14px !important;
    background: #ffffff !important; /* White background for inactive tabs */
    color: #111827 !important; /* BLACK TEXT so it is visible on white background! */
    font-weight: 800 !important;
    font-size: 14px !important;
    letter-spacing: 0.3px !important;
    border-radius: 12px 12px 0 0 !important;
    transition: all 150ms ease !important;
    text-decoration: none !important;
    border-bottom: 3px solid transparent !important;
    white-space: nowrap !important; /* PREVENT TEXT WRAPPING */
}

/* 6. Active Tab (same as filter selection: cyan and black text) */
ul#menu_main > li.current-menu-item > a,
ul#menu_main > li > a:hover,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li.current-menu-item > a,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li > a:hover {
    background: #00e5ff !important;
    color: #111827 !important;
    border-bottom-color: transparent !important;
}

/* Hide default theme orange circles on active tabs */
ul#menu_main > li.current-menu-item > a::before,
ul#menu_main > li.current-menu-item > a::after,
ul#menu_main > li > a:hover::before,
ul#menu_main > li > a:hover::after,
.menu_main_nav > li.current-menu-item > a::before,
.menu_main_nav > li.current-menu-item > a::after {
    display: none !important;
    opacity: 0 !important;
}

/* === Property cards refresh === */
.sc_property_item {
    border-radius: 16px;
    border: 1px solid rgba(0, 0, 0, 0.05);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    transform: translateY(0);
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.sc_property_item:hover {
    transform: translateY(-10px) scale(1.01);
    border-color: rgba(255, 107, 53, 0.35);
    box-shadow: 0 22px 60px rgba(16, 24, 40, 0.18);
}

.sc_property_item .sc_property_item_thumb img,
.sc_property_item_featured img,
.sc_property_item_featured .post_thumb img {
    border-radius: 14px;
    width: 100%;
    height: 240px;
    object-fit: cover;
    display: block;
}

.sc_property_item_featured {
    position: relative;
    overflow: hidden;
    height: 240px;
}

.sc_property_item_featured .post_thumb {
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.sc_property_item_featured .post_thumb a {
    display: block;
    width: 100%;
    height: 100%;
}

.sc_property_item .sc_property_item_title a {
    font-size: 18px;
    font-weight: 700;
    color: #1f2937;
}

.sc_property_item .sc_property_item_price {
    font-size: 20px;
    font-weight: 800;
    color: #00e5ff;
}

.sc_property_item .sc_property_item_meta {
    display: flex;
    gap: 10px;
    margin-top: 6px;
}

.sc_property_item .sc_property_item_meta span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 10px;
    background: rgba(255, 107, 53, 0.08);
    color: #5b6171;
    font-size: 12px;
    font-weight: 600;
}

.sc_property_item_status {
    padding: 6px 10px;
    border-radius: 10px;
    background: linear-gradient(135deg, #ff8f5f, #00e5ff);
    color: #fff;
    font-weight: 700;
    font-size: 12px;
    box-shadow: 0 10px 24px rgba(255, 107, 53, 0.3);
}

/* Smaller quick cards for API-driven listings */
.quick-search-card {
    border-radius: 14px !important;
    box-shadow: 0 12px 34px rgba(17, 24, 39, 0.14) !important;
    overflow: hidden;
}

/* === Animations === */
@keyframes heroOrbit {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

@keyframes heroIconPulse {
    0%, 100% {
        transform: scale(1);
        text-shadow: 0 0 0 rgba(255, 255, 255, 0.3);
    }
    50% {
        transform: scale(1.08);
        text-shadow: 0 0 16px rgba(255, 255, 255, 0.55);
    }
}

@keyframes heroZoom {
    0% {
        transform: scale(1);
    }
    100% {
        transform: scale(1.07);
    }
}

@keyframes navConvergeIn {
    0% {
        opacity: 0;
        transform: translateX(var(--nav-from-x, 0px)) translateY(-10px) scale(0.92);
        filter: blur(10px);
    }
    70% {
        opacity: 1;
        transform: translateX(0px) translateY(2px) scale(1.01);
        filter: blur(0px);
    }
    100% {
        opacity: 1;
        transform: translateX(0px) translateY(0) scale(1);
        filter: blur(0px);
    }
}

@keyframes cardStaggerIn {
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes autoFlip {
    0%, 49.9% {
        transform: rotateY(0deg);
    }
    50%, 99.9% {
        transform: rotateY(180deg);
    }
    100% {
        transform: rotateY(360deg);
    }
}

@media (prefers-reduced-motion: reduce) {
    .nav-animated .menu_main_nav > li,
    .hero-details-carousel .hero-card,
    .hero-card-inner {
        animation: none !important;
        transform: none !important;
        opacity: 1 !important;
        filter: none !important;
    }
}



/* Logo fixe en haut à gauche (au-dessus de tout) */
.logo-corner-fixed {
    /* header centering variables: adjust if your top band height changes */
    --header-top-height: 88px; /* approximate height of the top band (adjustable) */
    --logo-size: 160px; /* visible size of the logo (adjustable) */

    position: fixed;
    left: 12px;
    /* vertically center the logo within the top band */
    top: calc(var(--header-top-height) / 2 - var(--logo-size) / 2 + 4px);
    z-index: 10001;
    padding: 6px 10px;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0;
    backdrop-filter: none !important;
}

.logo-container {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    text-decoration: none;
}

.logo-3d-wrapper {
    perspective: 1000px;
    display: inline-block;
    width: var(--logo-size);
    height: var(--logo-size);
}

.logo-coin {
    position: relative;
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    animation: none;
}

.logo-face {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.logo-front {
    transform: rotateY(0deg);
}

.logo-back {
    transform: rotateY(180deg);
}

.logo-face img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

@keyframes rotateCoin {
    0% {
        transform: rotateY(0deg);
    }
    50% {
        transform: rotateY(180deg);
    }
    100% {
        transform: rotateY(360deg);
    }
}

.logo-text-wrapper {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-left: 0;
}

.logo-name {
    display: none;
}

.logo-corner .logo_slogan {
    font-size: 12px;
    color: #000000;
    font-weight: 500;
    text-transform: none;
    margin-top: 2px;
}

/* Position relative pour le conteneur du logo */
.top_panel_middle {
    position: relative;
}

/* Ajustement pour que le logo soit bien dans l'angle */
.contact_logo {
    position: relative;
}

/* === Sous-menus (Dropdowns) === */
/* Style du conteneur de sous-menu */
ul.menu_main_nav > li > ul.sub-menu,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li > ul.sub-menu,
ul.menu_main_nav > li > ul.sub-menu > li.menu-item-has-children > ul.sub-menu,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li > ul.sub-menu > li.menu-item-has-children > ul.sub-menu {
    background: #ffffff !important;
    border-radius: 0 0 12px 12px !important;
    box-shadow: 0 14px 30px rgba(0,0,0,0.15) !important;
    padding: 10px 0 !important;
    margin: 0 !important;
    border-top: 2px solid #00e5ff !important;
    display: none;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    width: 260px !important;
    z-index: 99999 !important;
}

/* 3ème niveau: sous-menu décalé à droite */
ul.menu_main_nav > li > ul.sub-menu > li.menu-item-has-children > ul.sub-menu,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li > ul.sub-menu > li.menu-item-has-children > ul.sub-menu {
    top: 0 !important;
    left: 100% !important;
    margin-left: 2px !important;
    border-top: none !important;
    border-left: 2px solid #00e5ff !important;
    border-radius: 0 12px 12px 12px !important;
}

/* Suppression des points de liste */
ul.menu_main_nav > li > ul.sub-menu li,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li > ul.sub-menu li {
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
}

/* Liens du sous-menu */
ul.menu_main_nav > li > ul.sub-menu li > a,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li > ul.sub-menu li > a {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 12px 20px !important;
    color: #111827 !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    background: transparent !important;
    border-radius: 0 !important;
    border: none !important;
    border-bottom: none !important;
    text-align: left !important;
    height: auto !important;
    white-space: normal !important;
}

/* Flèche pour indiquer qu'il y a un sous-menu */
ul.menu_main_nav > li > ul.sub-menu > li.menu-item-has-children > a::after,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li > ul.sub-menu > li.menu-item-has-children > a::after {
    content: "►";
    font-size: 10px;
    color: #888;
    margin-left: auto;
    display: inline-block;
}

/* Hover du sous-menu */
ul.menu_main_nav > li > ul.sub-menu li > a:hover,
.top_panel_wrap .menu_main_nav_area ul#menu_main > li > ul.sub-menu li > a:hover {
    background: rgba(0, 229, 255, 0.1) !important;
    color: #00e5ff !important;
}

