/* ================= NAVBAR RESPONSIVE FIX ================= */
/* This file overrides home.css navbar styles */

/* Prevent horizontal scroll */
html, body {
    overflow-x: hidden !important;
    max-width: 100vw !important;
}

/* ================= REMOVE NAV-LINK UNDERLINE EFFECT ================= */
.navbar .nav-link::after {
    display: none !important;
    content: none !important;
    width: 0 !important;
    height: 0 !important;
    background: none !important;
    position: static !important;
}

.navbar .nav-link:hover::after,
.navbar .nav-link.active::after {
    display: none !important;
    width: 0 !important;
}

/* ================= DROPDOWN ARROW ================= */
.navbar .dropdown-toggle::after {
    display: inline-block !important;
    content: '' !important;
    width: 0 !important;
    height: 0 !important;
    margin-left: 8px !important;
    vertical-align: middle !important;
    border-top: 5px solid currentColor !important;
    border-right: 5px solid transparent !important;
    border-left: 5px solid transparent !important;
    border-bottom: 0 !important;
    position: static !important;
    background: none !important;
    transform: none !important;
    transition: none !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Keep arrow visible on hover */
.navbar .dropdown-toggle:hover::after,
.navbar .dropdown:hover .dropdown-toggle::after,
.navbar .dropdown.show .dropdown-toggle::after {
    display: inline-block !important;
    opacity: 1 !important;
    visibility: visible !important;
    border-top: 5px solid currentColor !important;
    border-right: 5px solid transparent !important;
    border-left: 5px solid transparent !important;
}

/* ================= DROPDOWN MENU ================= */
.dropdown-menu {
    border: none !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.12) !important;
    border-radius: 8px !important;
    padding: 8px 0 !important;
    min-width: 180px !important;
}

.dropdown-item {
    padding: 10px 20px !important;
    color: #333 !important;
    transition: all 0.2s ease !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: #4f46e5 !important;
    color: #fff !important;
}

/* ================= DESKTOP HOVER DROPDOWN ================= */
@media (min-width: 992px) {
    /* Prevent menu from shifting on hover */
    .navbar .nav-item {
        position: relative !important;
    }

    .navbar .nav-link {
        position: relative !important;
        padding: 10px 15px !important;
    }

    .navbar .dropdown-menu {
        position: absolute !important;
        top: 100% !important;
        left: 0 !important;
        margin-top: 0 !important;
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.2s ease, visibility 0.2s ease !important;
        display: block !important;
    }

    .navbar .dropdown:hover > .dropdown-menu {
        opacity: 1;
        visibility: visible;
    }

    /* Prevent nav items from moving */
    .navbar-nav {
        align-items: center !important;
    }

    .navbar .dropdown-toggle::after {
        transition: none !important;
    }
}

/* ================= MOBILE STYLES ================= */
@media (max-width: 991.98px) {

    /* Hamburger button */
    .navbar-toggler {
        display: flex !important;
        align-items: center;
        justify-content: center;
        border: 2px solid #4f46e5 !important;
        padding: 8px 12px !important;
        border-radius: 5px !important;
        background: transparent !important;
    }

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

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

    /* Mobile menu container - FIX WIDTH OVERFLOW */
    .navbar-collapse {
        position: fixed !important;
        top: 70px !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        background: #fff !important;
        padding: 0 !important;
        box-shadow: 0 4px 20px rgba(0,0,0,0.15) !important;
        border-radius: 0 !important;
        border-top: 1px solid #eee !important;
        max-height: calc(100vh - 70px) !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        z-index: 1050 !important;
        margin: 0 !important;
        box-sizing: border-box !important;
    }

    /* Logo sizing */
    .navbar-brand img {
        height: 45px !important;
        max-height: 45px !important;
    }

    /* Nav items */
    .navbar-nav {
        width: 100% !important;
        padding: 10px 0 !important;
        margin: 0 !important;
        flex-direction: column !important;
        align-items: stretch !important;
    }

    .navbar-nav .nav-item {
        width: 100% !important;
        border-bottom: 1px solid #eee !important;
        margin: 0 !important;
    }

    .navbar-nav .nav-item:last-child {
        border-bottom: none !important;
    }

    .navbar-nav .nav-link {
        padding: 15px 20px !important;
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        color: #333 !important;
        font-size: 16px !important;
        width: 100% !important;
    }

    /* Dropdown arrow on mobile */
    .navbar .dropdown-toggle::after {
        margin-left: auto !important;
        margin-right: 0 !important;
    }

    /* Mobile dropdown menu */
    .navbar .dropdown-menu {
        position: static !important;
        float: none !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        background: #f8f9fa !important;
        border: none !important;
        box-shadow: none !important;
        border-radius: 0 !important;
    }

    .navbar .dropdown-item {
        padding: 12px 40px !important;
        border-bottom: 1px solid #e5e5e5 !important;
        color: #555 !important;
        font-size: 15px !important;
    }

    .navbar .dropdown-item:last-child {
        border-bottom: none !important;
    }

    /* Login button */
    .navbar-nav .nav-item.ms-3 {
        margin: 0 !important;
        padding: 15px !important;
        border-bottom: none !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }

    .navbar-nav .btn-login {
        width: 100% !important;
        max-width: 100% !important;
        text-align: center !important;
        display: block !important;
        padding: 12px 20px !important;
        font-size: 16px !important;
        box-sizing: border-box !important;
    }

    /* Ensure all nav items don't overflow */
    .navbar-nav .nav-item {
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .navbar-nav .nav-link {
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
}

/* ================= LOGO SPACING ON MOBILE ================= */
@media (max-width: 991.98px) {
    .navbar-brand {
        margin-right: 5px !important;
        padding: 0 !important;
    }

    .navbar-brand:first-of-type {
        margin-right: 5px !important;
    }

    .navbar-brand + .navbar-brand {
        margin-left: 0 !important;
    }

    /* Fix gap between navbar and banner slider */
    .hero-banner,
    .carousel,
    .carousel-inner,
    section:first-of-type {
        margin-top: 0 !important;
        padding-top: 0 !important;
        margin-bottom: 0 !important;
    }

    /* Navbar bottom margin/padding remove */
    .navbar,
    #mainNav {
        margin-bottom: 0 !important;
        padding: 0.5rem 0 !important;
        border-bottom: none !important;
    }

    /* Adjust body padding for fixed navbar */
    body {
        padding-top: 65px !important;
    }

    /* Remove any extra margin from main content */
    main, .main-content, #mainNav + *, nav + * {
        margin-top: 0 !important;
        padding-top: 0 !important;
    }
}

/* ================= VERY SMALL SCREENS ================= */
@media (max-width: 576px) {
    .navbar-brand img {
        height: 35px !important;
        max-height: 35px !important;
    }

    .navbar-brand {
        margin-right: 3px !important;
    }

    .navbar-toggler {
        padding: 6px 10px !important;
    }

    .navbar-toggler-icon {
        width: 20px !important;
        height: 20px !important;
    }
}
