/*
Theme Name: Hello Elementor Child
Description: Child theme of Hello Elementor
Author: Your Name
Template: hello-elementor
Version: 1.0
*/

/* Ocultar el icono X del selector de comuna */
.select2-selection__clear,
#billing_city + .select2 .select2-selection__clear,
#shipping_city + .select2 .select2-selection__clear {
    display: none !important;
}

/* Dropdown de opciones */
.select2-container--default .select2-results__option {
    padding: 10px 16px !important;
    font-size: 14px !important;
    color: #333 !important;
    transition: all 0.15s ease !important;
}

/* Hover en opciones */
.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: rgba(209, 155, 61, 0.1) !important;
    color: #D19B3D !important;
}

/* Opción seleccionada */
.select2-container--default .select2-results__option[aria-selected=true] {
    background-color: rgba(209, 155, 61, 0.15) !important;
    color: #D19B3D !important;
    font-weight: 600 !important;
}

/* Contenedor del dropdown */
.select2-dropdown {
    border: 1px solid #D19B3D !important;
    border-radius: 6px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
    margin-top: 4px !important;
}

/* Input de búsqueda dentro del dropdown */
.select2-search--dropdown .select2-search__field {
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
    margin: 8px 8px 4px 8px !important;
}

.select2-search--dropdown .select2-search__field:focus {
    border-color: #D19B3D !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(209, 155, 61, 0.1) !important;
}

/* Mensaje cuando no hay resultados */
.select2-container--default .select2-results__option.select2-results__message {
    color: #999 !important;
    font-style: italic !important;
}

/* Scroll dentro del dropdown */
.select2-results__options {
    max-height: 300px !important;
}

/* Responsive para móviles */
@media (max-width: 768px) {
    .woocommerce-checkout select:not(.select2-hidden-accessible),
    .woocommerce form select:not(.select2-hidden-accessible) {
        padding: 10px 40px 10px 14px !important;
        font-size: 16px !important; /* Evita zoom en iOS */
    }

    .woocommerce-checkout .select2-container .select2-selection--single,
    .woocommerce form .select2-container .select2-selection--single {
        height: 44px !important;
    }

    .woocommerce-checkout .select2-container .select2-selection__rendered,
    .woocommerce form .select2-container .select2-selection__rendered {
        line-height: 42px !important;
        padding-left: 14px !important;
        font-size: 16px !important; /* Evita zoom en iOS */
    }

    .woocommerce-checkout .select2-container .select2-selection__arrow,
    .woocommerce form .select2-container .select2-selection__arrow {
        height: 42px !important;
    }

    .select2-container--default .select2-results__option {
        padding: 12px 14px !important;
        font-size: 15px !important;
    }
}

/* Estilos para el shortcode de login */
.login-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;
    color: inherit;
    transition: opacity 0.3s ease;
}

.login-link:hover {
    opacity: 0.7;
    text-decoration: none;
}

.login-link svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
}

/* Estilos sutiles para formularios de login y registro */
#customer_login {
    max-width: 900px;
    margin: 0 auto;
    gap: 30px;
}

#customer_login .u-column1,
#customer_login .u-column2 {
    background: #fafafa;
    border-radius: 8px;
    border: 1px solid #e8e8e8;
    padding: 25px;
}

.woocommerce-form-login,
.woocommerce-form-register {
    background: transparent;
    border: none;
    padding: 0;
    margin: 0;
}

#customer_login h2 {
    text-align: center;
    margin-bottom: 20px;
    color: #333;
    font-weight: 600;
}

#customer_login .form-row {
    margin-bottom: 15px;
}

#customer_login input[type="text"],
#customer_login input[type="password"],
#customer_login input[type="email"] {
    width: 100%;
    padding: 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 14px;
    transition: border-color 0.3s ease;
    box-sizing: border-box;
}

#customer_login input[type="text"]:focus,
#customer_login input[type="password"]:focus,
#customer_login input[type="email"]:focus {
    border-color: #007cba;
    outline: none;
    box-shadow: 0 0 0 2px rgba(0, 124, 186, 0.1);
}

#customer_login .woocommerce-button,
#customer_login .woocommerce-Button {
    width: 100%;
    padding: 12px;
    background: #F4B906;
    color: white;
    border: none;
    border-radius: 4px;
    font-size: 16px;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

#customer_login .woocommerce-button:hover,
#customer_login .woocommerce-Button:hover {
    background: #d19f05;
}

#customer_login .woocommerce-LostPassword {
    text-align: center;
    margin-top: 15px;
}

#customer_login .woocommerce-LostPassword a {
    color: #666;
    text-decoration: none;
    font-size: 14px;
}

#customer_login .woocommerce-LostPassword a:hover {
    color: #007cba;
    text-decoration: underline;
}

#customer_login .woocommerce-privacy-policy-text {
    background: #f0f8ff;
    padding: 10px;
    border-radius: 4px;
    border-left: 3px solid #007cba;
    margin: 15px 0;
    font-size: 13px;
    line-height: 1.5;
}

#customer_login .woocommerce-privacy-policy-text a {
    color: #007cba;
    text-decoration: none;
}

#customer_login .woocommerce-privacy-policy-text a:hover {
    text-decoration: underline;
}

/* Mejoras adicionales para labels y campos requeridos */
#customer_login label {
    color: #333;
    font-weight: 500;
    font-size: 14px;
    margin-bottom: 8px;
    display: block;
}

#customer_login label .required {
    color: #dc2626;
    font-weight: 700;
    margin-left: 2px;
}

#customer_login .form-row {
    margin-bottom: 20px;
}

/* Estilos para checkbox "Recuérdame" personalizado */
#customer_login .woocommerce-form-login__rememberme {
    display: flex !important;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    margin-bottom: 15px;
    font-size: 14px;
    color: #666;
}

#customer_login input[type="checkbox"] {
    width: 18px;
    height: 18px;
    border: 2px solid #ddd;
    border-radius: 3px;
    cursor: pointer;
    accent-color: #F4B906;
    margin: 0;
}

#customer_login input[type="checkbox"]:checked {
    background-color: #F4B906;
    border-color: #F4B906;
}

#customer_login input[type="checkbox"]:focus {
    outline: 2px solid rgba(244, 185, 6, 0.3);
    outline-offset: 2px;
}

/* Estados de validación para inputs - Removidos para evitar feedback visual invasivo */

/* Mensajes de error y éxito en login/registro */
#customer_login .woocommerce-error,
#customer_login .woocommerce-message,
#customer_login .woocommerce-info {
    padding: 12px 16px;
    margin-bottom: 20px;
    border-radius: 6px;
    font-size: 14px;
    line-height: 1.5;
}

#customer_login .woocommerce-error {
    background: #fef2f2;
    border-left: 4px solid #dc2626;
    color: #991b1b;
}

#customer_login .woocommerce-message {
    background: #f0fdf4;
    border-left: 4px solid #10b981;
    color: #065f46;
}

#customer_login .woocommerce-info {
    background: #eff6ff;
    border-left: 4px solid #3b82f6;
    color: #1e40af;
}

/* Mejorar espaciado del botón */
#customer_login .woocommerce-button,
#customer_login .woocommerce-Button {
    margin-top: 10px;
}

/* Ajustes para el texto descriptivo en registro */
#customer_login .u-column2 > p {
    font-size: 13px;
    color: #666;
    line-height: 1.6;
    margin: 15px 0;
}

/* Responsive Design para móviles */
@media (max-width: 768px) {
    #customer_login {
        max-width: 100%;
        padding: 0 15px;
        gap: 20px;
    }

    /* Apilar columnas en móvil */
    #customer_login .u-columns {
        display: flex;
        flex-direction: column;
        gap: 25px;
    }

    #customer_login .u-column1,
    #customer_login .u-column2 {
        width: 100% !important;
        float: none !important;
        padding: 20px;
        margin: 0;
    }

    #customer_login h2 {
        font-size: 20px;
        margin-bottom: 15px;
    }

    #customer_login input[type="text"],
    #customer_login input[type="password"],
    #customer_login input[type="email"] {
        padding: 10px;
        font-size: 16px; /* Evita zoom en iOS */
    }

    #customer_login .woocommerce-button,
    #customer_login .woocommerce-Button {
        padding: 14px;
        font-size: 16px;
    }

    #customer_login label {
        font-size: 13px;
    }

    #customer_login .woocommerce-privacy-policy-text {
        font-size: 12px;
        padding: 8px;
    }
}

/* Tablet */
@media (max-width: 1024px) and (min-width: 769px) {
    #customer_login {
        max-width: 720px;
        gap: 25px;
    }

    #customer_login .u-column1,
    #customer_login .u-column2 {
        padding: 20px;
    }
}

/* Estilo para item de menú Ofertas - Color Quincallería */
.menu-item-1612 a {
    background: #C44F34 !important;
    color: white !important;
    padding: 8px 12px !important;
}

.menu-item-1612 a:hover {
    background: #A84329 !important;
}

/* Estilos para filtros de ferretería - Diseño minimalista corporativo */
.elementor-shortcode .filtros-ferreteria,
.filtros-ferreteria {
    background: white !important;
    border: 1px solid rgba(92, 109, 117, 0.15) !important;
    border-radius: 8px !important;
    padding: 24px !important;
    margin-bottom: 20px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    box-shadow: 0 2px 8px rgba(22, 38, 48, 0.04) !important;
}

.filtros-ferreteria .filtros-titulo {
    margin: 0 0 20px 0 !important;
    color: #162630 !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    border-bottom: 2px solid rgba(209, 155, 61, 0.2) !important;
    padding-bottom: 12px !important;
}

.filtros-ferreteria .filtros-container {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 24px !important;
    margin-bottom: 20px !important;
}

.filtros-ferreteria.layout-horizontal .filtros-container {
    flex-direction: row !important;
}

.filtros-ferreteria.layout-vertical .filtros-container {
    flex-direction: column !important;
}

.filtros-ferreteria .filtro-grupo {
    min-width: 200px !important;
    margin-bottom: 0 !important;
}

.filtros-ferreteria .filtro-grupo h4 {
    margin: 0 0 12px 0 !important;
    color: #5C6D75 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
}

.filtros-ferreteria .filtro-checkbox {
    display: flex !important;
    align-items: center !important;
    margin-bottom: 10px !important;
    cursor: pointer !important;
    font-size: 14px !important;
    position: relative !important;
    color: #162630 !important;
    transition: all 0.2s ease !important;
}

.filtros-ferreteria .filtro-checkbox:hover {
    color: #D19B3D !important;
}

.filtros-ferreteria .filtro-checkbox input[type="checkbox"] {
    margin-right: 10px !important;
    width: 18px !important;
    height: 18px !important;
    border: 2px solid #5C6D75 !important;
    border-radius: 3px !important;
    cursor: pointer !important;
    accent-color: #D19B3D !important;
}

.filtros-ferreteria .filtro-checkbox .checkmark {
    margin-left: 5px !important;
}

.filtros-ferreteria .precio-range-container {
    padding: 8px 0 !important;
}

.filtros-ferreteria .precio-values {
    display: flex !important;
    justify-content: space-between !important;
    margin-bottom: 16px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #162630 !important;
}

.filtros-ferreteria .precio-value-min,
.filtros-ferreteria .precio-value-max {
    background: rgba(209, 155, 61, 0.1) !important;
    padding: 6px 12px !important;
    border-radius: 6px !important;
    color: #D19B3D !important;
}

.filtros-ferreteria .precio-slider-wrapper {
    position: relative !important;
    height: 6px !important;
    margin: 20px 0 !important;
}

.filtros-ferreteria .precio-slider {
    position: absolute !important;
    width: 100% !important;
    height: 6px !important;
    background: transparent !important;
    pointer-events: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}

.filtros-ferreteria .precio-slider::-webkit-slider-track {
    width: 100% !important;
    height: 6px !important;
    background: rgba(92, 109, 117, 0.15) !important;
    border-radius: 3px !important;
}

.filtros-ferreteria .precio-slider::-moz-range-track {
    width: 100% !important;
    height: 6px !important;
    background: rgba(92, 109, 117, 0.15) !important;
    border-radius: 3px !important;
}

.filtros-ferreteria .precio-slider::-webkit-slider-thumb {
    -webkit-appearance: none !important;
    appearance: none !important;
    pointer-events: auto !important;
    width: 18px !important;
    height: 18px !important;
    background: linear-gradient(135deg, #D19B3D 0%, #BA8B37 100%) !important;
    border: 2px solid white !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    box-shadow: 0 2px 6px rgba(209, 155, 61, 0.3) !important;
    transition: all 0.2s ease !important;
}

.filtros-ferreteria .precio-slider::-moz-range-thumb {
    pointer-events: auto !important;
    width: 18px !important;
    height: 18px !important;
    background: linear-gradient(135deg, #D19B3D 0%, #BA8B37 100%) !important;
    border: 2px solid white !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    box-shadow: 0 2px 6px rgba(209, 155, 61, 0.3) !important;
    transition: all 0.2s ease !important;
}

.filtros-ferreteria .precio-slider::-webkit-slider-thumb:hover {
    transform: scale(1.15) !important;
    box-shadow: 0 3px 10px rgba(209, 155, 61, 0.4) !important;
}

.filtros-ferreteria .precio-slider::-moz-range-thumb:hover {
    transform: scale(1.15) !important;
    box-shadow: 0 3px 10px rgba(209, 155, 61, 0.4) !important;
}

.filtros-ferreteria .precio-slider::-webkit-slider-thumb:active {
    transform: scale(1.05) !important;
}

.filtros-ferreteria .precio-slider::-moz-range-thumb:active {
    transform: scale(1.05) !important;
}

.filtros-ferreteria .filtros-botones {
    display: flex !important;
    gap: 12px !important;
    justify-content: center !important;
    margin-top: 24px !important;
    padding-top: 20px !important;
    border-top: 1px solid rgba(92, 109, 117, 0.1) !important;
}

.filtros-ferreteria .btn-aplicar-filtros,
.filtros-ferreteria .btn-limpiar-filtros {
    padding: 12px 28px !important;
    border: none !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.filtros-ferreteria .btn-aplicar-filtros {
    background: linear-gradient(135deg, #D19B3D 0%, #BA8B37 100%) !important;
    color: white !important;
    box-shadow: 0 2px 6px rgba(209, 155, 61, 0.2) !important;
}

.filtros-ferreteria .btn-aplicar-filtros:hover {
    background: linear-gradient(135deg, #BA8B37 0%, #A57B2F 100%) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 10px rgba(209, 155, 61, 0.3) !important;
}

.filtros-ferreteria .btn-limpiar-filtros {
    background: transparent !important;
    color: #5C6D75 !important;
    border: 1px solid rgba(92, 109, 117, 0.3) !important;
}

.filtros-ferreteria .btn-limpiar-filtros:hover {
    background: rgba(92, 109, 117, 0.05) !important;
    border-color: #5C6D75 !important;
    color: #162630 !important;
}

@media (max-width: 768px) {
    .filtros-ferreteria .filtros-container {
        flex-direction: column !important;
    }

    .filtros-ferreteria .filtros-botones {
        flex-direction: column !important;
    }

    .filtros-ferreteria .btn-aplicar-filtros,
    .filtros-ferreteria .btn-limpiar-filtros {
        width: 100% !important;
    }
}

/* 🔽 SELECTOR DE ORDENAMIENTO WOOCOMMERCE */
.woocommerce-ordering {
    margin-bottom: 20px !important;
}

.woocommerce-ordering select.orderby,
select.orderby {
    padding: 10px 40px 10px 16px !important;
    border: 1px solid rgba(92, 109, 117, 0.25) !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #162630 !important;
    background-color: white !important;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="%235C6D75" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="6 9 12 15 18 9"></polyline></svg>') !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    background-size: 12px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    min-width: 200px !important;
}

.woocommerce-ordering select.orderby:hover,
select.orderby:hover {
    border-color: rgba(209, 155, 61, 0.4) !important;
    background-color: rgba(209, 155, 61, 0.02) !important;
}

.woocommerce-ordering select.orderby:focus,
select.orderby:focus {
    outline: none !important;
    border-color: #D19B3D !important;
    box-shadow: 0 0 0 3px rgba(209, 155, 61, 0.1) !important;
}

.woocommerce-ordering select.orderby option,
select.orderby option {
    padding: 10px !important;
    color: #162630 !important;
}

/* Responsive */
@media (max-width: 768px) {
    .woocommerce-ordering select.orderby,
    select.orderby {
        width: 100% !important;
        min-width: auto !important;
    }
}

/* 📞 BOTONES DE CONTACTO - MINIMALISTA */
.botones-contacto-wrapper {
    display: flex !important;
    gap: 10px !important;
    margin: 20px 0 !important;
}

.botones-contacto-wrapper.layout-horizontal {
    flex-direction: row !important;
    flex-wrap: wrap !important;
}

.botones-contacto-wrapper.layout-vertical {
    flex-direction: column !important;
}

.btn-contacto {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 12px 20px !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    flex: 1 !important;
    min-width: 160px !important;
    border: 1px solid !important;
    background: white !important;
}

.btn-contacto-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 18px !important;
    height: 18px !important;
}

.btn-contacto-icon svg {
    width: 100% !important;
    height: 100% !important;
    fill: currentColor !important;
}

.btn-contacto-text {
    font-size: 14px !important;
    font-weight: 500 !important;
}

/* Botón de teléfono/consultar - Color Construcción con opacidad */
.btn-contacto.btn-telefono {
    border-color: rgba(209, 155, 61, 0.3) !important;
    color: #D19B3D !important;
    background: rgba(209, 155, 61, 0.05) !important;
}

.btn-contacto.btn-telefono:hover {
    background: #D19B3D !important;
    border-color: #D19B3D !important;
    color: white !important;
}

/* Botón de tienda - Color Pinturas con opacidad */
.btn-contacto.btn-tienda {
    border-color: rgba(62, 139, 170, 0.3) !important;
    color: #3E8BAA !important;
    background: rgba(62, 139, 170, 0.05) !important;
}

.btn-contacto.btn-tienda:hover {
    background: #3E8BAA !important;
    border-color: #3E8BAA !important;
    color: white !important;
}

/* Responsive */
@media (max-width: 768px) {
    .botones-contacto-wrapper.layout-horizontal {
        flex-direction: column !important;
    }

    .btn-contacto {
        width: 100% !important;
        min-width: auto !important;
        padding: 11px 18px !important;
        font-size: 13px !important;
    }

    .btn-contacto-text {
        font-size: 13px !important;
    }

    .btn-contacto-icon {
        width: 16px !important;
        height: 16px !important;
    }
}

/* ========================================
   🖼️ GALERÍA DE PRODUCTO - ULTRA MINIMALISTA
   ======================================== */

.galeria-producto-wrapper {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
}

/* Contenedor principal de imagen */
.galeria-principal {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: white;
    border: 1px solid #f0f0f0;
    margin-bottom: 10px;
}

.galeria-imagen-principal {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s;
}

.galeria-imagen-principal.active {
    opacity: 1;
    visibility: visible;
}

.imagen-container {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px;
}

.imagen-container img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* Botón de zoom */
.btn-zoom {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 32px;
    height: 32px;
    background: transparent !important;
    border: none !important;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    opacity: 0;
    transition: opacity 0.2s;
    box-shadow: none !important;
}

.galeria-principal:hover .btn-zoom {
    opacity: 0.4;
}

.btn-zoom:hover {
    opacity: 1 !important;
    background: transparent !important;
}

.btn-zoom svg {
    width: 20px;
    height: 20px;
    fill: #000 !important;
    transition: fill 0.2s;
}

.btn-zoom:hover svg {
    fill: #000 !important;
}

/* Navegación */
.galeria-navegacion {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    transform: translateY(-50%);
    display: flex;
    justify-content: space-between;
    padding: 0 8px;
    pointer-events: none;
    z-index: 10;
}

.nav-btn {
    width: 32px;
    height: 32px;
    background: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    pointer-events: auto;
    opacity: 0;
    transition: opacity 0.2s;
}

.galeria-principal:hover .nav-btn {
    opacity: 0.4;
}

.nav-btn:hover {
    opacity: 1 !important;
}

.nav-btn svg {
    width: 20px;
    height: 20px;
    fill: #000;
}

/* Miniaturas */
.galeria-miniaturas {
    display: flex;
    gap: 6px;
    justify-content: center;
    flex-wrap: wrap;
}

.miniatura {
    width: 60px;
    height: 60px;
    padding: 0;
    background: white;
    border: 1px solid #f0f0f0;
    cursor: pointer;
    overflow: hidden;
    transition: border-color 0.2s;
}

.miniatura:hover {
    border-color: #ddd;
}

.miniatura.active {
    border-color: #000;
}

.miniatura-container {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
}

.miniatura-container img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* Lightbox */
.galeria-lightbox {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lightbox-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.98);
    cursor: pointer;
}

.lightbox-content {
    position: relative;
    z-index: 1;
    max-width: 90vw;
    max-height: 90vh;
    padding: 40px;
}

.lightbox-image-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
}

.lightbox-image {
    max-width: 100%;
    max-height: 80vh;
    object-fit: contain;
}

.lightbox-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 32px;
    height: 32px;
    background: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    opacity: 0.4;
    transition: opacity 0.2s;
}

.lightbox-close:hover {
    opacity: 1;
}

.lightbox-close svg {
    width: 24px;
    height: 24px;
    fill: #000;
}

/* Sin imagen */
.no-image {
    width: 100%;
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    background: white;
    color: #ccc;
    font-size: 13px;
}

/* Responsive */
@media (max-width: 768px) {
    .imagen-container {
        padding: 24px;
    }

    .btn-zoom,
    .nav-btn {
        width: 28px;
        height: 28px;
    }

    .btn-zoom svg,
    .nav-btn svg {
        width: 18px;
        height: 18px;
    }

    .miniatura {
        width: 52px;
        height: 52px;
    }

    .lightbox-content {
        padding: 20px;
    }

    .lightbox-close {
        top: 16px;
        right: 16px;
    }
}

.quantity-wrapper {
    display: flex;
    align-items: center;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
    background: white;
}

.qty-btn {
    padding: 8px 12px !important;
    border: none !important;
    background: white !important;
    cursor: pointer;
    font-size: 16px;
    line-height: 1;
    transition: background-color 0.2s;
    color: #333 !important;
}

.qty-btn:hover {
    background-color: #f5f5f5 !important;
}

.qty-btn.minus {
    border-radius: 8px 0 0 8px;
}

.qty-btn.plus {
    border-radius: 0 8px 8px 0;
}

.qty {
    width: 64px !important;
    text-align: center !important;
    border: none !important;
    padding: 8px 4px !important;
    outline: none !important;
    background: transparent !important;
    -moz-appearance: textfield;
    appearance: textfield;
}

.qty::-webkit-outer-spin-button,
.qty::-webkit-inner-spin-button {
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
}

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

/* Fix para cuando queda solo 1 producto (input hidden) */
.quantity input[type="hidden"].qty {
    display: none !important;
}

.quantity:has(input[type="hidden"].qty) {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 0 !important;
}

/* Fallback para navegadores que no soportan :has() */
.elementor-add-to-cart .quantity {
    min-height: auto !important;
}

.elementor-add-to-cart .quantity:empty,
.elementor-add-to-cart .quantity:not(:has(input[type="number"])) {
    display: none !important;
}

.stock.in-stock {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    color: #059669 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    margin: 15px 0 !important;
    padding: 0 !important;
}

.stock.in-stock:before {
    content: "";
    width: 16px;
    height: 16px;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="%23059669" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M22 11.08V12a10 10 0 1 1-5.93-9.14"></path><path d="m9 11 3 3L22 4"></path></svg>');
    background-repeat: no-repeat;
    background-size: contain;
    flex-shrink: 0;
}

.stock.out-of-stock {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    color: #dc2626 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    margin: 8px 0 !important;
    padding: 4px 8px !important;
    background-color: #fef2f2 !important;
    border: 1px solid #fecaca !important;
    border-radius: 12px !important;
    width: fit-content !important;
}

.stock.out-of-stock:before {
    content: "";
    width: 12px;
    height: 12px;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="%23dc2626" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"><circle cx="12" cy="12" r="10"></circle><path d="m15 9-6 6"></path><path d="m9 9 6 6"></path></svg>');
    background-repeat: no-repeat;
    background-size: contain;
    flex-shrink: 0;
}

.woocommerce button.button.added::after,
.woocommerce input.button.added::after,
.woocommerce a.button.added::after {
    display: none !important;
}

/* 🛒 ESTILOS PARA ÍCONO DE CARRITO EN LOOP DE PRODUCTOS */

/* Contenedor del ícono */
.cart-icon-wrapper {
    display: inline-flex;
    align-items: center;
    margin-right: 8px;
    margin-left: -2px;
}

/* Ícono SVG del carrito */
.cart-icon-loop {
    width: 16px;
    height: 16px;
    stroke: currentColor;
    transition: all 0.3s ease;
}

/* Estilos para botones de WooCommerce */
.woocommerce-loop-product__buttons .button.add_to_cart_button,
.elementor-widget-woocommerce-products .add_to_cart_button,
.elementor-widget-wc-archive-products .add_to_cart_button {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 6px;
    transition: all 0.3s ease;
}

/* Efecto hover en el botón */
.add_to_cart_button:hover .cart-icon-loop {
    transform: scale(1.1);
    stroke-width: 2.5;
}

/* Diseño mejorado con color corporativo Construcción #D19B3D */
.add_to_cart_button,
.button.product_type_simple {
    background: linear-gradient(135deg, #D19B3D 0%, #BA8B37 100%) !important;
    border: none !important;
    color: white !important;
    font-weight: 600 !important;
    padding: 10px 16px !important;
    border-radius: 6px !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-shadow: 0 2px 8px rgba(209, 155, 61, 0.2) !important;
}

.add_to_cart_button:hover,
.button.product_type_simple:hover {
    background: linear-gradient(135deg, #BA8B37 0%, #A57B2F 100%) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(209, 155, 61, 0.3) !important;
    color: white !important;
}

.add_to_cart_button .cart-icon-loop {
    stroke: white;
}

/* Estado de carga */
.add_to_cart_button.loading .cart-icon-loop {
    /* animation: spin 1s linear infinite; */
}

/* Estado de producto añadido */
.add_to_cart_button.added {
    background: linear-gradient(135deg, #28a745 0%, #20a040 100%) !important;
}

.add_to_cart_button.added .cart-icon-loop {
    animation: cart-success 0.6s ease;
}

@keyframes cart-success {
    0% { transform: scale(1); }
    50% { transform: scale(1.2); }
    100% { transform: scale(1); }
}

/* Responsive - Móviles */
@media (max-width: 768px) {
    .cart-icon-wrapper {
        margin-right: 4px;
    }

    .cart-icon-loop {
        width: 14px;
        height: 14px;
    }

    .add_to_cart_button {
        padding: 8px 12px !important;
        font-size: 14px !important;
    }
}

/* Para tablets */
@media (max-width: 1024px) and (min-width: 769px) {
    .add_to_cart_button {
        padding: 9px 14px !important;
    }
}

/* 📋 ESTILOS PARA PRODUCTOS EN LOOP */

/* Título del producto con margen simétrico */
.woocommerce-loop-product__title {
    margin: 12px 16px 8px 16px !important;
    text-align: left !important;
}

/* Precio del producto con margen simétrico */
.price {
    margin: 8px 16px 12px 16px !important;
    text-align: left !important;
    line-height: 1 !important;
}

/* 🚚 CONTENEDOR DE INDICADORES DE ENVÍO */
.shipping-indicators {
    display: flex !important;
    flex-direction: row !important;
    gap: 8px !important;
    margin: 12px 16px 12px 16px !important;
    justify-content: center !important;
}

/* Indicador de despacho a domicilio */
.delivery-indicator {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    padding: 8px 10px !important;
    background: rgba(62, 139, 170, 0.08) !important;
    border: 1px solid rgba(62, 139, 170, 0.2) !important;
    border-radius: 6px !important;
    color: #3E8BAA !important;
    font-size: 9px !important;
    font-weight: 500 !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    flex: 1 !important;
    line-height: 1.1 !important;
    text-align: center !important;
    transition: all 0.3s ease !important;
}

.delivery-indicator:hover {
    background: rgba(62, 139, 170, 0.12) !important;
    border-color: rgba(62, 139, 170, 0.3) !important;
}

.delivery-icon {
    width: 14px !important;
    height: 14px !important;
    color: #3E8BAA !important;
    stroke: #3E8BAA !important;
    flex-shrink: 0 !important;
    align-self: flex-start !important;
    margin-top: 2px !important;
}

/* Indicador de retiro en tienda */
.pickup-indicator {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    padding: 8px 10px !important;
    background: rgba(209, 155, 61, 0.08) !important;
    border: 1px solid rgba(209, 155, 61, 0.2) !important;
    border-radius: 6px !important;
    color: #D19B3D !important;
    font-size: 9px !important;
    font-weight: 500 !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    flex: 1 !important;
    line-height: 1.1 !important;
    text-align: center !important;
    transition: all 0.3s ease !important;
}

.pickup-indicator:hover {
    background: rgba(209, 155, 61, 0.12) !important;
    border-color: rgba(209, 155, 61, 0.3) !important;
}

.pickup-icon {
    width: 14px !important;
    height: 14px !important;
    color: #D19B3D !important;
    stroke: #D19B3D !important;
    flex-shrink: 0 !important;
    align-self: flex-start !important;
    margin-top: 2px !important;
}

/* Centrar botón "Agregar al carrito" */
.woocommerce-loop-product__buttons {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin-top: 16px !important;
    width: 100% !important;
}

.woocommerce-loop-product__buttons .add_to_cart_button {
    width: 90% !important;
    max-width: 200px !important;
    min-width: 140px !important;
}

/* Indicador de stock en loop de productos */
.product-stock-indicator {
    margin: 8px 16px 0 16px !important;
}

.stock-available {
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    font-style: normal !important;
    font-weight: 400 !important;
    font-size: 12px !important;
    line-height: 16px !important;
    color: #15803D !important;
    margin: 0 !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

.stock-low {
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    font-style: normal !important;
    font-weight: 400 !important;
    font-size: 12px !important;
    line-height: 16px !important;
    color: #D19B3D !important;
    margin: 0 !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

.stock-available:before,
.stock-low:before {
    display: none !important;
}

/* Responsive para móviles */
@media (max-width: 768px) {
    .woocommerce-loop-product__title,
    .price {
        margin-left: 12px !important;
        margin-right: 12px !important;
    }

    .shipping-indicators {
        margin: 10px 12px 8px 12px !important;
        gap: 6px !important;
    }

    .delivery-indicator,
    .pickup-indicator {
        padding: 6px 4px !important;
        font-size: 8px !important;
        gap: 3px !important;
        line-height: 1.1 !important;
    }

    .delivery-icon,
    .pickup-icon {
        width: 12px !important;
        height: 12px !important;
        margin-top: 1px !important;
    }

    .product-stock-indicator {
        margin: 6px 12px 0 12px !important;
    }

    .woocommerce-loop-product__buttons .add_to_cart_button {
        width: 85% !important;
        min-width: 120px !important;
    }
}

/* 📑 ESTILOS PARA TABS DE PRODUCTO */

/* Contenedor de tabs con borde inferior */
.wc-tabs {
    border-bottom: 1px solid #e5e5e5 !important;
    position: relative !important;
    margin-bottom: 20px !important;
}

/* Estilo de cada tab */
.wc-tabs li {
    position: relative !important;
    margin-bottom: -1px !important;
}

/* Enlaces de las tabs */
.wc-tabs li a {
    padding: 12px 20px !important;
    display: block !important;
    border-bottom: 2px solid transparent !important;
    transition: all 0.3s ease !important;
    text-decoration: none !important;
}

/* Tab activa */
.wc-tabs li.active a {
    border-bottom-color: #D19B3D !important;
    color: #D19B3D !important;
    font-weight: 500 !important;
}

/* Efecto hover en tabs inactivas */
.wc-tabs li:not(.active) a:hover {
    border-bottom-color: rgba(216, 144, 2, 0.3) !important;
}

/* Ocultar títulos de secciones dentro del contenido de tabs */
.woocommerce-tabs .panel h2 {
    display: none !important;
}

/* Estilos para iconos en tabs */
.wc-tabs li a {
    display: flex !important;
    align-items: center !important;
}

.wc-tabs li a svg {
    flex-shrink: 0 !important;
    margin-right: 6px !important;
}

/* 🚫 ESTILOS PARA PRODUCTOS AGOTADOS */

/* Botón de producto agotado */
.outofstock .add_to_cart_button,
.outofstock .product_type_simple {
    background: #6b7280 !important;
    border-color: #6b7280 !important;
    color: #ffffff !important;
    cursor: not-allowed !important;
    opacity: 0.8 !important;
}

.outofstock .add_to_cart_button:hover,
.outofstock .product_type_simple:hover {
    background: #6b7280 !important;
    border-color: #6b7280 !important;
    color: #ffffff !important;
    transform: none !important;
    box-shadow: none !important;
}

/* Remover ícono de carrito en productos agotados */
.outofstock .cart-icon-wrapper {
    display: none !important;
}

/* 🛒 ESTILOS PARA CONTADOR DE CARRITO */
.fkcart-shortcode-count,
.fkcart-item-count {
    background-color: #C44F34 !important;
    border-color: #C44F34 !important;
}

/* 👤 ESTILOS PARA ENLACE DE LOGIN */
.customer-login-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 35px !important;
    height: 35px !important;
    padding: 0 !important;
    text-decoration: none !important;
    color: #666 !important;
    transition: all 0.3s ease !important;
    border-radius: 6px !important;
}

.customer-login-link:hover {
    color: #666 !important;
    background-color: transparent !important;
}

.customer-login-link svg {
    width: 24px !important;
    height: 24px !important;
    flex-shrink: 0 !important;
    transition: none !important;
}

.customer-login-link:hover svg {
    transform: none !important;
}

/* 🛒 ESTILOS PARA ÍCONO DE CARRITO - AJUSTES DE TAMAÑO */
#fkcart-mini-toggler {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

#fkcart-mini-toggler .fkcart-shortcode-icon-wrap {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

#fkcart-mini-toggler svg {
    width: 35px !important;
    height: 35px !important;
    color: #666 !important;
}

/* Ajustar contador del carrito */
.fkcart-shortcode-count {
    position: absolute !important;
    top: -6px !important;
    right: -6px !important;
    min-width: 18px !important;
    height: 18px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
}

/* Responsive para móviles */
@media (max-width: 768px) {
    .customer-login-link {
        width: 32px !important;
        height: 32px !important;
    }

    .customer-login-link svg {
        width: 20px !important;
        height: 20px !important;
    }

    #fkcart-mini-toggler svg {
        width: 32px !important;
        height: 32px !important;
    }

    .fkcart-shortcode-count {
        min-width: 16px !important;
        height: 16px !important;
        font-size: 10px !important;
        top: -5px !important;
        right: -5px !important;
    }
}

/* Ocultar badge predeterminado de WooCommerce */
.onsale {
    display: none !important;
}


/* 🏷️ BADGE DE DESCUENTO PERSONALIZADO */
.discount-badge {
    position: absolute !important;
    top: 8px !important;
    right: 8px !important;
    background: #dc2626 !important;
    color: white !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    padding: 6px 10px !important;
    border-radius: 5px !important;
    z-index: 20 !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    line-height: 1 !important;
}

/* Asegurar que el enlace del producto tenga posición relativa */
.woocommerce-LoopProduct-link,
.woocommerce-loop-product__link {
    position: relative !important;
    display: block !important;
}

/* Contenedor de imagen con posición relativa */
.woocommerce ul.products li.product .woocommerce-LoopProduct-link,
.elementor-widget-woocommerce-products .woocommerce-loop-product__link {
    position: relative !important;
    overflow: hidden !important;
}

/* Responsive para móviles */
@media (max-width: 768px) {
    .discount-badge {
        top: 6px !important;
        right: 6px !important;
        font-size: 11px !important;
        padding: 4px 7px !important;
    }
}

/* 👤 ESTILOS PARA SHORTCODE LOGIN LINK */
.login-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
    color: #666666 !important;
}

.login-link svg {
    width: 20px !important;
    height: 20px !important;
    stroke: #666666 !important;
    fill: none !important;
    color: #666666 !important;
    transition: all 0.3s ease !important;
}

.login-link:hover,
.login-link:hover svg {
    stroke: #666666 !important;
    color: #666666 !important;
    fill: none !important;
}

/* ========================================
   👤 PANEL DE MI CUENTA - DISEÑO COMPLETO
   ======================================== */

/* Contenedor principal de Mi Cuenta */
.woocommerce-account .woocommerce {
    display: flex;
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto;
}

/* Navegación lateral */
.woocommerce-MyAccount-navigation {
    flex: 0 0 280px;
    background: #fafafa;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    padding: 20px;
    height: fit-content;
    position: sticky;
    top: 20px;
}

.woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.woocommerce-MyAccount-navigation li {
    margin: 0;
}

/* Enlaces de navegación */
.woocommerce-MyAccount-navigation a {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    text-decoration: none;
    font-size: 15px;
    font-weight: 500;
    color: #333;
    border-radius: 6px;
    transition: all 0.3s ease;
    background: white;
    border: 1px solid transparent;
}

.woocommerce-MyAccount-navigation a:hover {
    background: #f5f5f5;
    color: #D19B3D;
    border-color: #e8e8e8;
}

/* Estado activo del menú */
.woocommerce-MyAccount-navigation .is-active a,
.woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation .is-active a,
.woocommerce-MyAccount-navigation-link.is-active a,
.woocommerce-MyAccount-navigation ul li.is-active a {
    background: #D19B3D !important;
    color: #fff !important;
    font-weight: 600 !important;
    border-color: #D19B3D !important;
    box-shadow: 0 2px 8px rgba(209, 155, 61, 0.2);
}

.woocommerce-MyAccount-navigation .is-active a:hover,
.woocommerce-MyAccount-navigation li.is-active a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation .is-active a:hover,
.woocommerce-MyAccount-navigation-link.is-active a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a:hover {
    background: #BA8B37 !important;
    color: #fff !important;
}

/* Contenido principal */
.woocommerce-MyAccount-content {
    flex: 1;
    background: white;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    padding: 30px;
    min-height: 400px;
}

/* Títulos en el contenido */
.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
    color: #333;
    margin-top: 0;
    margin-bottom: 20px;
    font-weight: 600;
}

.woocommerce-MyAccount-content h2 {
    font-size: 24px;
    border-bottom: 2px solid #e8e8e8;
    padding-bottom: 12px;
}

.woocommerce-MyAccount-content h3 {
    font-size: 18px;
}

/* Enlaces en el contenido */
.woocommerce-MyAccount-content a {
    color: #D19B3D;
    text-decoration: none;
    font-weight: 500;
    transition: color 0.3s ease;
}

.woocommerce-MyAccount-content a:hover {
    color: #BA8B37;
    text-decoration: underline;
}

/* Botones en Mi Cuenta */
.woocommerce-MyAccount-content .button,
.woocommerce-MyAccount-content button {
    background: #D19B3D;
    color: white;
    border: none;
    padding: 12px 24px;
    border-radius: 6px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
}

.woocommerce-MyAccount-content .button:hover,
.woocommerce-MyAccount-content button:hover {
    background: #BA8B37;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(209, 155, 61, 0.3);
}

/* Tablas en Mi Cuenta (pedidos, descargas) */
.woocommerce-MyAccount-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
    font-size: 14px;
}

.woocommerce-MyAccount-content table thead {
    background: #fafafa;
    border-bottom: 2px solid #e8e8e8;
}

.woocommerce-MyAccount-content table th {
    padding: 12px 16px;
    text-align: left;
    font-weight: 600;
    color: #333;
}

.woocommerce-MyAccount-content table td {
    padding: 12px 16px;
    border-bottom: 1px solid #f0f0f0;
    color: #666;
}

.woocommerce-MyAccount-content table tr:hover {
    background: #fafafa;
}

/* Direcciones */
.woocommerce-MyAccount-content .woocommerce-Address {
    background: #fafafa;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 20px;
}

.woocommerce-MyAccount-content .woocommerce-Address-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}

.woocommerce-MyAccount-content .woocommerce-Address-title h3 {
    margin: 0;
}

/* Formularios en Mi Cuenta */
.woocommerce-MyAccount-content form .form-row {
    margin-bottom: 20px;
}

.woocommerce-MyAccount-content form label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: #333;
    font-size: 14px;
}

.woocommerce-MyAccount-content form input[type="text"],
.woocommerce-MyAccount-content form input[type="email"],
.woocommerce-MyAccount-content form input[type="password"],
.woocommerce-MyAccount-content form input[type="tel"],
.woocommerce-MyAccount-content form select,
.woocommerce-MyAccount-content form textarea {
    width: 100%;
    padding: 12px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 14px;
    transition: border-color 0.3s ease;
}

.woocommerce-MyAccount-content form input:focus,
.woocommerce-MyAccount-content form select:focus,
.woocommerce-MyAccount-content form textarea:focus {
    border-color: #D19B3D;
    outline: none;
    box-shadow: 0 0 0 3px rgba(209, 155, 61, 0.1);
}

/* Mensajes en Mi Cuenta */
.woocommerce-MyAccount-content .woocommerce-message,
.woocommerce-MyAccount-content .woocommerce-error,
.woocommerce-MyAccount-content .woocommerce-info {
    padding: 12px 16px;
    border-radius: 6px;
    margin-bottom: 20px;
    font-size: 14px;
}

.woocommerce-MyAccount-content .woocommerce-message {
    background: #f0fdf4;
    border-left: 4px solid #10b981;
    color: #065f46;
}

.woocommerce-MyAccount-content .woocommerce-error {
    background: #fef2f2;
    border-left: 4px solid #dc2626;
    color: #991b1b;
}

.woocommerce-MyAccount-content .woocommerce-info {
    background: #eff6ff;
    border-left: 4px solid #3b82f6;
    color: #1e40af;
}

/* Estado vacío (sin pedidos, sin descargas) */
.woocommerce-MyAccount-content .woocommerce-Message--info {
    text-align: center;
    padding: 40px 20px;
    background: #fafafa;
    border-radius: 8px;
    color: #666;
}

/* Responsive para tablets */
@media (max-width: 1024px) {
    .woocommerce-account .woocommerce {
        gap: 20px;
        padding: 0 20px;
    }

    .woocommerce-MyAccount-navigation {
        flex: 0 0 240px;
    }

    .woocommerce-MyAccount-content {
        padding: 25px;
    }
}

/* Responsive para móviles */
@media (max-width: 768px) {
    .woocommerce-account .woocommerce {
        flex-direction: column;
        gap: 20px;
        padding: 0 15px;
    }

    .woocommerce-MyAccount-navigation {
        flex: 1;
        width: 100%;
        position: static;
        padding: 15px;
    }

    .woocommerce-MyAccount-navigation a {
        padding: 10px 14px;
        font-size: 14px;
    }

    .woocommerce-MyAccount-content {
        padding: 20px;
    }

    .woocommerce-MyAccount-content h2 {
        font-size: 20px;
    }

    .woocommerce-MyAccount-content h3 {
        font-size: 16px;
    }

    /* Hacer tabla responsive con scroll horizontal */
    .woocommerce-MyAccount-content table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }

    .woocommerce-MyAccount-content .button,
    .woocommerce-MyAccount-content button {
        width: 100%;
        padding: 14px 20px;
    }
}

/* 🏢 REGIÓN BLOQUEADA EN RM */
#billing_state:disabled,
#shipping_state:disabled {
    background-color: #f5f5f5 !important;
    color: #666 !important;
    cursor: not-allowed !important;
    opacity: 0.6 !important;
}

.select2-container--disabled .select2-selection {
    background-color: #f5f5f5 !important;
    color: #666 !important;
    cursor: not-allowed !important;
    opacity: 0.6 !important;
}

.region-locked-notice {
    color: #666 !important;
    font-size: 12px !important;
    font-style: italic !important;
    margin-top: 4px !important;
    display: block !important;
}

/* 📦 DISPLAY DE PRECIOS DE ENVÍO */
.shipping-price-display {
    margin-top: 8px !important;
    padding: 12px 16px !important;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
    border: 1px solid #dee2e6 !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    color: #495057 !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05) !important;
    transition: all 0.3s ease !important;
}

.shipping-price-display strong {
    color: #343a40 !important;
    font-size: 14px !important;
    display: block !important;
    margin-bottom: 4px !important;
}

.comuna-select {
    width: 100% !important;
}

/* Estilos para select de comunas */
#billing_city,
#shipping_city {
    width: 100% !important;
    padding: 12px 16px !important;
    border: 1px solid #ddd !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    background: white !important;
}

#billing_city:focus,
#shipping_city:focus {
    border-color: #D19B3D !important;
    box-shadow: 0 0 0 2px rgba(209, 155, 61, 0.1) !important;
    outline: none !important;
}

/* Select2 styling para comunas */
.comuna-select + .select2-container .select2-selection {
    border: 1px solid #ddd !important;
    border-radius: 6px !important;
    padding: 4px 8px !important;
    min-height: 44px !important;
}

.comuna-select + .select2-container .select2-selection:focus,
.comuna-select + .select2-container.select2-container--focus .select2-selection {
    border-color: #D19B3D !important;
    box-shadow: 0 0 0 2px rgba(209, 155, 61, 0.1) !important;
}

/* Responsive */
@media (max-width: 768px) {
    .shipping-price-display {
        padding: 10px 12px !important;
        font-size: 12px !important;
    }

    .shipping-price-display strong {
        font-size: 13px !important;
    }
}

/* 📄 ESTILOS PARA SELECTOR FACTURA/BOLETA */

/* Contenedor de opciones - alineación horizontal */
#billing_select_field .woocommerce-input-wrapper {
    display: flex !important;
    gap: 15px !important;
    align-items: center !important;
    flex-wrap: wrap !important;
}

/* Ocultar radio buttons nativos */
#billing_select_field input[type="radio"] {
    position: absolute !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
}

/* Estilos para labels - Estado normal */
#billing_select_field label.radio {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 12px 20px !important;
    border: 1px solid #ddd !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #333 !important;
    background: white !important;
    position: relative !important;
    min-width: 150px !important;
    justify-content: center !important;
    flex: 1 !important;
}

/* Hover en opciones NO seleccionadas */
#billing_select_field input[type="radio"]:not(:checked) + label:hover {
    border-color: #D19B3D !important;
    background: #fafafa !important;
}

/* Iconos con ::before - Factura = Edificio/Empresa */
#billing_select_field label[for="billing_select_Factura"]::before {
    content: "" !important;
    width: 18px !important;
    height: 18px !important;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="%23666" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M3 21h18"/><path d="M5 21V7l8-4v18"/><path d="M19 21V11l-6-4"/><path d="M9 9v.01"/><path d="M9 12v.01"/><path d="M9 15v.01"/><path d="M9 18v.01"/></svg>') !important;
    background-repeat: no-repeat !important;
    background-size: contain !important;
    flex-shrink: 0 !important;
    transition: all 0.2s ease !important;
}

/* Iconos con ::before - Boleta = Persona/Usuario */
#billing_select_field label[for="billing_select_Boleta"]::before {
    content: "" !important;
    width: 18px !important;
    height: 18px !important;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="%23666" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2"/><circle cx="12" cy="7" r="4"/></svg>') !important;
    background-repeat: no-repeat !important;
    background-size: contain !important;
    flex-shrink: 0 !important;
    transition: all 0.2s ease !important;
}

/* Estado seleccionado */
#billing_select_field input[type="radio"]:checked + label {
    border-color: #D19B3D !important;
    background: rgba(209, 155, 61, 0.05) !important;
    color: #D19B3D !important;
    font-weight: 600 !important;
}

/* Iconos en estado seleccionado (color corporativo) - Factura */
#billing_select_field input[type="radio"]:checked + label[for="billing_select_Factura"]::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="%23D19B3D" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"><path d="M3 21h18"/><path d="M5 21V7l8-4v18"/><path d="M19 21V11l-6-4"/><path d="M9 9v.01"/><path d="M9 12v.01"/><path d="M9 15v.01"/><path d="M9 18v.01"/></svg>') !important;
}

/* Iconos en estado seleccionado - Boleta */
#billing_select_field input[type="radio"]:checked + label[for="billing_select_Boleta"]::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="%23D19B3D" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"><path d="M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2"/><circle cx="12" cy="7" r="4"/></svg>') !important;
}

/* Responsive para móviles */
@media (max-width: 768px) {
    #billing_select_field .woocommerce-input-wrapper {
        flex-direction: column !important;
        gap: 10px !important;
    }

    #billing_select_field label.radio {
        width: 100% !important;
        min-width: auto !important;
    }
}

