/* Estilos para el menú unificado de CardioSof */

/* --- Navbar --- */
.navbar {
    background: transparent !important;
    padding: 20px 0;
}

.navbar-brand {
    font-weight: 700;
    color: var(--primary) !important;
    font-size: 1.8rem;
    display: flex;
    align-items: center;
    gap: 12px;
}

.dark-mode .navbar-brand { color: var(--primary) !important; }
.dark-mode .nav-link { color: var(--dark-text) !important; }
.dark-mode .nav-link:hover, .dark-mode .nav-link.active {
     background: linear-gradient(145deg, var(--dark-shadow-dark), var(--dark-shadow-light));
}

.nav-link {
    color: var(--text) !important;
    font-weight: 500;
    margin: 0 8px;
    border-radius: 15px;
    padding: 10px 18px !important;
    transition: var(--transition);
}

.nav-link:hover, .nav-link.active {
    background: linear-gradient(145deg, #dce3ec, var(--white-color));
}

.navbar-toggler {
    border: none;
}

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

.navbar-toggler-icon {
    /* El color por defecto de Bootstrap es oscuro, bueno para light mode */
}

.dark-mode .navbar-toggler-icon {
    filter: invert(1) hue-rotate(180deg); /* Invierte el icono para que sea visible en modo oscuro */
}

/* --- Dropdown Menu Styles --- */
.dropdown-menu {
    background-color: var(--card-bg);
    border: none;
    box-shadow: 5px 5px 15px var(--shadow-dark), -5px -5px 15px var(--shadow-light);
    border-radius: 15px;
    padding: 0.5rem 0;
}

.dropdown-item {
    color: var(--text);
    padding: 10px 20px;
    transition: background-color 0.3s, color 0.3s;
    background-color: transparent;
}

.dropdown-item:hover, .dropdown-item:focus {
    background-color: #dce3ec;
    color: var(--text);
}

.dropdown-item.active {
    font-weight: bold;
    color: var(--primary);
    background-color: transparent;
}


/* Dark Mode Dropdown */
.dark-mode .dropdown-menu {
    background-color: var(--dark-card);
    border: 1px solid var(--dark-shadow-dark);
    box-shadow: 5px 5px 15px var(--dark-shadow-dark);
}

.dark-mode .dropdown-item {
    color: var(--dark-text);
}

.dark-mode .dropdown-item:hover, .dark-mode .dropdown-item:focus {
    background-color: var(--dark-shadow-light);
    color: var(--dark-text);
}

.dark-mode .dropdown-item.active {
    color: var(--primary);
    background-color: transparent;
}

.dark-mode .dropdown-divider {
    border-top: 1px solid var(--dark-shadow-dark);
}


/* --- Theme Switcher (integrado en el menú) --- */
.theme-switch-wrapper { display: flex; align-items: center; margin-left: 15px; }
.theme-switch { display: inline-block; height: 34px; position: relative; width: 60px; }
.theme-switch input { display: none; }
.slider { background: var(--card-bg); box-shadow: inset 2px 2px 4px var(--shadow-dark), inset -2px -2px 4px var(--shadow-light); bottom: 0; cursor: pointer; left: 0; position: absolute; right: 0; top: 0; transition: var(--transition); border-radius: 34px; }
.slider:before { background: var(--primary); bottom: 4px; content: ""; height: 26px; left: 4px; position: absolute; transition: var(--transition); width: 26px; border-radius: 50%; }
input:checked + .slider { background: var(--primary); }
input:checked + .slider:before { transform: translateX(26px); background: var(--white-color); }
.slider i { position: absolute; top: 50%; transform: translateY(-50%); font-size: 14px; color: var(--text); }
.slider .fa-sun { left: 8px; }
.slider .fa-moon { right: 8px; color: var(--dark-text); }
.dark-mode .slider .fa-moon { color: var(--text); }


/* --- Responsividad del menú --- */

/* Ajuste para pantallas medianas donde el menú no cabe */
@media (min-width: 992px) and (max-width: 1400px) {
    .nav-link {
        margin: 0 4px; /* Reducir margen horizontal */
    padding: 10px 2px !important;
    font-size: 12px;
    }
	
.navbar-brand {
    font-size: 1.2rem;
}	
}

@media (max-width: 991.98px) {
    .navbar-collapse {
        background: var(--card-bg);
        border-radius: 20px;
        padding: 20px;
        margin-top: 15px;
        box-shadow: 5px 5px 15px var(--shadow-dark), -5px -5px 15px var(--shadow-light);
    }
    .theme-switch-wrapper {
        margin-top: 15px;
        margin-left: 0;
        justify-content: center;
    }
}
