/* =====================================
   NAVBAR LAYOUT STRUCTURE
   ===================================== */

/* Distribución para desktop (lg y superior) */
@media (min-width: 992px) {
    /* Logo a la izquierda con margen */
    .navbar > .container-fluid {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
    }
    
    /* Menú centrado */
    .navbar-nav.mx-auto {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        order: 2;
        flex-grow: 1;
    }
    
    /* Iconos a la derecha */
    .d-none.d-lg-flex {
        order: 3;
        margin-left: auto;
    }
    
    /* Botón hamburguesa (oculto en desktop) */
    .navbar-toggler {
        order: 4;
        display: none !important;
    }
    
    /* Carrito móvil (oculto en desktop) */
    .d-lg-none.ms-auto {
        display: none !important;
    }
}

/* Distribución para móvil (< 992px) */
@media (max-width: 991.98px) {
    /* Logo a la izquierda */
    .navbar-brand {
        order: 1;
        flex: 0 0 auto;
    }
    
    /* Carrito al centro */
    .d-lg-none.ms-auto {
        order: 2;
        flex: 0 0 auto;
        margin-left: auto !important;
        margin-right: 1rem !important;
    }
    
    /* Botón hamburguesa a la derecha */
    .navbar-toggler {
        order: 3;
        flex: 0 0 auto;
    }
    
    /* Contenido colapsable */
    .navbar-collapse {
        order: 4;
        width: 100%;
    }
    
    /* Iconos desktop (ocultos en móvil) */
    .d-none.d-lg-flex {
        display: none !important;
    }
}

/* Ajustes de altura */
.navbar {
    min-height: 80px;
}

@media (max-width: 991.98px) {
    .navbar {
        min-height: 70px;
    }
}

/* Asegurar que el contenedor tenga padding adecuado */
.container-fluid.px-3.px-lg-4 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
}

@media (min-width: 992px) {
    .container-fluid.px-3.px-lg-4 {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }
}

/* Z-index para dropdowns */
.dropdown-menu {
    z-index: 1020;
}

.dropdown-submenu .dropdown-menu {
    z-index: 1021;
}


/* =====================================
   ESTILOS PARA EL CARRITO DE COMPRAS
   ===================================== */

/* Toast container */
#cartToastContainer {
    z-index: 9999;
}

/* Toast animations */
.toast {
    animation: slideIn 0.3s ease;
}

@keyframes slideIn {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

/* Modal del carrito */
#cartModal .modal-header {
    border-bottom: none;
    padding: 1rem 1.5rem;
}

#cartModal .modal-footer {
    border-top: 1px solid rgba(0,0,0,0.1);
    padding: 1.5rem;
}

#cartModal .table th {
    font-weight: 600;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #6c757d;
}

#cartModal .table td {
    vertical-align: middle;
}

#cartModal input[type="number"] {
    -moz-appearance: textfield;
}

#cartModal input[type="number"]::-webkit-outer-spin-button,
#cartModal input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Badges en el carrito */
#cartModal .badge {
    font-size: 0.7rem;
    font-weight: 500;
    padding: 0.35rem 0.5rem;
}

/* Botones de cantidad */
#cartModal .btn-outline-secondary {
    padding: 0.25rem 0.5rem;
    border-color: #dee2e6;
}

#cartModal .btn-outline-secondary:hover {
    background-color: #e9ecef;
    border-color: #ced4da;
    color: #212529;
}

#cartModal .btn-outline-secondary:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Contador del carrito en navbar */
#cartCountDesktop,
#cartCountMobileHeader {
    transition: all 0.2s ease;
    font-size: 0.7rem;
    padding: 0.25rem 0.45rem;
}

#cartCountDesktop.visible,
#cartCountMobileHeader.visible {
    transform: scale(1);
}

#cartCountDesktop.visually-hidden,
#cartCountMobileHeader.visually-hidden {
    transform: scale(0);
}

/* Animación del carrito cuando se agrega un item */
@keyframes cartBounce {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.2); }
}

.cart-bounce {
    animation: cartBounce 0.3s ease;
}

/* Responsive */
@media (max-width: 767.98px) {
    #cartModal .modal-dialog {
        margin: 0.5rem;
    }
    
    #cartModal .table {
        font-size: 0.85rem;
    }
    
    #cartModal .btn-sm {
        padding: 0.2rem 0.4rem;
    }
    
    #cartModal input[type="number"] {
        width: 50px !important;
    }
}