/* ==========================================================================
 * NORDIC LUXURY HEADER REDESIGN
 * ========================================================================== */

/* --- 1. Base Header Adjustments --- */
.site-header {
    background-color: #ffffff !important;
    border-bottom: none !important; /* Removed subtle bottom border as requested */
    padding: 15px 0 !important;
    margin-bottom: 0 !important;
    position: relative !important;
    z-index: 9999 !important;
}

/* Master container */
.site-header > .col-full {
    max-width: 65.146em !important; /* Matches main content container width precisely */
    margin: 0 auto !important;
    padding: 0 40px !important;
    position: relative;
    box-sizing: border-box;
}

/* ==========================================================================
   IMPORTANT WARNING: DO NOT CHANGE OR SHIFT THE LOGO POSITION ON THE HOMEPAGE.
   The left-edge alignment (max-width: 100%, padding: 0 25px) is custom-tailored
   and must remain untouched to prevent breaking the homepage branding layout.
   ========================================================================== */
/* Homepage header is extra wide for a modern hero feel */
.home .site-header > .col-full,
.front-page .site-header > .col-full {
    max-width: 100% !important; /* Push logo all the way to the left edge on large screens */
    padding: 0 25px !important; /* A comfortable padding to bring it back to the right slightly */
}

/* Hide old Storefront header elements and backgrounds */
.storefront-primary-navigation,
.boutique-primary-navigation {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
}

.storefront-primary-navigation .col-full {
    padding: 0 !important;
    margin: 0 !important;
    max-width: none !important;
}

/* --- 2. Flexbox Header Layout --- */
.nordic-header-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    gap: 20px;
}

/* Brand (Left) */
.site-branding {
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
    display: flex !important;
    align-items: center !important;
    flex: 0 0 auto !important;
}

/* ==========================================================================
   IMPORTANT WARNING: DO NOT CHANGE OR SHIFT THE LOGO POSITION ON INTERNAL PAGES.
   The current alignment (margin-left: -115px, margin-top: -12px on desktop)
   is custom-tailored and must remain untouched to prevent breaking alignment.
   ========================================================================== */
/* Shift the logo on internal pages to the left and up for optical alignment (desktop only) */
@media screen and (min-width: 768px) {
    body:not(.home):not(.front-page) .site-branding {
        margin-left: -115px !important; /* Shifted further left as requested by user */
        margin-top: -12px !important; /* Moved up a little bit more as requested by user */
    }
}

.site-branding img {
    max-width: 230px !important; /* Increased from 180px for better readability */
    height: auto !important;
    display: block !important;
}

/* Navigation (Center) */
.main-navigation {
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
    flex: 1 !important;
    display: flex !important;
    justify-content: center !important;
}

/* Force the intermediate WordPress container to stretch and center the menu list */
.main-navigation .primary-navigation {
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
    float: none !important;
}

.main-navigation ul.menu,
.main-navigation ul.nav-menu {
    display: flex !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    list-style: none !important;
}

.main-navigation ul.menu > li,
.main-navigation ul.nav-menu > li {
    margin: 0 20px !important;
    padding: 0 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
}

.main-navigation ul.menu > li > a,
.main-navigation ul.nav-menu > li > a {
    color: #1a1a1a !important;
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    padding: 10px 0 !important;
    display: block !important;
    position: relative !important;
    text-decoration: none !important;
}

/* Remove default blue outline on header links */
.site-header a:focus,
.main-navigation a:focus,
.nordic-header-utilities a:focus,
.site-branding a:focus {
    outline: none !important;
    box-shadow: none !important;
}

/* Custom Underline Hover Effect */
.main-navigation ul.menu > li > a::after,
.main-navigation ul.nav-menu > li > a::after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 0% !important;
    height: 2px !important;
    background-color: #cca270 !important;
    transition: width 0.3s ease !important;
}

.main-navigation ul.menu > li > a:hover::after,
.main-navigation ul.nav-menu > li > a:hover::after {
    width: 100% !important;
}

.main-navigation ul.menu > li > a:hover,
.main-navigation ul.nav-menu > li > a:hover {
    color: #cca270 !important;
}

/* Utilities (Right) */
.nordic-header-utilities {
    display: flex !important;
    align-items: center !important;
    gap: 20px !important;
    flex: 0 0 auto !important;
}

.nordic-header-utilities a {
    color: #1a1a1a !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    transition: color 0.3s ease, transform 0.3s ease !important;
}

.nordic-header-utilities a:hover {
    color: #cca270 !important;
    transform: translateY(-2px) !important;
}

.nordic-header-utilities svg {
    display: block !important;
}

.nordic-cart-count {
    position: absolute !important;
    top: -6px !important;
    right: -8px !important;
    background: #cca270 !important;
    color: #fff !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    width: 16px !important;
    height: 16px !important;
    border-radius: 50% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    line-height: 1 !important;
}

/* ==========================================================================
   IMPORTANT WARNING: DO NOT CHANGE THE MOBILE HEADER ELEMENT ORDER OR LAYOUT.
   The layout order (Logo on left, Utilities in middle-right, Menu button on far right)
   is custom-tailored and must remain untouched.
   ========================================================================== */
/* --- 3. Mobile Layout Overrides --- */
@media screen and (max-width: 767px) {
    .site-header {
        padding: 10px 0 !important;
    }
    
    .site-header > .col-full {
        padding: 0 20px !important;
    }
    
    .nordic-header-inner {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        height: auto !important;
        min-height: 50px !important;
    }
    
    /* Order: Logo (Left), Search/Utilities (Middle-Right), Menu Button (Far Right) */
    
    /* 1. Logo (Left) */
    body:not(.home):not(.front-page) .site-branding,
    .site-branding {
        order: -1 !important;
        flex: 1 !important;
        display: flex !important;
        justify-content: flex-start !important;
        align-items: center !important;
        margin: 0 !important;
        margin-left: 0 !important; /* Reset desktop shift on mobile viewports */
    }
    
    .site-branding img {
        max-width: 150px !important; /* Increased from 130px for better visibility */
        margin: 0 !important;
    }
    
    /* 2. Utilities (Middle-Right) */
    .nordic-header-utilities {
        order: 0 !important;
        flex: 0 0 auto !important;
        width: auto !important;
        min-width: 0 !important;
        display: flex !important;
        justify-content: flex-end !important;
        align-items: center !important;
        margin-right: 15px !important; /* Spacing between search icon and hamburger menu */
    }
    
    /* 3. Hamburger (Far Right) */
    .main-navigation {
        order: 1 !important;
        flex: 0 0 auto !important;
        width: auto !important;
        min-width: 0 !important;
        display: flex !important;
        align-items: center !important;
        float: none !important;
        margin: 0 !important;
    }
    
    button.menu-toggle {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: transparent !important;
        border: none !important;
        color: #1a1a1a !important;
        padding: 0 !important;
        width: 40px !important;
        height: 40px !important;
        box-shadow: none !important;
    }
    
    /* Hide the default text span "Menu" */
    button.menu-toggle span {
        display: none !important;
    }
    
    /* Hide the account and cart icon on mobile header, since Storefront has a sticky footer bar for them! */
    .nordic-header-utilities .nordic-account-link,
    .nordic-header-utilities .nordic-cart-link {
        display: none !important; 
    }
    
    .nordic-header-utilities .nordic-search-toggle {
        display: flex !important;
    }
    
    /* Mobile Dropdown Menu styling */
    .main-navigation ul.menu,
    .main-navigation ul.nav-menu {
        display: none !important;
        flex-direction: column !important;
        position: absolute !important;
        top: 100% !important;
        left: 0 !important;
        width: 100% !important;
        background: #ffffff !important;
        box-shadow: 0 10px 25px rgba(0,0,0,0.05) !important;
        z-index: 99999 !important;
        padding: 10px 20px !important;
        box-sizing: border-box !important;
    }
    
    .main-navigation.toggled ul.menu,
    .main-navigation.toggled ul.nav-menu {
        display: flex !important;
    }
    
    .main-navigation ul.menu > li,
    .main-navigation ul.nav-menu > li {
        margin: 0 !important;
        border-bottom: 1px solid #f5f5f5 !important;
    }
    
    .main-navigation ul.menu > li:last-child,
    .main-navigation ul.nav-menu > li:last-child {
        border-bottom: none !important;
    }
    
    .main-navigation ul.menu > li > a,
    .main-navigation ul.nav-menu > li > a {
        padding: 15px 0 !important;
        font-size: 14px !important;
    }
}
