.card-img, .card-img-top {
        object-fit: contain !important;
}


/* ======================================= */
/* 1. Estilo General de Etiquetas (Pill Badge) */
/* ======================================= */

.badge-tipo-venta {
    display: inline-block;
    padding: 4px 10px; /* Espaciado cómodo */
    border-radius: 20px; /* Forma de píldora */
    font-size: 13px;
    font-weight: bold;
    text-transform: uppercase;
    margin-right: 8px; /* Separación de otros elementos */
}

/* Colores para cada tipo de venta */
.badge-rapida {
    background-color: #C8E6C9; /* Menta */
    color: #388E3C; /* Verde oscuro */
}

.badge-cliente {
    background-color: #FFCCBC; /* Durazno */
    color: #E64A19; /* Naranja oscuro */
}

.badge-mayorista {
    background-color: #BBDEFB; /* Azul cielo */
    color: #1976D2; /* Azul rey */
}


/* ======================================= */
/* 2. Estilos de la Barra de Envío Gratis */
/* ======================================= */

#barra-envio-gratis-contenedor {
    margin-top: 20px;
    padding: 10px;
    border: 1px solid #e0e0e0; /* Borde sutil para delimitar la sección */
    border-radius: 6px;
    /* Estilo para que el texto de ¡Casi listo! se vea mejor */
    font-size: 16px;
    color: #333;
    line-height: 1.4;
    font-weight: 500;
}

/* Contenedor de la barra visual */
.barra-principal-fondo {
    width: 100%;
    height: 12px; /* Altura fija */
    background-color: #f0f0f0; /* Fondo gris claro */
    border-radius: 6px;
    overflow: hidden; /* Esto es CLAVE */
    margin-top: 10px; /* Separación del texto */
}

/* El relleno que muestra el progreso */
#barra-relleno.barra-principal-relleno {
    height: 100%;
    width: 0%; /* JS cambia este valor */
    background-color: #007bff; /* Azul primario para progreso */
    transition: width 0.4s ease-in-out; 
}

/* Estado de META ALCANZADA (JS añade la clase 'barra-meta-lograda' al contenedor) */
.barra-meta-lograda #barra-relleno.barra-principal-relleno {
    background-color: #28a745; /* Verde de éxito */
}

/* Texto de éxito (para que resalte cuando se logra la meta) */
.barra-meta-lograda .texto-progreso {
    font-weight: bold;
    color: #28a745; 
}


#btn-retirar-envio {
    /* 1. ELIMINAR EL CUADRO Y EL BORDE */
    background: none !important; /* Quita el fondo negro/gris por defecto */
    border: none !important;      /* Quita el borde del botón */
    padding: 0 !important;        /* Quita el espacio interno que hace que el botón sea grande */
    
    /* 2. ESTILO DEL ÍCONO (la "X") */
    color: #cc0000 !important;   /* Rojo vivo para indicar acción peligrosa */
    font-size: 18px !important;  /* Hacer la X un poco más grande para mejor toque táctil */
    cursor: pointer !important;

    /* 3. POSICIÓN Y ESPACIO */
    margin-left: 12px !important; /* Más separación del valor $11.34 */
    display: inline-flex !important;
    align-items: center !important;
}

/* 4. Efecto sutil al pasar el mouse */
#btn-retirar-envio:hover {
    opacity: 0.7; /* Lo hace ligeramente transparente al pasar el mouse */
    background-color: transparent !important; /* Asegura que no aparezca el fondo al hacer hover */
}


/* ======================================= */
/* ESTILOS DE BOTÓN DE ICONO CUADRADO */
/* ======================================= */

.btn-cuadrado-icono {
    /* 1. Definir dimensiones cuadradas y compactas */
    width: 100% !important; 
    height: 45px !important;
    
    /* 2. Centrar el ícono */
    display: inline-flex !important;
    align-items: center; 
    justify-content: center;
    
    /* 3. Eliminar relleno y bordes innecesarios */
    padding: 0 !important; 
    border-radius: 0.5rem !important; /* Bordes suaves */
    line-height: 1; /* Asegura el centrado vertical */
}

/* 4. Estilo del ícono (Más grande) */
.btn-cuadrado-icono i.bi {
    font-size: 1.5rem !important; /* Ícono significativamente grande para el toque */
    margin: 0 !important; /* Elimina cualquier margen residual */
}


/* ======================================= */
/* ESTILOS DE SCANNER */
/* ======================================= */

.scanner-frame{
  position: relative;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  border-radius: 14px;
  overflow: hidden;
  background: #000;

  /* Franja horizontal tipo lector */
  aspect-ratio: 16 / 7;
}

.scanner-frame video{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.scanner-overlay{
  position:absolute;
  inset:0;
  pointer-events:none;
}

.scanner-overlay::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(
      to bottom,
      rgba(0,0,0,.55) 0%,
      rgba(0,0,0,.55) 30%,
      rgba(0,0,0,.05) 42%,
      rgba(0,0,0,.05) 58%,
      rgba(0,0,0,.55) 70%,
      rgba(0,0,0,.55) 100%
    );
}

.scanner-overlay::after{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  top:50%;
  height:2px;
  background: rgba(0,255,140,.9);
  box-shadow: 0 0 12px rgba(0,255,140,.9);
  transform: translateY(-50%);
  animation: scanLine 1.2s ease-in-out infinite;
}

@keyframes scanLine{
  0%{ transform: translateY(-18px); opacity:.6; }
  50%{ transform: translateY(18px); opacity:1; }
  100%{ transform: translateY(-18px); opacity:.6; }
}

.scanner-hint{
  text-align:center;
  font-size:.9rem;
  color:#6c757d;
  margin-top:.5rem;
}
