/**
 * Header Component Styles
 * Komodo Luxury Theme
 *
 * @package KomodoLuxury
 * @author Marcell
 */

/* ==========================================
   HEADER GENERAL STYLES
   ========================================== */

/* Backdrop blur for header */
.backdrop-blur-header {
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

/* Header border bottom - white line */
.header-border-bottom::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: rgba(255, 255, 255, 0.3);
}

/* Top bar link styles - white text on black bg */
.top-bar-link {
    color: #ffffff;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.8rem;
    padding: 0.625rem 0.75rem;
    line-height: 140%;
    transition: all 0.3s ease;
}

.top-bar-link:hover {
    color: #e6b31e;
}

/* Button outline secondary */
.btn-outline-secondary {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    background: transparent;
    border: 2px solid #e6b31e;
    color: #e6b31e;
    text-decoration: none;
    font-weight: 600;
    border-radius: 0.25rem;
    transition: all 0.3s ease;
    font-size: 0.875rem;
}

.btn-outline-secondary:hover {
    background: #e6b31e;
    color: #fff;
}

/* ==========================================
   DESKTOP HEADER STYLES
   ========================================== */

/* Top bar hidden state on scroll */
#klux-top-bar {
    transition: transform 0.4s ease, opacity 0.4s ease;
}

#klux-top-bar.hidden {
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none;
}

/* Desktop header scroll states */
#klux-desktop-header {
    transition: top 0.4s ease, background-color 0.4s ease;
    top: 59px; /* Same height as top bar */
}

#klux-desktop-header.scrolled {
    top: 0 !important;
    background-color: rgba(0, 0, 0, 0.9) !important;
}

/* Navigation link styling for compact header */
.klux-nav-link {
    padding: 0.5rem 0.75rem !important;
    font-size: 0.8rem !important;
}

/* Reduce gap between menu items */
#klux-desktop-header nav ul {
    gap: 0 !important;
}

#klux-desktop-header nav ul li {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
}

/* Override nav link colors to white */
.klux-nav-link,
.klux-nav-link span {
    color: #ffffff !important;
}

.klux-nav-link:hover,
.klux-nav-link:hover span {
    color: #e6b31e !important;
}

/* ==========================================
   MEGA MENU STYLES (Desktop)
   ========================================== */

/* Mega dropdown base state - hidden */
.klux-mega-dropdown {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                visibility 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Mega dropdown visible state */
.klux-mega-dropdown.klux-mega-show {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
}

/* Active state for parent menu item */
.klux-has-mega-menu.klux-mega-active > .klux-nav-link,
.klux-has-mega-menu.klux-mega-active > .klux-nav-link span {
    color: #e6b31e !important;
}

.klux-has-mega-menu.klux-mega-active > .klux-nav-link i {
    transform: rotate(180deg);
}

/* 4-Column Mega Menu Grid Styling */
.klux-mega-dropdown .grid {
    align-items: start;
}

/* Column 1: Title + Description */
.klux-mega-dropdown .col-span-1:first-child h3 {
    line-height: 1.2;
}

.klux-mega-dropdown .col-span-1:first-child p {
    line-height: 1.6;
}

/* Column 2 & 3: Link Groups with Scroll */
.klux-scroll-column {
    scroll-behavior: smooth !important;
    -webkit-overflow-scrolling: touch;
}

/* Custom Scrollbar for Link Columns */
.klux-scroll-column::-webkit-scrollbar {
    width: 8px;
}

.klux-scroll-column::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 4px;
    margin: 4px 0;
}

.klux-scroll-column::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.5);
    border-radius: 4px;
    transition: background 0.3s ease;
    border: 2px solid transparent;
    background-clip: padding-box;
}

.klux-scroll-column::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.8);
    background-clip: padding-box;
}

.klux-scroll-column::-webkit-scrollbar-thumb:active {
    background: #ffffff;
    background-clip: padding-box;
}

/* Force scroll visibility */
.klux-scroll-column {
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.5) rgba(255, 255, 255, 0.08);
}

.klux-mega-dropdown h4 {
    color: rgba(255, 255, 255, 0.6);
}

.klux-mega-dropdown ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.klux-mega-dropdown ul li a {
    display: block;
    transition: all 0.3s ease;
}

.klux-mega-dropdown ul li a:hover {
    padding-left: 8px;
}

/* Group Item Active State */
.klux-group-item.klux-group-active {
    border-left-color: #e6b31e !important;
    background: rgba(255, 255, 255, 0.05) !important;
}

.klux-group-item.klux-group-active h4 {
    color: #e6b31e !important;
}

/* Group Content Visibility */
.klux-group-content {
    transition: opacity 0.3s ease;
}

.klux-group-content.hidden {
    display: none !important;
}

.klux-group-content.block {
    display: block !important;
}

/* Column 4: Featured Image */
.klux-mega-dropdown .col-span-1:last-child img {
    object-position: center;
}

.klux-mega-dropdown .col-span-1:last-child .group:hover img {
    transform: scale(1.05);
}


/* Fix mega dropdown position based on header state */
.klux-mega-dropdown {
    top: 100% !important; /* Directly below the header */
}

#klux-desktop-header.scrolled .klux-mega-dropdown {
    top: 100% !important; /* Directly below the header when scrolled */
}

/* Ensure proper z-index stacking */
.klux-has-mega-menu {
    position: relative;
}

/* Button styling in mega menu */
.klux-mega-dropdown .btn-pc {
    background: transparent;
    border: 1px solid #e6b31e;
    color: #e6b31e;
    padding: 0.5rem 1rem;
    text-decoration: none;
    display: inline-block;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.klux-mega-dropdown .btn-pc:hover {
    background: #e6b31e;
    color: #000;
}

/* W-85 mega menu button width */
.w-85-mega-menu {
    width: 85%;
    text-align: center;
    margin-top: auto;
}

/* ==========================================
   MOBILE GENERAL STYLES
   ========================================== */

/* Prevent horizontal overflow on mobile */
body {
    overflow-x: hidden;
}

/* Mobile menu animations */
#klux-mobile-menu {
    transition: left 0.3s ease;
}

#klux-mobile-menu.active {
    left: 0 !important;
}

#klux-mobile-overlay {
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

#klux-mobile-overlay.active {
    opacity: 1 !important;
    visibility: visible !important;
}

/* Mobile nav item styles */
.mobile-nav-item {
    border-bottom: 1px solid rgba(230, 179, 30, 0.2);
}

.mobile-nav-link {
    display: block;
    padding: 1rem 1.25rem;
    color: #fff;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.3s ease;
}

.mobile-nav-link:hover {
    background: rgba(230, 179, 30, 0.1);
    padding-left: 1.75rem;
}

/* Mobile nav link wrapper - Depth 0 (Level 0) */
.klux-mobile-nav-link-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.klux-mobile-nav-link-wrapper .klux-mobile-nav-link {
    flex: 1;
    padding: 1rem 1.25rem;
    color: #fff;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.3s ease;
}

.klux-mobile-nav-link-wrapper .klux-mobile-nav-link:hover {
    background: rgba(230, 179, 30, 0.1);
    color: #e6b31e;
    padding-left: 1.25rem;
}

.klux-mobile-nav-toggle {
    background: transparent;
    border: none;
    color: rgba(255, 255, 255, 0.7);
    cursor: pointer;
    padding: 1rem 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    font-size: 1.25rem;
}

.klux-mobile-nav-toggle:hover {
    color: #e6b31e;
}

.klux-mobile-nav-item.active .klux-mobile-nav-toggle i {
    transform: rotate(180deg);
}

.klux-mobile-nav-toggle i {
    transition: transform 0.3s ease;
}

/* Keyframe animations */
@keyframes slideIn {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(0); }
}

@keyframes fadeIn {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

.animate-slide-in {
    animation: slideIn 0.3s ease-out;
}

.animate-fade-in {
    animation: fadeIn 0.3s ease-out;
}

/* Mobile mega menu link wrapper - Depth 1 */
.klux-mobile-mega-menu-link-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.klux-mobile-mega-menu-link-wrapper .klux-mobile-mega-menu-link {
    flex: 1;
    color: #fff;
    text-decoration: none;
    padding: 0.75rem 1rem;
    transition: color 0.3s ease;
}

.klux-mobile-mega-menu-link-wrapper .klux-mobile-mega-menu-link:hover {
    color: #e6b31e;
}

.klux-mobile-submenu-toggle {
    background: transparent;
    border: none;
    color: rgba(255, 255, 255, 0.7);
    cursor: pointer;
    padding: 0.75rem 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.klux-mobile-submenu-toggle:hover {
    color: #e6b31e;
}

.klux-mobile-mega-menu-item.active .klux-mobile-submenu-toggle i {
    transform: rotate(180deg);
}

.klux-mobile-submenu-toggle i {
    transition: transform 0.3s ease;
}

/* Mobile header container fix */
@media (max-width: 768px) {
    #klux-mobile-header-container {
        width: 90%;
        margin: 0 auto;
        padding: 0.75rem 0;
        text-align: right;
    }

    #klux-mobile-menu-trigger {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: transparent;
        border: none;
        color: white;
        font-size: 1.5rem;
        cursor: pointer;
        padding: 0.5rem;
        transition: color 0.3s ease;
    }

    #klux-mobile-menu-trigger:hover {
        color: #e6b31e;
    }
}
