/* ================================================
   NAVBAR CONTROL ABSOLUTO - Spanish Guitar Academy
   ================================================
   Este archivo tiene control total sobre el navbar
   sin interferencias de otros archivos CSS
   =============================================== */

/* Reset y Base del Navbar */
.top-navbar {
    background: rgba(20, 19, 20, 0.4) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1030 !important;
    padding: 0.5rem 3rem !important;
    max-height: 85px !important;
    height: 85px !important;
    border: none !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1) !important;
    transition: all 0.3s ease !important;
}

/* Brand/Logo Styles - Solo el logo puede estar en negrita */
.top-navbar .navbar-brand,
nav.top-navbar .navbar-brand,
.top-navbar a.navbar-brand {
    color: #fff !important;
    font-weight: normal !important;
    text-decoration: none !important;
    transition: color 0.3s ease !important;
    margin-right: 2rem !important;
}

.top-navbar .navbar-brand:hover {
    color: #d50407 !important;
}

.top-navbar .navbar-brand img {
    height: 45px !important;
    transition: transform 0.3s ease !important;
}

.top-navbar .navbar-brand:hover img {
    transform: scale(1.05) !important;
}

/* Navigation Links - Peso de fuente normal, NO negrita */
.top-navbar .nav-link,
.top-navbar .navbar-nav .nav-link,
.top-navbar .navbar-nav li .nav-link,
nav.top-navbar .nav-link {
    color: rgba(255, 255, 255, 0.95) !important;
    font-weight: normal !important;
    padding: 8px 15px !important;
    transition: all 0.3s ease !important;
    position: relative !important;
    border-radius: 6px !important;
    border: 1px solid transparent !important;
    font-size: 14px !important;
}

/* Hover Effect con línea roja - EXACTO como en la imagen */
.top-navbar .nav-link:hover {
    color: #ffffff !important;
    background: rgba(213, 4, 7, 0.15) !important;
    border: 1px solid #d50407 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 0 8px rgba(213, 4, 7, 0.3) !important;
}

.top-navbar .nav-link:focus {
    color: #ffffff !important;
    background: rgba(213, 4, 7, 0.15) !important;
    border: 1px solid #d50407 !important;
}

/* Dropdown Menus - Fondo OSCURO siempre */
.top-navbar .dropdown-menu {
    background: rgba(20, 19, 20, 0.95) !important;
    border: 1px solid rgba(213, 4, 7, 0.3) !important;
    border-radius: 8px !important;
    backdrop-filter: blur(15px) !important;
    -webkit-backdrop-filter: blur(15px) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4) !important;
    margin-top: 5px !important;
    min-width: 200px !important;
    padding: 8px !important;
    overflow: hidden !important;
    z-index: 99999 !important;
    display: none !important;
    position: absolute !important;
}

.top-navbar .dropdown-menu.show {
    display: block !important;
    z-index: 99999 !important;
    position: absolute !important;
}

/* Dropdown menus del lado derecho - Alineación correcta */
.top-navbar .dropdown-menu-end {
    right: 0 !important;
    left: auto !important;
    transform: none !important;
    margin-right: 0 !important;
}

/* Asegurar que los dropdowns no se salgan del viewport */
.top-navbar .dropdown {
    position: relative !important;
}

.top-navbar .dropdown-menu {
    position: absolute !important;
    top: 100% !important;
    z-index: 99999 !important;
    max-width: calc(100vw - 20px) !important;
}

/* Específico para dropdowns del extremo derecho */
.top-navbar .navbar-nav:last-child .dropdown-menu,
.top-navbar .navbar-nav .dropdown:last-child .dropdown-menu {
    right: 0 !important;
    left: auto !important;
}

/* Dropdown Items */
.top-navbar .dropdown-item {
    color: rgba(255, 255, 255, 0.9) !important;
    transition: all 0.3s ease !important;
    padding: 0.7rem 1rem !important;
    font-weight: 500 !important;
    border-radius: 4px !important;
    margin: 2px 4px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: calc(100% - 8px) !important;
    box-sizing: border-box !important;
}

.top-navbar .dropdown-item:hover {
    background: rgba(213, 4, 7, 0.2) !important;
    color: #d50407 !important;
    transform: none !important;
    margin: 2px 4px !important;
}

.top-navbar .dropdown-item:focus {
    background: rgba(213, 4, 7, 0.2) !important;
    color: #d50407 !important;
}

/* Dropdown Icons */
.top-navbar .dropdown-item i {
    color: inherit !important;
    margin-right: 8px !important;
}

/* Mobile Toggle Button */
.navbar-toggler {
    border: none !important;
    padding: 4px 8px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border-radius: 6px !important;
    transition: all 0.3s ease !important;
}

.navbar-toggler:focus {
    box-shadow: none !important;
    background: rgba(213, 4, 7, 0.2) !important;
}

.navbar-toggler:hover {
    background: rgba(213, 4, 7, 0.2) !important;
}

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

/* Efectos especiales para desktop */
@media (min-width: 992px) {
    .top-navbar.no-dropdowns {
        -webkit-mask: linear-gradient(to bottom, 
            rgba(0, 0, 0, 1) 0%, 
            rgba(0, 0, 0, 1) 60%, 
            rgba(0, 0, 0, 0.7) 75%, 
            rgba(0, 0, 0, 0.3) 90%, 
            rgba(0, 0, 0, 0) 100%) !important;
        mask: linear-gradient(to bottom, 
            rgba(0, 0, 0, 1) 0%, 
            rgba(0, 0, 0, 1) 60%, 
            rgba(0, 0, 0, 0.7) 75%, 
            rgba(0, 0, 0, 0.3) 90%, 
            rgba(0, 0, 0, 0) 100%) !important;
    }
    
    .top-navbar.has-dropdown-open {
        -webkit-mask: none !important;
        mask: none !important;
    }
}

/* Mobile Styles */
@media (max-width: 991px) {
    .top-navbar {
        min-height: 60px !important;
        height: auto !important;
        padding: 0.5rem 1rem !important;
    }
    
    /* Hide desktop navigation */
    .top-navbar .navbar-nav.d-none.d-lg-flex {
        display: none !important;
    }
    
    /* Mobile navbar collapse */
    .navbar-collapse {
        background: rgba(20, 19, 20, 0.95) !important;
        border: 1px solid rgba(213, 4, 7, 0.2) !important;
        border-radius: 10px !important;
        margin-top: 5px !important;
        padding: 10px 0 !important;
        backdrop-filter: blur(15px) !important;
        -webkit-backdrop-filter: blur(15px) !important;
        max-height: calc(100vh - 100px) !important;
        min-height: auto !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        position: relative !important;
        z-index: 1020 !important;
    }
    
    /* Mobile navigation items */
    .navbar-collapse .navbar-nav.d-lg-none {
        display: flex !important;
        flex-direction: column !important;
        width: 100% !important;
    }
    
    .navbar-collapse .nav-item {
        width: 100% !important;
        margin: 1px 0 !important;
    }
    
    .navbar-collapse .nav-link {
        padding: 12px 20px !important;
        color: #fff !important;
        font-size: 15px !important;
        border-radius: 6px !important;
        margin: 1px 10px !important;
        transition: all 0.3s ease !important;
    }
    
    .navbar-collapse .nav-link:hover {
        background-color: rgba(213, 4, 7, 0.2) !important;
        color: #d50407 !important;
        transform: translateX(10px) !important;
    }
    
    /* Mobile divider */
    .mobile-divider {
        height: 1px !important;
        background: rgba(213, 4, 7, 0.3) !important;
        margin: 15px 20px !important;
        border: none !important;
    }
    
    /* Mobile dropdown menus */
    .navbar-collapse .dropdown-menu {
        background: rgba(15, 15, 15, 0.95) !important;
        border: 1px solid rgba(213, 4, 7, 0.2) !important;
        margin: 5px 15px !important;
        border-radius: 8px !important;
        position: static !important;
        width: auto !important;
        box-shadow: none !important;
        max-height: none !important;
        overflow: visible !important;
    }
    
    .navbar-collapse .dropdown-item {
        padding: 12px 20px !important;
        color: rgba(255, 255, 255, 0.9) !important;
        font-size: 14px !important;
        white-space: nowrap !important;
    }
    
    .navbar-collapse .dropdown-item:hover {
        background: rgba(213, 4, 7, 0.15) !important;
        color: #d50407 !important;
    }
    
    /* Asegurar que el container padre tenga suficiente espacio */
    .navbar-collapse .nav-item.dropdown {
        width: 100% !important;
        position: relative !important;
    }
}

/* Language selector específico */
.top-navbar #currentLang {
    font-weight: 600 !important;
    font-size: 0.9rem !important;
}

/* Normalizar dropdowns del lado derecho - Alineación perfecta */
.top-navbar .navbar-nav.d-none.d-lg-flex .nav-link.dropdown-toggle {
    min-width: 50px !important;
    min-height: 40px !important;
    padding: 8px 12px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 6px !important;
    border: 1px solid transparent !important;
    transition: all 0.3s ease !important;
}

/* Hover consistente para ambos dropdowns */
.top-navbar .navbar-nav.d-none.d-lg-flex .nav-link.dropdown-toggle:hover {
    background: rgba(213, 4, 7, 0.15) !important;
    border: 1px solid #d50407 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 0 8px rgba(213, 4, 7, 0.3) !important;
}

/* Search button */
.top-navbar .nav-link[data-bs-target="#searchModal"] {
    padding: 0.4rem !important;
    border-radius: 50% !important;
}

.top-navbar .nav-link[data-bs-target="#searchModal"]:hover {
    background: rgba(213, 4, 7, 0.2) !important;
    transform: scale(1.1) !important;
}

/* User account dropdown - Tamaño normalizado */
.top-navbar .nav-link .bi-person-circle {
    font-size: 1.2rem !important;
}

/* Normalizar espaciado del selector de idioma */
.top-navbar .nav-link .bi-globe {
    font-size: 1rem !important;
    margin-right: 4px !important;
}

/* Asegurar que ambos dropdowns tengan el mismo contenedor */
.top-navbar .navbar-nav.d-none.d-lg-flex .nav-item.dropdown {
    margin: 0 2px !important;
}

/* Dropdown dividers */
.top-navbar .dropdown-divider {
    border-color: rgba(213, 4, 7, 0.3) !important;
    margin: 8px 0 !important;
}

/* Force override any external CSS */
nav.navbar.navbar-expand-lg.top-navbar,
.navbar.navbar-expand-lg.top-navbar,
nav.top-navbar {
    background: rgba(20, 19, 20, 0.4) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
}

/* Ensure dropdown consistency */
.top-navbar .dropdown-menu.show {
    background: rgba(20, 19, 20, 0.95) !important;
    border: 1px solid rgba(213, 4, 7, 0.3) !important;
    z-index: 99999 !important;
    position: absolute !important;
}

/* JavaScript estado classes */
.navbar-dropdown-open .top-navbar {
    -webkit-mask: none !important;
    mask: none !important;
}

/* Final overrides to ensure control */
.top-navbar * {
    box-sizing: border-box !important;
}

/* Smooth transitions for all elements */
.top-navbar, .top-navbar * {
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
}

/* ================================================
   SOBRESCRIBIR CUALQUIER CSS INLINE - MÁXIMA PRIORIDAD
   =============================================== */

/* REGLAS ULTRA-ESPECÍFICAS para sobrescribir CSS inline */
body .top-navbar .navbar-brand,
html body .top-navbar .navbar-brand,
nav.navbar.top-navbar .navbar-brand {
    font-weight: normal !important;
}

body .top-navbar .nav-link,
html body .top-navbar .nav-link,
nav.navbar.top-navbar .nav-link,
nav.navbar.top-navbar .navbar-nav .nav-link {
    font-weight: normal !important;
}

/* Si aún hay conflictos, estas reglas tienen máxima especificidad */
html body nav.navbar.navbar-expand-lg.top-navbar .navbar-brand {
    font-weight: normal !important;
}

html body nav.navbar.navbar-expand-lg.top-navbar .nav-link {
    font-weight: normal !important;
}

/* ÚLTIMA LÍNEA DE DEFENSA - Override cualquier font-weight inline */
.top-navbar [style*="font-weight"] {
    font-weight: normal !important;
}

/* REGLAS NUCLEARES - Máxima especificidad posible */
html body div nav.navbar.navbar-expand-lg.fixed-top.top-navbar .navbar-brand {
    font-weight: normal !important;
}

html body div nav.navbar.navbar-expand-lg.fixed-top.top-navbar .nav-link {
    font-weight: normal !important;
}

html body div nav.navbar.navbar-expand-lg.fixed-top.top-navbar .navbar-nav .nav-item .nav-link {
    font-weight: normal !important;
}

/* SOBRESCRIBIR CUALQUIER ESTILO INLINE CON !important */
nav.top-navbar .navbar-brand[style] {
    font-weight: normal !important;
}

nav.top-navbar .nav-link[style] {
    font-weight: normal !important;
}

/* REGLA FINAL - Override todo */
.top-navbar * {
    font-weight: normal !important;
}

/* ================================================
   FIN DE GLOBAL NAVBAR CSS
   =============================================== */