/**
 * HibNET Custom Menu - Frontend Styles
 *
 * @author    HibNET
 * @copyright 2025 HibNET
 */

/* =============================================
   CSS Variables - Easy Color Customization
   ============================================= */
:root {
    /* Primary color */
    --hibnet-menu-primary: var(--bs-primary, #DFAA0A);

    /* Text colors */
    --hibnet-menu-text: #000;
    --hibnet-menu-text-hover: #000;

    /* Background colors */
    --hibnet-menu-bg: trasparent;
    --hibnet-menu-bg-hover: rgba(0, 0, 0, 0.05);
    --hibnet-menu-bg-subtle: rgba(0, 0, 0, 0.03);
    --hibnet-menu-bg-submenu: rgba(0, 0, 0, 0.02);

    --hibnet-menu-dropdown-bg: #ffffff;

    /* Border colors */
    --hibnet-menu-border: rgba(0, 0, 0, 0.125);
    --hibnet-menu-border-accent: var(--hibnet-menu-primary);

    /* Shadow */
    --hibnet-menu-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);

    /* Border radius */
    --hibnet-menu-radius: 0.375rem;

    /* Transitions */
    --hibnet-menu-transition: 0.2s ease;
    --hibnet-menu-transition-slow: 0.3s ease;

    /* Dark mode colors */
    --hibnet-menu-dark-bg: trasparent;
    --hibnet-menu-dark-text: #000;
    --hibnet-menu-dark-border: rgba(255, 255, 255, 0.125);
    --hibnet-menu-dark-bg-hover: rgba(255, 255, 255, 0.1);

    /* Mobile menu (slide-out) */
    --hibnet-mobile-menu-width: 320px;
    --hibnet-mobile-menu-bg: #024189;
    --hibnet-mobile-menu-text: #fff !important;
    --hibnet-mobile-menu-border: #024189;
    --hibnet-mobile-menu-transition: 0.3s ease;

    /* Sticky header */
    --hibnet-header-sticky-bg: rgb(255, 255, 255);
    --hibnet-header-transition: 0.3s ease;
}

/* General Menu Styles */
.hibnet-custom-menu {
    position: relative;
}

.hibnet-custom-menu .menu-icon {
    max-width: 20px;
    max-height: 20px;
    margin-right: 8px;
    vertical-align: middle;
}

/* Dropdown Template (Bootstrap 5) */
.hibnet-menu-dropdown .navbar-nav .nav-link {
    color: var(--hibnet-menu-text);
    padding: 0.5rem 1rem;
    transition: all var(--hibnet-menu-transition-slow) !important;
}

.hibnet-menu-dropdown .navbar-nav .nav-link:hover {
    color: var(--hibnet-menu-text-hover);
}

.hibnet-menu-dropdown .dropdown-menu {
    border-radius: var(--hibnet-menu-radius);
    box-shadow: var(--hibnet-menu-shadow);
    background: var(--hibnet-menu-dropdown-bg);
}

body:not(.page-index)  .hibnet-menu-dropdown .dropdown-menu {
    background: #fff;
}

.hibnet-menu-dropdown .dropdown-menu .dropdown-item {
    padding: 0.5rem 1rem;
    transition: background-color var(--hibnet-menu-transition);
}

.hibnet-menu-dropdown .dropdown-menu .dropdown-item:hover {
    background-color: var(--hibnet-menu-bg-hover);
}

/* Nested dropdown (multi-level) */
.hibnet-menu-dropdown .dropdown-menu .dropdown-menu {
    top: 0;
    left: 100%;
    margin-top: -0.5rem;
}

.hibnet-menu-dropdown .dropdown-menu .dropdown {
    position: relative;
}

.hibnet-menu-dropdown .dropdown-menu .dropdown > .dropdown-toggle::after {
    transform: rotate(-90deg);
    vertical-align: middle;
}

/* Vertical Template */
.hibnet-menu-vertical .list-group-item {
    border: 1px solid var(--hibnet-menu-border);
    transition: all var(--hibnet-menu-transition);
}

.hibnet-menu-vertical .list-group-item .menu-link {
    display: block;
    color: var(--hibnet-menu-text);
    text-decoration: none;
    padding: 0.75rem 1rem;
}

.hibnet-menu-vertical .list-group-item:hover {
    background-color: var(--hibnet-menu-bg-subtle);
}

.hibnet-menu-vertical .submenu {
    margin-top: 0.5rem;
    padding-left: 1.5rem;
}

.hibnet-menu-vertical .submenu .list-group-item {
    border-left: 3px solid var(--hibnet-menu-border-accent);
    background-color: var(--hibnet-menu-bg-submenu);
}

.hibnet-menu-vertical .depth-0 {
    font-weight: 500;
}

.hibnet-menu-vertical .depth-1 {
    font-size: 0.95rem;
    padding-left: 1rem;
}

.hibnet-menu-vertical .depth-2 {
    font-size: 0.9rem;
    padding-left: 2rem;
}

.hibnet-menu-vertical .depth-3 {
    font-size: 0.85rem;
    padding-left: 3rem;
}

/* Horizontal Template */
.hibnet-menu-horizontal .menu-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
}

.hibnet-menu-horizontal .menu-item {
    position: relative;
}

.hibnet-menu-horizontal .menu-item a {
    color: var(--hibnet-menu-text);
    text-decoration: none;
    transition: color var(--hibnet-menu-transition);
}

.hibnet-menu-horizontal .menu-item a:hover {
    color: var(--hibnet-menu-text-hover);
}

.hibnet-menu-horizontal .submenu {
    list-style: none;
    padding-left: 1.5rem;
    margin-top: 0.5rem;
}

.hibnet-menu-horizontal .submenu .menu-item {
    margin-bottom: 0.5rem;
}

/* HTML/Text Content */
.menu-html-content,
.menu-text-content {
    display: block;
}

/* =============================================
   Sticky Header with Scroll Effect
   ============================================= */
.page-index .header {
    transition: background-color var(--hibnet-header-transition);
}

body:not(.page-index) .header {
    /* background-image: url('/themes/child_hummingbird/assets/images/bg.png');
    background-size: cover;
    background-position: center left; */
    background-color: #fff !important;
}

.elementor-widget-theme-site-logo img {
    max-height: 172px;
    transition: max-height var(--hibnet-header-transition);
}

body:not(.page-index) .elementor-widget-theme-site-logo img {
    max-height: 90px;
}

.header.scrolled {
    background-color: var(--hibnet-header-sticky-bg) !important;
    /* backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
        background-image: url('/themes/child_hummingbird/assets/images/bg.png');
    background-size: cover;
    background-position: center left; */
}

.header.scrolled .elementor-widget-theme-site-logo img {
    max-height: 80px;
}

/* =============================================
   Mobile Menu - Slide Out from Right
   ============================================= */

/* Hide mobile close button on desktop */
.hibnet-mobile-close {
    display: none;
}

/* Mobile menu panel */
@media (max-width: 991px) {
    .hibnet-menu-dropdown .navbar-collapse {
        position: fixed !important;
        top: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        left: auto !important;
        width: var(--hibnet-mobile-menu-width) !important;
        max-width: 85vw !important;
        height: 100% !important;
        min-height: 100vh !important;
        background: var(--hibnet-mobile-menu-bg) !important;
        padding: 0 !important;
        margin: 0 !important;
        border-radius: 0 !important;
        /* box-shadow: -5px 0 25px rgba(0, 0, 0, 0.3); */
        transform: translateX(100%);
        transition: transform var(--hibnet-mobile-menu-transition) !important;
        z-index: 1050 !important;
        overflow-y: auto;
        overflow-x: hidden;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }

    /* Prevent Bootstrap collapse animation */
    .hibnet-menu-dropdown .navbar-collapse.collapsing {
        height: 100% !important;
        min-height: 100vh !important;
        transition: transform var(--hibnet-mobile-menu-transition) !important;
    }

    .hibnet-menu-dropdown .navbar-collapse.show {
        transform: translateX(0);
    }

    /* Mobile menu header */
    .hibnet-menu-dropdown .navbar-collapse::before {
        content: '';
        display: block;
        height: 94px;
        background: rgba(255, 255, 255, 0.05);
        border-bottom: 1px solid var(--hibnet-mobile-menu-border);
    }

    /* Close button */
    .hibnet-mobile-close {
        display: block;
        position: absolute;
        top: 12px;
        right: 15px;
        width: 36px;
        height: 36px;
        background: transparent;
        border: 1px solid var(--hibnet-mobile-menu-border);
        border-radius: 50%;
        color: var(--hibnet-mobile-menu-text);
        font-size: 24px;
        line-height: 32px;
        text-align: center;
        cursor: pointer;
        transition: all var(--hibnet-menu-transition);
        z-index: 1051;
    }

    .hibnet-mobile-close:hover {
        background: rgba(255, 255, 255, 0.1);
        transform: rotate(90deg);
    }

    /* Mobile navigation items */
    .hibnet-menu-dropdown .navbar-nav {
        padding: 1rem 0;
    }

    .hibnet-menu-dropdown .navbar-nav .nav-item {
        border-bottom: 1px solid var(--hibnet-mobile-menu-border);
    }

    .hibnet-menu-dropdown .navbar-nav .nav-item:last-child {
        border-bottom: none;
    }

    .hibnet-menu-dropdown .navbar-nav .nav-link {
        color: var(--hibnet-mobile-menu-text) !important;
        padding: 1rem 1.5rem;
        font-size: 1rem;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .hibnet-menu-dropdown .navbar-nav .nav-link:hover,
    .hibnet-menu-dropdown .navbar-nav .nav-link:focus {
        background: rgba(255, 255, 255, 0.05);
    }

    /* Dropdown in mobile */
    .hibnet-menu-dropdown .dropdown-menu {
        position: static !important;
        transform: none !important;
        border: none;
        box-shadow: none;
        background: rgba(255, 255, 255, 0.03);
        border-radius: 0;
        padding: 0;
        margin: 0;
    }

    .hibnet-menu-dropdown .dropdown-menu .dropdown-item {
        color: var(--hibnet-mobile-menu-text);
        padding: 0.875rem 1.5rem 0.875rem 2.5rem;
        border-bottom: 1px solid var(--hibnet-mobile-menu-border);
    }

    .hibnet-menu-dropdown .dropdown-menu .dropdown-item:last-child {
        border-bottom: none;
    }

    .hibnet-menu-dropdown .dropdown-menu .dropdown-item:hover {
        background: rgba(255, 255, 255, 0.05);
    }

    /* Nested dropdown */
    .hibnet-menu-dropdown .dropdown-menu .dropdown-menu {
        margin-left: 0;
    }

    .hibnet-menu-dropdown .dropdown-menu .dropdown-menu .dropdown-item {
        padding-left: 3.5rem;
    }

    /* Dropdown toggle arrow */
    .hibnet-menu-dropdown .dropdown-toggle::after {
        transition: transform var(--hibnet-menu-transition);
    }

    .hibnet-menu-dropdown .dropdown.show > .dropdown-toggle::after {
        transform: rotate(180deg);
    }

    /* Horizontal menu mobile */
    .hibnet-menu-horizontal .menu-list {
        flex-direction: column;
        gap: 0;
    }

    .hibnet-menu-horizontal .menu-item {
        border-bottom: 1px solid var(--hibnet-mobile-menu-border);
        padding: 1rem 0;
    }

    .hibnet-menu-horizontal .menu-item:last-child {
        border-bottom: none;
    }

    /* Hamburger button enhancement */
    .navbar-toggler {
        border: none;
        padding: 0.5rem;
        position: relative;
        z-index: 1060;
    }

    .navbar-toggler:focus {
        box-shadow: none;
    }

    .navbar-toggler-icon {
        width: 30px;
        height: 30px;
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255, 255, 255, 1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.5' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
        background-size: 100% 100%;
    }

    .collapsed .navbar-toggler-icon {
        width: 30px;
        height: 30px;
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(0, 0, 0, 1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.5' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
        background-size: 100% 100%;
    }


    /* Body scroll lock when menu is open */
    body.mobile-menu-open {
        overflow: hidden;
    }

    /* Hide hamburger when menu is open */
    body.mobile-menu-open .navbar-toggler {
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
    }
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
    :root {
        --hibnet-menu-bg: var(--hibnet-menu-dark-bg);
        --hibnet-menu-text: var(--hibnet-menu-dark-text);
        --hibnet-menu-border: var(--hibnet-menu-dark-border);
        --hibnet-menu-bg-hover: var(--hibnet-menu-dark-bg-hover);
        --hibnet-menu-bg-subtle: var(--hibnet-menu-dark-bg-hover);
        --hibnet-menu-bg-submenu: rgba(255, 255, 255, 0.05);
    }

    .hibnet-menu-dropdown .navbar-collapse {
        background: var(--hibnet-menu-bg);
    }

    .hibnet-menu-vertical .list-group-item {
        background-color: var(--hibnet-menu-bg);
        border-color: var(--hibnet-menu-border);
        color: var(--hibnet-menu-text);
    }

    .hibnet-menu-vertical .list-group-item:hover {
        background-color: var(--hibnet-menu-bg-hover);
    }
}
