/* --- HIGH FIDELITY HEADER CUSTOM STYLES (FIXED STACKING) --- */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap');

/* RESET & BASE FONTS */
.z-header-top,
.z-header-mid,
.z-navbar {
    font-family: 'Manrope', sans-serif !important;
    box-sizing: border-box;
}

/* CRITICAL FIX: Ensure proper document flow */
body {
    font-family: 'Manrope', sans-serif;
}

/* FIX: Remove the gap caused by switching from fixed to relative header */
.z-hero {
    margin-top: 0 !important;
}

/* 1. TOP BAR - HIGHEST LAYER */
.z-header-top {
    background-color: #ffffff !important;
    border-bottom: 1px solid #e5e5e5 !important;
    padding: 6px 0 !important;
    /* Even narrower */
    font-size: 11px !important;
    /* Back to 11px match */
    font-weight: 600 !important;
    color: #555 !important;
    letter-spacing: 0.2px !important;
    position: relative !important;
    z-index: 1002 !important;
    width: 100% !important;
    order: 1 !important;
}

.z-top-flex {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.z-top-menu {
    display: flex !important;
    gap: 20px !important;
}

.z-top-menu a {
    color: #666 !important;
    text-decoration: none !important;
    transition: color 0.2s !important;
}

.z-top-menu a:hover {
    color: #D4AF37 !important;
}

.z-top-socials {
    display: flex !important;
    gap: 15px !important;
}

.z-top-socials a {
    color: #aaa !important;
    font-size: 12px !important;
    /* Smaller icons */
    transition: color 0.2s !important;
}

.z-top-socials a:hover {
    color: #D4AF37 !important;
}


/* 2. MID HEADER - MIDDLE LAYER */
.z-header-mid {
    background-color: #fff !important;
    padding: 30px 0 !important;
    /* Increased padding for better logo visibility */
    position: relative !important;
    z-index: 1001 !important;
    width: 100% !important;
    order: 2 !important;
}

.z-mid-flex {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.z-logo-wrapper img {
    height: 100px !important;
    /* Increased for better text readability */
    display: block !important;
}

.z-header-widgets {
    display: flex !important;
    gap: 35px !important;
}

.z-h-widget {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.z-hw-icon {
    width: 36px !important;
    height: 36px !important;
    border: none !important;
    display: flex !important;
    align-items: center;
    justify-content: center !important;
    color: #D4AF37 !important;
    font-size: 22px !important;
    background: transparent !important;
    transition: all 0.3s !important;
}

/* Visual match: Icons might not need borders depending on the image. Assuming clean icons. */

.z-hw-text {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    line-height: 1.2 !important;
}

.z-hw-text span {
    font-size: 9px !important;
    color: #999 !important;
    text-transform: uppercase !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 2px !important;
}

.z-hw-text strong {
    font-size: 12px !important;
    color: #333 !important;
    font-weight: 700 !important;
}


/* 3. NAVBAR - LOWEST HEADER LAYER */
.z-navbar {
    background: #fff !important;
    border-top: 1px solid #f0f0f0 !important;
    position: relative !important;
    z-index: 1000 !important;
    width: 100% !important;
    order: 3 !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03) !important;
}

.z-nav-flex {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    height: 60px !important;
    /* Compact */
}

.z-nav-menu {
    display: flex !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 100% !important;
    align-items: center !important;
    gap: 0 !important;
}

.z-nav-item {
    height: 100% !important;
    position: relative !important;
    display: flex !important;
    align-items: center !important;
}

.z-nav-link {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #222 !important;
    /* Darker black */
    text-transform: uppercase !important;
    text-decoration: none !important;
    padding: 0 18px !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    transition: all 0.2s !important;
    border-bottom: 3px solid transparent !important;
    letter-spacing: 0.3px !important;
}

.z-nav-link i {
    font-size: 10px !important;
    color: #ccc !important;
    margin-top: 0 !important;
}

.z-nav-item:hover .z-nav-link {
    color: #D4AF37 !important;
    /* border-bottom-color: #D4AF37 !important; REMOVED per user request */
    background: #fff !important;
    /* No gray bg on hover */
}

/* MEGA MENU */
.z-mega-menu {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    background: #fff !important;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.1) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(10px) !important;
    transition: all 0.2s ease-out !important;
    z-index: 10001 !important;
    /* border-top: 3px solid #D4AF37 !important;  REMOVED to prevent double line clash */
}

.z-mega-menu.full-width {
    width: 1200px !important;
    /* Wider */
    left: -150px !important;
    /* Adjusted centering */
}

.z-nav-item:hover .z-mega-menu {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

.z-mega-container {
    display: flex !important;
    padding: 0 !important;
}

.z-mega-col {
    flex: 1 !important;
    padding: 30px 20px !important;
    border-right: 1px solid #f5f5f5 !important;
}

.z-mega-col:last-child {
    border-right: none !important;
}

.z-mega-col h4 {
    font-family: 'Manrope', sans-serif !important;
    font-size: 11px !important;
    color: #888 !important;
    text-transform: uppercase !important;
    font-weight: 800 !important;
    margin: 0 0 20px 0 !important;
    letter-spacing: 1px !important;
}

.z-mega-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.z-mega-list li {
    margin-bottom: 12px !important;
}

.z-mega-list li a {
    font-size: 13px !important;
    color: #444 !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: 0.2s !important;
    display: inline-block !important;
}

.z-mega-list li a:hover {
    color: #D4AF37 !important;
    padding-left: 5px !important;
}

/* ACTIONS */
.z-nav-actions {
    display: flex !important;
    align-items: center !important;
    gap: 15px !important;
}

.z-lang-select {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: auto !important;
    min-width: 60px !important;
    height: 36px !important;
    padding: 0 10px !important;
    background: transparent !important;
    border: 1px solid #eaeaea !important;
    border-radius: 4px !important;
    cursor: pointer !important;
    position: relative !important;
}

/* LANG DROPDOWN & CURRENT LANG FIXES */
/* LANG DROPDOWN & CURRENT LANG FIXES */
.z-current-lang {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #444 !important;
    width: 100% !important;
    justify-content: space-between !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

.z-current-lang img {
    border: none !important;
    box-shadow: none !important;
}

.z-lang-dropdown {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    width: 100% !important;
    min-width: 80px !important;
    background: #fff !important;
    border: 1px solid #eee !important;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05) !important;
    padding: 5px 0 !important;
    border-radius: 4px !important;
    display: none !important;
    z-index: 10005 !important;
    margin-top: 5px !important;
}

.z-lang-select:hover .z-lang-dropdown {
    display: block !important;
}

.z-lang-dropdown a {
    display: block !important;
    padding: 6px 12px !important;
    font-size: 12px !important;
    color: #555 !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    transition: 0.2s !important;
    text-align: center !important;
}

.z-lang-dropdown a:hover {
    background: #f9f9f9 !important;
    color: #D4AF37 !important;
}

.z-btn-quote {
    background-color: #D4AF37 !important;
    color: #fff !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    height: 42px !important;
    padding: 0 25px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 4px !important;
    transition: transform 0.2s, background-color 0.2s !important;
}

.z-btn-quote:hover {
    background-color: #c4a02e !important;
    transform: translateY(-1px) !important;
}

/* ==============================================
   MOBILE RESPONSIVE FOR HEADER
   ============================================== */

/* Hide mobile toggle on desktop */
.z-mobile-toggle {
    display: none !important;
}

/* Tablet & Below */
@media (max-width: 1024px) {
    .z-header-widgets {
        gap: 20px !important;
    }

    .z-hw-text span {
        font-size: 8px !important;
    }

    .z-hw-text strong {
        font-size: 11px !important;
    }
}

/* Mobile */
@media (max-width: 768px) {

    /* Hide top bar on mobile */
    .z-header-top {
        display: none !important;
    }

    /* Simplify mid header */
    .z-header-mid {
        padding: 15px 0 !important;
    }

    .z-logo-wrapper img {
        height: 70px !important;
    }

    /* Hide info widgets on mobile */
    .z-header-widgets {
        display: none !important;
    }

    /* Navbar mobile */
    .z-navbar {
        height: 70px !important;
    }

    .z-nav-flex {
        height: 70px !important;
    }

    /* Show mobile toggle */
    .z-mobile-toggle {
        display: block !important;
        background: none !important;
        border: none !important;
        font-size: 24px !important;
        color: #0d2e1c !important;
        cursor: pointer !important;
        padding: 10px !important;
        margin-left: auto !important;
    }

    /* Mobile menu */
    .z-nav-menu {
        position: fixed !important;
        top: 130px !important;
        left: -100% !important;
        width: 100% !important;
        height: calc(100vh - 130px) !important;
        background: #fff !important;
        flex-direction: column !important;
        padding: 20px !important;
        transition: left 0.3s ease !important;
        overflow-y: auto !important;
        gap: 0 !important;
        align-items: flex-start !important;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1) !important;
        z-index: 9999 !important;
    }

    .z-nav-menu.active {
        left: 0 !important;
    }

    .z-nav-item {
        width: 100% !important;
        height: auto !important;
        border-bottom: 1px solid #eee !important;
        padding: 15px 0 !important;
    }

    .z-nav-link {
        padding: 10px 0 !important;
        height: auto !important;
        border-bottom: none !important;
    }

    /* Mobile mega menu */
    .z-mega-menu {
        position: static !important;
        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;
        box-shadow: none !important;
        border: none !important;
        padding: 15px 0 0 20px !important;
        display: none !important;
        width: 100% !important;
    }

    .z-nav-item.active .z-mega-menu {
        display: block !important;
    }

    .z-mega-container {
        flex-direction: column !important;
    }

    .z-mega-col {
        border-right: none !important;
        border-bottom: 1px solid #f5f5f5 !important;
        padding: 15px 10px !important;
    }

    .z-mega-col:last-child {
        border-bottom: none !important;
    }

    /* Mobile actions */
    .z-nav-actions {
        width: 100% !important;
        flex-direction: column !important;
        gap: 10px !important;
        margin-top: 20px !important;
        padding-top: 20px !important;
        border-top: 1px solid #eee !important;
    }

    .z-lang-select {
        width: 100% !important;
    }

    .z-btn-quote {
        width: 100% !important;
        justify-content: center !important;
    }
}

/* Small Mobile */
@media (max-width: 480px) {
    .z-logo-wrapper img {
        height: 60px !important;
    }

    .z-navbar {
        height: 60px !important;
    }

    .z-nav-flex {
        height: 60px !important;
    }

    .z-nav-menu {
        top: 115px !important;
        height: calc(100vh - 115px) !important;
    }

    .z-mobile-toggle {
        font-size: 22px !important;
    }
}