/* .menubar{background-color: #ff9900;} */

.nav-link{
    color: #fff;
    font-weight: bold;
    font-family: Verdana, Geneva, Tahoma, sans-serif;
}

.badge{
    font-size: 0.5rem;
    font-weight: lighter;
}

.carrito a:hover{color: #fff;}

.carrito{margin-right: auto;}

.carrito a:focus{color:#fff;}

.user a{
    text-decoration: none;
    color: #fff;
    font-family: Verdana;
}

.user li a{
    color:#000;
    font-family: Verdana;
    font-size: 0.8rem;
}

.dropdown-menu{
    background-color: rgba(255, 167, 52, 0.9);
}

footer{
    background-color: rgb(255, 153, 0);
    bottom: 0;
    width: 100%;
}

footer li{
    display: block;
    color: #fff;
}

footer h5{
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 8px;
}

.divider-text h5 {
    margin-top: 30px;
    text-align: center;
}

.divider-text h5.linea {
    position: relative;
    z-index: 1;
}

.divider-text h5.linea:before {
    border-top: 2px solid rgba(255, 153, 0, 0.651);
    content: "";
    margin: 0 auto;
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    bottom: 0;
    width: 55%;
    z-index: -1;
}

.divider-text h5.linea span {
    background: #fff;
    padding: 0 15px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: sans-serif;
}

.box {
    width: 18rem;
    position: relative;
    overflow: hidden;
}

.box img {
    width: 100%;
    min-width: 18rem;
    display: block; /* Asegura que la imagen se comporte como un bloque */
}

.content {
    background-color: rgba(0,0,0, .7);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); /* Centra el contenido */
    text-align: center;
    color: #FFF;
    opacity: 0; /* Inicialmente invisible */
    transition: opacity .5s ease;
}

.box:hover .content {
    opacity: 1; /* Hace visible el contenido al hacer hover */
}

/* --- ESTILOS MODERNOS PARA LAS TARJETAS (CARD) --- */
.card {
    border: none; /* Elimina el borde por defecto */
    border-radius: 12px; /* Esquinas más redondeadas */
    overflow: hidden; /* Asegura que el contenido se ajuste a los bordes redondeados */
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.1); /* Sombra suave para un efecto flotante */
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Transición suave al interactuar */
}

.card:hover {
    transform: translateY(-8px); /* Eleva la tarjeta ligeramente al pasar el ratón */
    box-shadow: 0 12px 25px rgba(0, 0, 0, 0.2); /* Sombra más pronunciada al hover */
}

.a_transicion {
    display: block; /* Asegura que el enlace ocupe todo el espacio de la imagen */
    position: relative; /* Necesario para posicionar la segunda imagen */
    overflow: hidden;
    border-radius: 12px 12px 0 0; /* Solo redondea las esquinas superiores */
}

.a_transicion img {
    width: 100%;
    height: 100%; /* Asegura que la imagen llene el contenedor */
    object-fit: cover; /* Ajusta la imagen para cubrir el área sin distorsionar */
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out; /* Transición para el efecto de hover */
}

.a_transicion img:first-child {
    display: block; /* La primera imagen visible por defecto */
}

.a_transicion img:last-child {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0; /* La segunda imagen está oculta por defecto */
}

.a_transicion:hover img:first-child {
    opacity: 0; /* Oculta la primera imagen al pasar el ratón */
    transform: scale(1.05); /* Ligerísimo zoom a la primera imagen al ocultarse */
}

.a_transicion:hover img:last-child {
    opacity: 1; /* Muestra la segunda imagen al pasar el ratón */
    transform: scale(1.05); /* Ligerísimo zoom a la segunda imagen al mostrarse */
}

.agotado {
    filter: grayscale(100%) brightness(50%); /* Oscurece y desatura la imagen */
}

.agotado + div { /* Estilo para el texto AGOTADO superpuesto */
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 2.5rem; /* Tamaño de fuente impactante */
    color: rgba(100, 100, 100, 0.8); /* Color gris translúcido */
    font-weight: bold;
    text-align: center;
    width: 90%;
    background-color: rgba(255, 255, 255, 0.7); /* Fondo semi-transparente para legibilidad */
    padding: 0.5rem 1rem;
    border-radius: 8px;
    z-index: 1; /* Asegura que esté por encima de la imagen */
    pointer-events: none; /* Permite clics a través del overlay al enlace */
}

.card-body {
    padding: 1rem; /* Mantiene el padding uniforme */
}

/* Conservando los tamaños de letra originales para la categoría y el nombre del producto */
.card-title{ /* Usado para la categoría */
    color: #b9b9b9;
    font-size: 0.7rem; /* Tamaño de letra original */
}

.card-text{ /* Usado para el nombre del producto */
    font-family: Verdana;
    color: #585858;
    font-size: small; /* Tamaño de letra original */
    line-height: 1.3;
    min-height: 2.8rem; /* Reserva espacio para 2 líneas de texto */
    display: -webkit-box;
    -webkit-line-clamp: 2; /* Limita a 2 líneas */
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis; /* Añade puntos suspensivos si el texto se trunca */
}

.card-body h5 { /* Usado para el precio */
    font-size: 1rem; /* Tamaño de letra original */
    font-family: Verdana;
    font-weight: bold;
    color: rgb(255, 153, 0);
}

.precio-producto {
    color: rgb(255, 153, 0); /* Color naranja de la marca */
}

.card-body li{display: block;} /* Mantener si tu HTML sigue usando LI dentro de card-body */

/* Fin de la sección de tarjetas modernas */

.store-breadcrumb li{
    font-size: 1.1rem;
    font-family: Verdana;
}

.store-breadcrumb li{font-weight: bold;}

.details-breadcrumb{
    font-size: 0.8rem;
    font-family: Verdana;
}

.details-breadcrumb li{color: #b9b9b9;}
.details-breadcrumb li a{color: #b9b9b9;}

.hr-details{
    border-top: 5px solid #585858;
    width: 60px;
}

.hr-details-share{ 	
    border-top: 1px solid #a7a7a7;
    width: 60%;
}

.text-share{
    color: #585858;
    font-size: 0.8rem;
}

.offcanvas-title{font-family: Verdana;}

.increment{
    width: 110px;
}

.input-incre:focus{
    box-shadow: none;
    border-color: #acacac;
    font-family: Verdana;
    font-size: 0.8rem;
    color: #5e5d5d;
}

.input-incre{
    font-family: Verdana;
    font-size: 0.8rem;
    color: #5e5d5d;
}

.icon i{color: #fddc1e;}

.valoracion-h5{
    font-weight: bold;
    font-family: Verdana;
    color: #585858;
}

.descrip-valora button:focus{
    background-color: #00acee;
}

.descrip-valora button:hover{
    color: #fff;
    background-color: #00acee;
}

.descrip-valora button{color: #000;}

.button-cart{
    padding: 1% 2%;
    text-align: center;
    background-color: #00acee;
    color: #fff;
    border: none;
    font-size: 0.9rem;
}

.form-login{
    padding: 5% 20% 5% 20%;
}

.remision-ped{border-top: 3px solid #585858;}

.tarjeta{
    background-color: #f7edb9;
}

.modal{background-color: rgba(255, 153, 0, 0.651);}

.modal-content{
    background-color: #ffffffc7;
    width: 100%;
}

.register-form{
    border: 2px solid #5e5d5d;
    background-color: #eeeeee;
}

.carrito-tabla{
    border-right: 1px solid #d4d4d4;
}

.carrito-tabla th{font-size: 0.9rem;}
.carrito-tabla td{font-size: 0.9rem;}

.table-group-divider{border-top: 3px solid #d4d4d4;}
.td-border-botton{border-bottom: 3px solid #d4d4d4;}

.button-cart2{
    padding: 1% 2%;
    text-align: center;
    background-color: #fff;
    color: #00acee;
    border: 1px solid #00acee;
    font-size: 0.9rem;
}

.button-cart3{
    padding: 1% 2%;
    text-align: center;
    background-color: #037dad;
    color: #fff;
    font-size: 0.9rem;
    border: none;
}

#carrito-popover {
    display: none;
    position: absolute;
    top: 50px;
    right: 0;
    background-color: #fff;
    border: 1px solid #ccc;
    padding: 10px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    max-height: 350px;
    overflow-y: auto;
    width: 300px; 
}

.hr-popover{border-bottom: 2px solid #a7a7a7;}

.espacio{height: 140px;}

.input-search{
    border: none;
    font-size: 0.9rem;
    -webkit-box-shadow: 0px 4px 7px 0px rgba(110,110,110,1);
    -moz-box-shadow: 0px 4px 7px 0px rgba(110,110,110,1);
    box-shadow: 0px 4px 7px 0px rgba(110,110,110,1);
}

.button-search{
    text-align: center;
    border: none;
    background-color: #ffffff00;
}

.search{margin-right: auto;}

.input-search-v{
    border: none;
    font-size: 0.9rem;
    width: 500px;
    -webkit-box-shadow: 0px 4px 7px 0px rgba(110,110,110,1);
    -moz-box-shadow: 0px 4px 7px 0px rgba(110,110,110,1);
    box-shadow: 0px 4px 7px 0px rgba(110,110,110,1);
}

/* .user{margin-left: auto;} */

.submenu{font-size: 0.9rem;}
.login-a{font-size: 1.2rem;}
.login-b{font-size: 1rem;}

.nav-menu{display: inline-block;}

.filtro-prod{border: none;}

.text-logo{
    font-weight: bold;
}

.text-logo:hover{color: #fff;}

label.icon {
    cursor: pointer;
}

label.icon.resaltado {
    color: rgb(231, 183, 27);
}
label.icon:hover {
    cursor: pointer;
    color: rgb(231, 183, 27);
}

.whatsapp-container {
    position: fixed;
    bottom: 20px; /* Ajusta la distancia desde la parte inferior según tus preferencias */
    left: 20px; /* Ajusta la distancia desde la parte izquierda según tus preferencias */
    z-index: 1000; /* Ajusta el índice z para que esté por encima de otros elementos */
}

.envio-gratis, a{
    color: #FFFFFF;
    text-decoration: none;
}

.envio-gratis a {
    color: #FFFFFF;
    text-decoration: none;
}

.envio-gratis a.gratis {
    color: rgb(231, 183, 27);
    font-weight: bold;
    animation: titilar 0.9s infinite; /* Agregamos una animación de titilado */
}

@keyframes titilar {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0;
    }
}

.btn-comprardn{
    background:#3688f4;
    color: #ffffff;
    width: 100px;
    padding: 7px;
}

/* Oculta el checkbox predeterminado */
.producto-checkbox {
    display: none;
}
 
/* Estilo del label que actúa como el contenedor del checkbox */
.checkbox-label {
    display: inline-block;
    position: relative;
    padding-left: 30px; /* Espacio para la apariencia del nuevo checkbox */
    cursor: pointer; /* Cambia el cursor al señalar */
    vertical-align: middle; /* Alinea verticalmente el label y el checkbox */
}
 
/* Estilo del checkbox personalizado */
.custom-checkbox {
    position: absolute;
    top: 0;
    left: 0;
    height: 20px; /* Tamaño del nuevo checkbox */
    width: 20px; /* Tamaño del nuevo checkbox */
    background-color: #eee;
    border: 1px solid #aaa;
    border-radius: 3px;
}
 
/* Estilo del checkbox personalizado cuando está marcado */
.producto-checkbox:checked + .checkbox-label .custom-checkbox {
    background-color: #797979;
}
 
/* Estilo del texto del label */
.checkbox-label-text {
    position: relative;
    z-index: 1;
}

.compartir li{display: inline-block;}

.orange{background-color: rgb(255, 153, 0);}

/* --- NUEVOS ESTILOS PARA LA SECCIÓN DE TESTIMONIOS --- */
.testimonial-card {
    background-color: #fff;
    border-radius: 0.75rem;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 220px; /* Ajusta si tus comentarios son más largos */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.testimonial-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

.testimonial-stars .fas, .testimonial-stars .far {
    font-size: 1.1rem;
    color: #fddc1e; /* Amarillo para estrellas rellenas */
}

.testimonial-stars .far {
    color: #b9b9b9; /* Gris para estrellas vacías */
}

.testimonial-text {
    font-style: italic;
    color: #333;
    font-size: 1rem;
    line-height: 1.6;
    margin-bottom: 1rem;
    display: -webkit-box;
    -webkit-line-clamp: 4; /* Limita el texto a 4 líneas */
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.testimonial-author {
    font-size: 1.1rem;
    color: rgb(255, 153, 0); /* Naranja de la marca para el autor */
    margin-top: auto;
    margin-bottom: 0.25rem;
    font-weight: bold;
}

/* --- ESTILOS PARA LOS CONTROLES DEL CARRUSEL (APLICABLES A AMBOS CAROUSELES) --- */
/* Los iconos de las flechas del carrusel */
.carousel-control-prev,
.carousel-control-next {
    width: 5%;
    opacity: 0.7;
    transition: opacity 0.3s ease;
}

.carousel-control-prev:hover,
.carousel-control-next:hover {
    opacity: 1;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
    background-color: rgba(0, 0, 0, 0.4);
    border-radius: 50%;
    padding: 1.2rem;
    transition: background-color 0.3s ease;
}
.carousel-control-prev-icon:hover,
.carousel-control-next-icon:hover {
    background-color: #00acee;
}

/* --- Estilos para el botón de cierre del modal de ofertas (si quieres que sea tu estilo moderno) --- */
/* Este estilo reemplaza el "btn-close float-end bg-danger" si lo usas en el HTML del modal */
.btn-close-custom { /* Si no usas esta clase en el HTML, esta regla no tendrá efecto */
    background-color: rgba(0, 0, 0, 0.5);
    color: #fff;
    border-radius: 50%;
    padding: 0.5rem;
    font-size: 0.8rem;
    opacity: 1;
    transition: background-color 0.3s ease, transform 0.3s ease;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}
.btn-close-custom:hover {
    background-color: #00acee;
    transform: scale(1.1);
}

/* --- Estilos para el contenedor del código de cupón en el modal de ofertas --- */
/* Estos estilos reemplazan los inline styles en tu HTML del modal de ofertas */
.coupon-code-container {
    padding-bottom: 2rem; /* Ajusta este valor si el texto se superpone con la imagen */
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 350px;
}

.coupon-code-container .input-group {
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    border-radius: 0.5rem;
    overflow: hidden;
}

.coupon-code-container .input-group .form-control {
    border: none;
    background-color: rgba(255, 255, 255, 0.9);
    color: rgb(255, 153, 0);
    font-weight: bold;
    font-size: 1.1rem;
    padding: 0.75rem 1rem;
    text-align: center;
    border-radius: 0.5rem 0 0 0.5rem;
}

.coupon-code-container .input-group .btn {
    background-color: #00acee;
    color: #fff;
    border: none;
    padding: 0.75rem 1rem;
    font-weight: bold;
    border-radius: 0 0.5rem 0.5rem 0;
    transition: background-color 0.3s ease;
}

.coupon-code-container .input-group .btn:hover {
    background-color: #008cc9;
}

/* --- Variables CSS (Asegúrate de que estas estén en tu :root al inicio del archivo) --- */
:root {
    --primary-color: rgb(255, 153, 0); /* Naranja principal */
    --secondary-color: #00acee; /* Azul de acento */
    --accent-yellow: #fddc1e; /* Amarillo para estrellas */
    --text-dark: #333;
    --text-muted: #6c757d;
    --shadow-subtle: 0 4px 10px rgba(0, 0, 0, 0.1); /* Sombra suave */
    --shadow-hover: 0 8px 20px rgba(0, 0, 0, 0.15); /* Sombra al hover */
    /* ... (otras variables que ya tengas) ... */
}

/* --- ESTILOS MODERNOS PARA LAS TARJETAS (CARD) - Si ya las tienes, verifica los cambios --- */
.card {
    border: none;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 25px rgba(0, 0, 0, 0.2);
}

.a_transicion { /* Clase que envuelve las imágenes en la tarjeta */
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 12px 12px 0 0;
}

.a_transicion img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
}

.a_transicion img:first-child { display: block; }
.a_transicion img:last-child {
    position: absolute; top: 0; left: 0; opacity: 0;
}

.a_transicion:hover img:first-child { opacity: 0; transform: scale(1.05); }
.a_transicion:hover img:last-child { opacity: 1; transform: scale(1.05); }

.agotado { /* Filtro para la imagen de producto agotado */
    filter: grayscale(100%) brightness(50%);
}

.agotado-overlay { /* Estilo para el texto "AGOTADO" superpuesto */
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 2.5rem;
    color: rgba(100, 100, 100, 0.8);
    font-weight: bold;
    text-align: center;
    width: 90%;
    background-color: rgba(255, 255, 255, 0.7);
    padding: 0.5rem 1rem;
    border-radius: 8px;
    z-index: 1;
    pointer-events: none; /* Crucial para permitir el clic en el enlace subyacente */
}

.card-body {
    padding: 1rem;
}

/* Tamaños de letra originales para el texto dentro de la tarjeta */
.card-title { /* Categoría */
    color: #b9b9b9;
    font-size: 0.7rem; /* Original: 0.7rem */
}

.card-text { /* Nombre del producto */
    font-family: Verdana;
    color: #585858;
    font-size: small; /* Original: small */
    line-height: 1.3;
    min-height: 2.8rem; /* Para 2 líneas de texto */
    display: -webkit-box;
    -webkit-line-clamp: 2; /* Trunca a 2 líneas */
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.card-body h5 { /* Precio */
    font-size: 1rem; /* Original: 1rem */
    font-family: Verdana;
    font-weight: bold;
    color: #000;
}

.precio-producto { /* Color del precio normal */
    color: rgb(255, 153, 0); /* Tu color naranja */
}

/* Estilo para el precio tachado de oferta */
.precio-oferta {
    color: #dc3545; /* Rojo de Bootstrap para ofertas */
}

/* --- CHECKBOX PERSONALIZADO (ADAPTADO PARA BOOTSTRAP FORM-CHECK) --- */
/* Ya tienes algunas reglas, pero asegúrate de que estas sean coherentes */
.form-check-input.producto-checkbox { /* Usamos ambas clases para mayor especificidad */
    width: 1.25em; /* Tamaño estándar de Bootstrap */
    height: 1.25em;
    border: 1px solid #aaa; /* Borde original */
    border-radius: 0.25rem; /* Pequeño redondeo */
    transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.form-check-input.producto-checkbox:checked {
    background-color: #797979; /* Color de fondo al estar marcado, según tu original */
    border-color: #797979;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10l3 3l6-6'/%3e%3c/svg%3e"); /* Tick blanco */
}

.form-check-label.checkbox-label {
    padding-left: 0.5rem; /* Espacio entre el checkbox y el texto */
    cursor: pointer;
    vertical-align: middle;
    color: var(--text-dark); /* Color de texto más legible */
}

/* --- BOTONES DE FILTRO Y ORDENAMIENTO --- */
.btn-outline-secondary { /* Para los botones de ordenar y filtrar del desktop */
    border-color: var(--border-color);
    color: var(--text-dark);
    transition: all 0.3s ease;
}

.btn-outline-secondary:hover {
    background-color: var(--secondary-color);
    border-color: var(--secondary-color);
    color: var(--text-light);
}

.btn-primary.d-inline-flex { /* Para el botón "Filtrar" en móvil */
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: var(--text-light);
    transition: all 0.3s ease;
}
.btn-primary.d-inline-flex:hover {
    background-color: #e68a00; /* Un tono más oscuro de naranja al hover */
    border-color: #e68a00;
}

/* --- OFFCANVAS PARA FILTROS MÓVILES --- */
/* Si ya tienes estilos para offcanvas, verifica que no haya conflictos */
.offcanvas-header {
    background-color: var(--primary-color); /* Encabezado del offcanvas */
    color: var(--text-light);
}
.offcanvas-header .btn-close {
    color: var(--text-light); /* Color del botón de cerrar */
    opacity: 1;
    filter: invert(1) grayscale(100%) brightness(200%); /* Para hacer la 'x' blanca */
}

/* --- Variables CSS (Asegúrate de que estas estén en tu :root al inicio del archivo) --- */
:root {
    --primary-color: rgb(255, 153, 0); /* Naranja principal */
    --secondary-color: #00acee; /* Azul de acento */
    --accent-yellow: #fddc1e; /* Amarillo para estrellas de valoración */
    --text-dark: #333; /* Color de texto general */
    --text-muted: #6c757d; /* Gris tenue */
    --border-color: #dee2e6; /* Color de borde predeterminado de Bootstrap */
    --shadow-sm: 0 .125rem .25rem rgba(0,0,0,.075); /* Sombra pequeña */
    --shadow-lg: 0 .5rem 1rem rgba(0,0,0,.15); /* Sombra grande */
    /* ... otras variables que ya tengas ... */
}

/* --- ESTILOS GENERALES PARA DETALLE DE PRODUCTO --- */
.product-thumbnail { /* Miniaturas de imagen del producto */
    width: 80px; /* Ancho fijo para las miniaturas verticales */
    height: 80px; /* Altura fija para mantener proporción */
    object-fit: cover; /* Recorta la imagen para que cubra el área */
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.2s ease-in-out;
}

.product-thumbnail:hover, .product-thumbnail[data-bs-slide-to].active {
    border-color: var(--primary-color); /* Resalta la miniatura activa o al pasar el ratón */
}

.carousel-indicators-thumbnails { /* Indicadores de carrusel para móviles (miniaturas horizontales) */
    position: static;
    margin-top: 1rem;
    justify-content: center;
}

.carousel-indicators-thumbnails button {
    width: 60px;
    height: 60px;
    margin: 0 5px;
    opacity: 0.6;
    transition: opacity 0.2s ease-in-out, transform 0.2s ease-in-out;
    border: 2px solid transparent;
    border-radius: 8px;
    overflow: hidden;
    background-color: transparent;
    padding: 0;
}

.carousel-indicators-thumbnails button img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 8px;
}

.carousel-indicators-thumbnails button.active {
    opacity: 1;
    transform: scale(1.05);
    border-color: var(--primary-color);
}

.hr-details { /* Línea divisoria debajo del título del producto */
    border-top: 3px solid var(--primary-color);
    width: 60px;
    margin-bottom: 1rem;
    margin-left: 0;
}

.hr-details-share { /* Línea divisoria para la sección de compartir */
    border-top: 1px solid var(--border-color);
    width: 100%;
    margin: 2rem 0;
}

/* --- ESTILOS PARA LA SECCIÓN DE CANTIDAD Y BOTONES DE CARRITO --- */
.increment { /* Contenedor para el control de cantidad */
    width: 160px;
    border-radius: 50px;
}

.increment .input-group-lg .btn { /* Botones de +/- */
    border: none;
    background-color: var(--background-light); /* Asumiendo que tienes background-light en tus variables */
    color: var(--primary-color); /* Cambiado a primary-color para consistencia */
    font-weight: bold;
    font-size: 1.25rem;
    padding: 0.5rem 1rem;
}
/* Asegura que el color de la fuente de los botones +/- sea el primary-color,
   ya que en HTML se usa text-primary */
.increment .input-group-text.text-primary {
    color: var(--primary-color) !important;
}


.increment .input-group-lg .form-control { /* Input de cantidad */
    border: none;
    background-color: transparent;
    font-size: 1.25rem;
    font-weight: bold;
    color: var(--text-dark);
}

.button-cart { /* Botón principal "Añadir al Carrito" */
    background-color: var(--primary-color);
    color: #FFFFFF;
    border: none;
    padding: 0.8rem 2rem;
    font-size: 1.1rem;
    font-weight: bold;
    border-radius: 50px;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.button-cart:hover {
    background-color: #e68a00; /* Tono de naranja más oscuro al hover */
    transform: translateY(-2px);
}

.btn-outline-primary { /* Botón "COMPRAR AHORA" */
    border-color: var(--primary-color);
    color: var(--primary-color);
    background-color: transparent;
    font-weight: bold;
    font-size: 1.1rem;
    padding: 0.8rem 2rem;
    border-radius: 50px;
    transition: all 0.3s ease;
}

.btn-outline-primary:hover {
    background-color: var(--primary-color);
    color: var(--text-light);
    transform: translateY(-2px);
}

/* --- ESTILOS PARA LA SECCIÓN DE COMPARTIR --- */
.compartir li a i.fab {
    font-size: 2.5rem; /* Iconos más grandes para redes sociales */
    transition: transform 0.2s ease;
}

.compartir li a i.fab:hover {
    transform: translateY(-3px);
}

/* --- ESTILOS PARA PESTAÑAS (DESCRIPCIÓN/VALORACIONES) --- */
.nav-pills .nav-item .nav-link {
    background-color: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-dark);
    font-weight: bold;
    padding: 0.8rem 1.5rem;
    border-radius: 0.5rem;
    transition: all 0.3s ease;
    margin: 0 0.5rem;
}

.nav-pills .nav-item .nav-link.active,
.nav-pills .nav-item .nav-link:hover {
    background-color: var(--primary-color);
    color: var(--text-light);
    border-color: var(--primary-color);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.tab-content .tab-pane {
    border-radius: 0.75rem;
    background-color: #fff;
}

/* --- ESTILOS PARA LA SECCIÓN DE VALORACIONES --- */
.valoracion-h5 {
    font-weight: bold;
    font-family: Verdana;
    color: var(--text-dark);
}

.h4.mx-1 { /* Asegura que las estrellas tengan el tamaño h4 */
    font-size: 1.5rem;
}

.progress {
    background-color: var(--background-light);
}

.progress-bar {
    background-color: var(--primary-color);
}

.valoracion-item {
    background-color: #f8f9fa;
    border-radius: 0.5rem;
    padding: 1.5rem;
    margin-bottom: 1rem;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}

.valoracion-item .text-muted.small {
    font-size: 0.85rem;
}

/* --- ESTILOS PARA EL FORMULARIO DE VALORACIÓN --- */
.form-valoracion {
    background-color: #fff;
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    box-shadow: var(--shadow-subtle);
}

.rating-stars .icon-star-rating {
    font-size: 2.5rem;
    color: #b9b9b9; /* Color gris por defecto */
    cursor: pointer;
    transition: color 0.2s ease;
    line-height: 1; /* Para alinear bien el icono de estrella */
    display: inline-block; /* Para que el cursor sea de puntero en toda la estrella */
}

/* **AJUSTE CRÍTICO AQUÍ: FUERZA EL COLOR AMARILLO** */
.rating-stars .icon-star-rating.highlighted,
.rating-stars .icon-star-rating:hover {
    color: var(--accent-yellow) !important; /* Añadido !important para asegurar la prioridad */
}

.form-control {
    border-color: var(--border-color);
    border-radius: 0.5rem;
    padding: 0.75rem 1rem;
}
.form-control:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.25rem rgba(255, 153, 0, 0.25);
}

/* --- MODAL DE GALERÍA DE IMÁGENES --- */
.modal-dialog.modal-xl {
    max-width: 50vw;
}

.modal-content.bg-transparent {
    background-color: transparent !important;
}

.btn-close-modal-custom { /* Botón de cierre del modal de galería */
    position: absolute;
    top: 15px;
    right: 15px;
    z-index: 1060;
    background-color: rgba(255, 255, 255, 0.8);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--text-dark);
    border: none;
    transition: background-color 0.2s ease, transform 0.2s ease;
}

.btn-close-modal-custom:hover {
    background-color: var(--primary-color);
    color: var(--text-light);
    transform: scale(1.1);
}

/* Controladores del carrusel en el modal (flechas) */
#productGalleryCarouselInner .carousel-control-prev-icon,
#productGalleryCarouselInner .carousel-control-next-icon {
    background-color: rgba(0, 0, 0, 0.6);
    border-radius: 50%;
    padding: 1.5rem;
}
#productGalleryCarouselInner .carousel-control-prev-icon:hover,
#productGalleryCarouselInner .carousel-control-next-icon:hover {
    background-color: var(--primary-color);
}

/* --- Variables CSS (Asegúrate de que estas estén en tu :root al inicio del archivo) --- */
:root {
    --primary-color: rgb(255, 153, 0); /* Naranja principal */
    --secondary-color: #00acee; /* Azul de acento */
    --text-dark: #333; /* Gris oscuro para texto general */
    --text-muted: #6c757d; /* Gris tenue */
    --border-color: #dee2e6; /* Color de borde predeterminado de Bootstrap */
    --shadow-sm: 0 .125rem .25rem rgba(0,0,0,.075); /* Sombra pequeña */
    /* ... otras variables que ya tengas ... */
}

/* --- Breadcrumb de Pasos de Compra --- */
.breadcrumb-steps .breadcrumb-item {
    font-size: 1.5rem; /* Tamaño más grande para los pasos */
    font-weight: bold;
}

.breadcrumb-steps .breadcrumb-item a {
    color: var(--text-dark);
    text-decoration: none;
    transition: color 0.3s ease;
}

.breadcrumb-steps .breadcrumb-item.breadcrumb-active a {
    color: var(--primary-color); /* Color activo */
}

.breadcrumb-steps .breadcrumb-item.breadcrumb-inactive a {
    color: var(--text-muted); /* Color inactivo */
    pointer-events: none; /* No clickable si no es el paso activo */
}

.breadcrumb-steps .breadcrumb-item::before { /* Flecha divisoria */
    color: var(--text-muted);
}
.breadcrumb-steps .breadcrumb-item:first-child::before {
    display: none; /* No mostrar flecha antes del primer elemento */
}

/* --- Tabla del Carrito --- */
.table-borderless th,
.table-borderless td {
    padding-left: 0.75rem; /* Padding horizontal */
    padding-right: 0.75rem;
}

.table thead th {
    font-weight: 600; /* Un poco más de negrita para los encabezados */
    color: var(--text-muted); /* Color más suave */
    border-bottom: 1px solid var(--border-color); /* Separador inferior */
}

.table tbody tr td {
    vertical-align: middle; /* Alineación vertical al centro */
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.table-group-divider {
    border-top: 2px solid var(--border-color); /* Línea divisoria entre thead y tbody */
}

.table-group-divider tr:first-child td {
    border-top: 0; /* Eliminar la doble línea si existe */
}

.fa-trash-can { /* Icono de eliminar */
    color: #dc3545; /* Rojo de peligro de Bootstrap */
    transition: color 0.2s ease, transform 0.2s ease;
}
.fa-trash-can:hover {
    color: #c82333; /* Rojo más oscuro al hover */
    transform: scale(1.1);
}

.input-group.justify-content-center .btn-sm { /* Botones +/- de cantidad */
    border-color: var(--border-color);
    color: var(--text-dark);
    transition: all 0.2s ease;
}
.input-group.justify-content-center .btn-sm:hover {
    background-color: var(--background-light);
    color: var(--primary-color);
    border-color: var(--primary-color);
}

.input-group.justify-content-center .form-control { /* Input de cantidad en la tabla */
    font-weight: bold;
    color: var(--text-dark);
}

/* --- Formularios de Código Promocional y Botones de Acción --- */
.input-group.rounded-start .form-control {
    border-radius: 0.25rem 0 0 0.25rem; /* Redondeado solo a la izquierda */
}

.input-group .btn-primary.rounded-end {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: var(--text-light);
    border-radius: 0 0.25rem 0.25rem 0; /* Redondeado solo a la derecha */
    transition: all 0.3s ease;
}

.input-group .btn-primary.rounded-end:hover {
    background-color: #e68a00; /* Naranja más oscuro al hover */
    border-color: #e68a00;
}

.button-cart2.btn-outline-primary { /* Botón "Seguir Comprando" */
    border-color: var(--primary-color);
    color: var(--primary-color);
    transition: all 0.3s ease;
}
.button-cart2.btn-outline-primary:hover {
    background-color: var(--primary-color);
    color: var(--text-light);
}

.button-cart3.btn-danger { /* Botón "Vaciar Carrito" */
    background-color: #dc3545; /* Rojo de peligro */
    border-color: #dc3545;
    color: var(--text-light);
    transition: all 0.3s ease;
}
.button-cart3.btn-danger:hover {
    background-color: #c82333; /* Rojo más oscuro al hover */
    border-color: #c82333;
}

/* --- Resumen del Total del Carrito --- */
.card h5.fw-bold.border-bottom {
    color: var(--text-dark);
}

.table-borderless .border-top {
    border-top: 1px solid var(--border-color) !important; /* Asegura la línea divisoria para el total */
}

/* Botón "Finalizar Compra" en el resumen */
.button-cart.btn-primary {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: var(--text-light);
    transition: all 0.3s ease;
}
.button-cart.btn-primary:hover {
    background-color: #e68a00;
    border-color: #e68a00;
}

.button-cart.btn-secondary { /* Botón de finalizar compra deshabilitado */
    background-color: var(--text-muted);
    border-color: var(--text-muted);
    color: var(--text-light);
}

.text-justify { /* Clase para justificar texto, si no está en Bootstrap */
    text-align: justify;
}

/* --- ESTILOS PARA LA SECCIÓN MIS COMPRAS --- */
.purchase-item-card .card-header {
    background-color: var(--background-light); /* Fondo para el encabezado de la tarjeta (fecha) */
    border-bottom: 1px solid var(--border-color);
    color: var(--text-dark);
    font-size: 1.1rem;
    padding: 0.75rem 1rem;
}

/* Estilos para los badges de estado del pedido */
.status-badge-pendiente {
    background-color: var(--warning-color) !important;
    color: var(--text-dark); /* Texto oscuro para el amarillo */
}
.status-badge-entregado, .status-badge-enviado {
    background-color: var(--success-green) !important;
    color: var(--text-light);
}
.status-badge-cancelado {
    background-color: var(--danger-color) !important;
    color: var(--text-light);
}

/* Estilos para los botones dentro de la tarjeta de compra */
.btn-sm.rounded-pill {
    font-size: 0.85rem;
    padding: 0.4rem 0.9rem;
}
/* Estilo específico para el botón "Volver a comprar" si es diferente al button-cart general */
.btn-comprardn { 
    background: var(--primary-color); /* Tu color naranja para este botón */
    color: var(--text-light);
    transition: background 0.3s ease;
}
.btn-comprardn:hover {
    background: #e68a00; /* Un tono más oscuro de naranja */
}