/* CSS COMPLETO para selects de Departamento y Distrito - Diseño Morado */

/* Estilos base para todos los selects del formulario de ubicación */
#location-form select.form-control,
#departamento,
#distrito {
    /* Dimensiones y forma */
    height: 50px !important;
    width: 100% !important;
    border-radius: 25px !important;
    padding: 12px 45px 12px 20px !important;
    
    /* Fondo morado translúcido */
    background: rgba(98, 127, 255, 0.15) !important;
    background-color: rgba(103, 126, 234, 0.15) !important;
    
    /* Borde blanco redondeado */
    border: 2px solid rgba(255, 255, 255, 0.4) !important;
    
    /* Texto */
    color: white !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    
    /* Eliminar estilos por defecto del navegador */
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    outline: none !important;
    
    /* Transición suave */
    transition: all 0.3s ease !important;
    
    /* Cursor pointer */
    cursor: pointer !important;
    
    /* Flecha personalizada blanca */
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.8)' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 15px center !important;
    background-size: 18px !important;
}

/* Estado hover - más brillante */
#location-form select.form-control:hover,
#departamento:hover,
#distrito:hover {
    background: rgba(103, 126, 234, 0.25) !important;
    border-color: rgba(255, 255, 255, 0.6) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 15px rgba(103, 126, 234, 0.2) !important;
}

/* Estado focus - borde verde cuando está seleccionado */
#location-form select.form-control:focus,
#departamento:focus,
#distrito:focus {
    background: rgba(103, 126, 234, 0.2) !important;
    border-color: rgba(127, 173, 57, 0.8) !important;
    box-shadow: 0 0 0 3px rgba(127, 173, 57, 0.15) !important;
    color: white !important;
}

/* Estilos para las opciones del dropdown */
#location-form select.form-control option,
#departamento option,
#distrito option {
    background: #ffffff !important;
    color: #333333 !important;
    padding: 12px 20px !important;
    font-size: 15px !important;
    font-weight: 400 !important;
}

/* Option hover (algunos navegadores lo soportan) */
#location-form select.form-control option:hover,
#departamento option:hover,
#distrito option:hover {
    background: #f8f9fa !important;
    color: #495057 !important;
}

/* Option seleccionada */
#location-form select.form-control option:checked,
#departamento option:checked,
#distrito option:checked {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    color: white !important;
}

/* Estado disabled */
#location-form select.form-control:disabled,
#departamento:disabled,
#distrito:disabled {
    background: rgba(103, 126, 234, 0.1) !important;
    border-color: rgba(255, 255, 255, 0.2) !important;
    color: rgba(255, 255, 255, 0.5) !important;
    cursor: not-allowed !important;
    opacity: 0.6 !important;
}

/* Estado de carga */
#location-form select.form-control.loading,
#departamento.loading,
#distrito.loading {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.8)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3ccircle cx='12' cy='12' r='3'%3e%3c/circle%3e%3cpath d='m12 1v6m0 6v6'%3e%3c/path%3e%3cpath d='M9 12h6'%3e%3c/path%3e%3c/svg%3e") !important;
    animation: spin 1.5s linear infinite !important;
    color: rgba(255, 255, 255, 0.7) !important;
}

/* Animación de rotación para estado de carga */
@keyframes spin {
    from { 
        transform: rotate(0deg); 
        background-position: right 15px center;
    }
    to { 
        transform: rotate(360deg); 
        background-position: right 15px center;
    }
}

/* Placeholder mejorado para el primer option */
#location-form select.form-control option[value=""],
#departamento option[value=""],
#distrito option[value=""] {
    color: #6c757d !important;
    font-style: italic !important;
}

/* Estilos para cuando está seleccionado pero el valor está vacío */
#location-form select.form-control[value=""],
#departamento[value=""],
#distrito[value=""] {
    color: rgba(255, 255, 255, 0.7) !important;
    font-style: italic !important;
}

/* Efectos adicionales para mejor UX */
#location-form select.form-control.select-focused,
#departamento.select-focused,
#distrito.select-focused {
    border-color: rgb(19, 87, 105) !important;
    box-shadow: 0 0 0 4px rgba(127, 173, 57, 0.25) !important;
    background: rgba(103, 126, 234, 0.25) !important;
}

/* Animación de entrada suave */
#departamento,
#distrito {
    animation: slideInFromTop 0.6s ease-out !important;
}

@keyframes slideInFromTop {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Responsive - ajustes para móviles */
@media (max-width: 768px) {
    #location-form select.form-control,
    #departamento,
    #distrito {
        height: 45px !important;
        font-size: 15px !important;
        padding: 10px 40px 10px 18px !important;
        background-size: 16px !important;
        background-position: right 12px center !important;
    }
}

@media (max-width: 576px) {
    #location-form select.form-control,
    #departamento,
    #distrito {
        height: 44px !important;
        font-size: 14px !important;
        border-radius: 20px !important;
    }
}

/* Estilos para optgroup (si los usas) */
#location-form select.form-control optgroup,
#departamento optgroup,
#distrito optgroup {
    background: #e9ecef !important;
    color: #495057 !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    padding: 8px 15px !important;
}

/* Fix para Firefox */
@-moz-document url-prefix() {
    #location-form select.form-control,
    #departamento,
    #distrito {
        text-indent: 0.01px !important;
        text-overflow: '' !important;
    }
}

/* Fix para Safari */
@supports (-webkit-appearance: none) {
    #location-form select.form-control,
    #departamento,
    #distrito {
        background-position-x: calc(100% - 15px) !important;
    }
}

.select-focused {
        border-color: #2089a3 !important;
        box-shadow: 0 0 0 0.2rem rgba(57, 165, 173, 0.25) !important;
    }
    
    .loading {
        background-image: linear-gradient(45deg, transparent, rgba(255,255,255,0.1), transparent);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
    
    @keyframes loading {
        0% { background-position: -200% 0; }
        100% { background-position: 200% 0; }
    }
    
    .wishlist-added img {
        filter: hue-rotate(120deg);
        transform: scale(1.1);
        transition: all 0.3s ease;
    }
    
    .product__item {
        transition: all 0.3s ease;
        border-radius: 10px;
        overflow: hidden;
    }
    
    .product__item:hover {
        transform: translateY(-5px);
        box-shadow: 0 10px 30px rgba(0,0,0,0.15);
    }
    
    .pagination-link {
        display: inline-block;
        padding: 8px 12px;
        margin: 0 2px;
        border: 1px solid #ddd;
        color: #666;
        text-decoration: none;
        border-radius: 4px;
        transition: all 0.3s ease;
    }
    
    .pagination-link:hover {
        background: #7fad39;
        color: white;
        border-color: #7fad39;
    }


    /*FIN*/

    .tienda-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 5px 20px rgba(0,0,0,0.15) !important;
    border-color: #1b698d !important;
}

#direccion:focus {
    border-color: #1a656d !important;
    background: rgba(255, 255, 255, 0.2) !important;
    box-shadow: 0 0 15px rgba(57, 171, 173, 0.3);
}

.form-control.loading {
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 32 32"%3E%3Ccircle cx="16" cy="16" r="14" fill="none" stroke="%23ffffff" stroke-width="3" stroke-dasharray="80" stroke-dashoffset="60"%3E%3CanimateTransform attributeName="transform" type="rotate" from="0 16 16" to="360 16 16" dur="1s" repeatCount="indefinite"/%3E%3C/circle%3E%3C/svg%3E');
    background-repeat: no-repeat;
    background-position: right 15px center;
    background-size: 20px 20px;
}



.productos-scroll::-webkit-scrollbar { display: none; }
.tienda-block:hover { box-shadow: 0 4px 15px rgba(0,0,0,0.12) !important; }
.scroll-prev:hover, .scroll-next:hover { background: #7fad39 !important; border-color: #7fad39 !important; }
.scroll-prev:hover i, .scroll-next:hover i { color: white !important; }
@media (max-width: 768px) {
    .scroll-prev, .scroll-next { display: none !important; }
}
/* ============================================
   ESTILOS MEJORADOS PARA TIENDAS Y PRODUCTOS
   ============================================ */

/* Contenedor principal de tiendas */
.shop.spad {
    padding: 40px 0;
    background: #f8f9fa;
}

.shop .col-lg-9 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
    gap: 20px;
    grid-auto-rows: max-content;
}

/* Bloque de tienda */
.tienda-block {
    background: #fff !important;
    border-radius: 12px !important;
    padding: 18px !important;
    margin-bottom: 0 !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08) !important;
    border: 1px solid #e9ecef;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.tienda-block:hover {
    transform: translateY(-8px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15) !important;
    border-color: #7fad39 !important;
}

/* Header de tienda */
.tienda-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 15px !important;
    padding-bottom: 15px !important;
    border-bottom: 2px solid #f1f1f1 !important;
    flex-wrap: wrap;
    gap: 10px;
}

.tienda-header > div:first-child {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    min-width: 200px;
}

.tienda-header img {
    width: 60px !important;
    height: 40px !important;
    border-radius: 50% / 35% !important;
    overflow: hidden !important;
  
    object-fit: cover !important;
}

.tienda-header h5 {
    margin: 0 0 4px 0 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #2c3e50 !important;
}

.tienda-header h5 a {
    color: #2c3e50 !important;
    text-decoration: none !important;
    transition: color 0.2s ease;
}

.tienda-header h5 a:hover {
    color: #7fad39 !important;
}

.tienda-header p {
    margin: 0 !important;
    font-size: 11px !important;
    color: #666 !important;
}

/* Contenedor de botones */
.tienda-header > div:last-child {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
    min-width: 200px;
}

/* Botones de tienda */
.btn-sm {
    padding: 8px 16px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    border-radius: 20px !important;
    white-space: nowrap;
    transition: all 0.2s ease;
}

.btn-success {
    background: #7fad39 !important;
    border: 1px solid #7fad39 !important;
    color: #fff !important;
}

.btn-success:hover {
    background: #6b9630 !important;
    border-color: #6b9630 !important;
    box-shadow: 0 4px 12px rgba(127, 173, 57, 0.3);
}

.btn-outline-info {
    border: 2px solid #17a2b8 !important;
    color: #17a2b8 !important;
    background: transparent !important;
}

.btn-outline-info:hover {
    background: #17a2b8 !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(23, 162, 184, 0.3);
}

.btn-outline-info i {
    margin-right: 4px;
    display: inline-block;
}

/* Contenedor de scroll de productos */
.tienda-block > div:last-child {
    position: relative !important;
    flex-grow: 1;
    display: flex;
    align-items: center;
}

/* Scroll de productos */
.productos-scroll {
    display: flex !important;
    gap: 12px !important;
    overflow-x: auto !important;
    scroll-behavior: smooth !important;
    padding: 10px 5px !important;
    scrollbar-width: none;
    -ms-overflow-style: none;
    width: 100%;
}

.productos-scroll::-webkit-scrollbar {
    display: none;
}

/* Botones de navegación */
.scroll-prev, .scroll-next {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 10;
    background: white !important;
    border: 2px solid #e9ecef !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease;
    color: #666 !important;
    font-size: 16px;
}

.scroll-prev {
    left: -20px !important;
}

.scroll-next {
    right: -20px !important;
}

.scroll-prev:hover, .scroll-next:hover {
    background: #7fad39 !important;
    border-color: #7fad39 !important;
    color: white !important;
    transform: translateY(-50%) scale(1.1);
    box-shadow: 0 4px 12px rgba(127, 173, 57, 0.3);
}

/* Cards de productos */
.productos-scroll > div {
    flex: 0 0 160px !important;
    background: #fff !important;
    border: 1px solid #e9ecef !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    transition: all 0.2s ease;
}

.productos-scroll > div:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
    border-color: #7fad39;
}

.productos-scroll > div > a > div:first-child {
    position: relative;
    width: 100%;
    height: 140px;
    overflow: hidden;
    background: #f8f9fa;
}

.productos-scroll > div > a > div:first-child img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
}

.productos-scroll > div > a > div:last-child {
    padding: 10px !important;
}

.productos-scroll h6 {
    margin: 6px 0 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #2c3e50 !important;
    line-height: 1.2;
    height: 24px;
    overflow: hidden;
}

/* Responsive */
@media (max-width: 1200px) {
    .shop .col-lg-9 {
        grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    }
}

@media (max-width: 992px) {
    .shop .col-lg-9 {
        grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
    }
    
    .tienda-header {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .tienda-header > div:last-child {
        width: 100%;
        justify-content: flex-start;
    }
}

@media (max-width: 768px) {
    .shop .col-lg-9 {
        grid-template-columns: 1fr;
    }
    
    .scroll-prev, .scroll-next {
        display: none !important;
    }
    
    .productos-scroll {
        padding: 5px 0 !important;
    }
}

/* Badge de productos */
.badge {
    font-size: 11px !important;
    padding: 4px 8px !important;
    border-radius: 12px !important;
}

.badge-primary {
    background: #007bff !important;
}

.badge-info {
    background: #17a2b8 !important;
}

.badge-secondary {
    background: #6c757d !important;
}

/* Precio */
.productos-scroll span {
    font-size: 14px !important;
}

/* Mensaje sin productos */
.no-products {
    grid-column: 1 / -1;
    text-align: center;
    padding: 80px 20px !important;
    background: #f8f9fa !important;
    border-radius: 12px !important;
}

/* Animación suave */
* {
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}


