/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Feb 06 2026 | 03:08:52 */
/* --- Contenedor principal --- */
.category-widget {
    font-family: "Arial", sans-serif;
    max-width: 400px;
    margin: 20px auto;
}

/* --- Botón del acordeón --- */
.accordion-button {
    background-color: #f5b21a;
    color: #ffffff;
    font-weight: 900;
    text-transform: uppercase;
    font-size: 1.3rem !important;
    padding: 18px 25px;
    width: 100%;
    border: none;
    text-align: left;
    cursor: pointer;
    border-radius: 25px;
    margin-bottom: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: background-color 0.3s ease, transform 0.2s ease;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
}

.accordion-button:hover {
    background-color: #FF5A00;
    color: #fff !important;
    transform: translateY(-1px);
}

/* --- Ícono circular a la izquierda (si lo usas) --- */
.icon-circle {
    background-color: #711242 !important;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
}

/* --- Flecha de apertura --- */
.arrow {
    border: solid #fff;
    border-width: 0 4px 4px 0;
    display: inline-block;
    padding: 4px;
    transform: rotate(45deg);
    transition: transform 0.35s ease, border-color 0.3s ease;
    margin-top: -3px;
}

.accordion-button.active .arrow {
    transform: rotate(-135deg);
    margin-top: 3px;
    border-color: #fff;
}

/* --- Contenedor del panel desplegable --- */
.panel {
  background-color: #f9f9f9;
  border-radius: 15px;
  margin-bottom: 10px;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  padding: 0 20px;
  transition:
    max-height 0.5s ease-in-out,
    opacity 0.4s ease-in-out,
    padding 0.4s ease-in-out;
}

/* (opcional) Asegura que el contenido visible no se corte */
.panel.open {
  overflow: visible;
}


/* --- Panel activo (cuando se abre) --- */
.accordion-button.active + .panel {
    max-height: 1000px; /* Suficiente para cualquier contenido */
    opacity: 1;
    padding: 15px 20px 20px;
}

/* --- Lista de productos dentro del panel --- */
.product-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding-top: 10px;
    padding-bottom: 10px;
}

/* --- Tarjeta de producto --- */
.product-card {
    background-color: #fff;
    border-radius: 10px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    text-align: center;
    padding: 20px;
    max-width: 300px;
    margin: 0 auto;
    flex-shrink: 0;
    width: 100%;
    transition: transform 0.2s ease, box-shadow 0.3s ease;
}

.product-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15);
}

.product-card img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin-bottom: 15px;
}

.product-card h3 {
    font-size: 1.3rem !important;
    color: #333;
    margin-bottom: 10px;
}

.product-card p {
    font-size: 0.9em;
    color: #666;
    line-height: 1.5;
    margin-bottom: 20px;
    min-height: 45px;
}

.product-card .price {
    font-size: 1.6em;
    font-weight: bold;
    color: #d9534f;
    margin-bottom: 20px;
}

/* --- Botón de agregar al carrito --- */
.add-to-cart-btn {
    background-color: #D93232;
    color: #fff;
    border: none;
    border-radius: 25px;
    padding: 12px 25px;
    font-size: 1em;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    width: 80%;
    max-width: 200px;
}

.add-to-cart-btn:hover {
    background-color: #c9302c;
    transform: translateY(-1px);
    color: #fff !important;
}

/* Círculo contenedor del ícono */
.icon-circle {
  background-color: #fff;
  border-radius: 50%;
  width: 35px;
  height: 35px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  transition: background-color 0.3s ease;
}

/* Animación al girar el ícono SVG */
.icon-circle svg {
  transition: transform 0.4s ease;
}

.rotate-icon {
  transform: rotate(180deg);
}

/* Opcional: cambia color del círculo cuando está activo */
.accordion-button.active .icon-circle {
  background-color: #fff;
}

/* estilos de la parte de sabores tamaños completos de pizza */

.flavor-selector {
  display: flex;
  justify-content: space-between;
  margin: 10px 0;
  font-size: 0.9rem;
  color: #333;
}

.flavors {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 10px;
}

.flavors select {
  padding: 6px;
  border-radius: 8px;
  border: 1px solid #ddd;
  font-size: 0.9rem;
}

.hidden {
  display: none;
}


/* ESTILOS DE CARRITO DE COMPRAS */

/* estilos mini car */

/* --- Estilos de la Burbuja Flotante --- */
.floating-cart {
    position: fixed; /* Esto la hace flotante */
    bottom: 25px;
    right: 25px;
    background-color: #d9534f; /* Mismo rojo que el botón 'Add to cart' */
    color: white;
    width: 65px;
    height: 65px;
    border-radius: 50%; /* Círculo perfecto */
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    z-index: 999;
    transition: transform 0.2s ease;
    display: none; /* Oculta por defecto, JS la mostrará */
}

.floating-cart:hover {
    transform: scale(1.1);
}

.cart-icon {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

.cart-counter {
    position: absolute;
    top: -5px;
    right: -5px;
    background-color: #f5b21a; /* Naranja del acordeón */
    color: white;
    font-weight: bold;
    font-size: 0.9em;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 2px solid white;
}

/* --- Animación de 'sacudida' al añadir --- */
.floating-cart.shake {
    animation: shake 0.5s cubic-bezier(.36,.07,.19,.97) both;
}

@keyframes shake {
  10%, 90% { transform: translate3d(-1px, 0, 0); }
  20%, 80% { transform: translate3d(2px, 0, 0); }
  30%, 50%, 70% { transform: translate3d(-4px, 0, 0); }
  40%, 60% { transform: translate3d(4px, 0, 0); }
}


/* --- Modal general --- */
.cart-modal {
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  z-index: 1000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.6);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* Mostrar modal */
.cart-modal.show-modal {
  opacity: 1;
  visibility: visible;
}

/* Contenido del modal */
.cart-modal-content {
  background-color: #fff;
  padding: 25px 30px;
  border: none;
  border-radius: 14px;
  width: 90%;
  max-width: 480px;
  position: relative;
  transform: scale(0.9);
  filter: blur(4px);
  opacity: 0;
  transition: transform 0.4s ease, filter 0.4s ease, opacity 0.4s ease;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
}

/* Animación de aparición */
.cart-modal.show-modal .cart-modal-content {
  transform: scale(1);
  filter: blur(0);
  opacity: 1;
}

/* Botón cerrar (X) */
.close-cart-btn {
  color: #aaa;
  position: absolute;
  top: 10px;
  right: 18px;
  font-size: 28px;
  font-weight: bold;
  cursor: pointer;
  transition: color 0.2s ease;
}
.close-cart-btn:hover {
  color: #333;
}

/* --- Lista de productos --- */
#cart-items-list {
  margin-top: 20px;
  margin-bottom: 15px;
  max-height: 280px;
  overflow-y: auto;
  padding-right: 6px;
}
.cart-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid #eee;
}
.cart-item span {
  font-size: 1rem;
  color: #333;
}
.cart-item strong {
  color: #222;
}

/* --- Total --- */
.cart-total {
  font-size: 1.2em;
  font-weight: bold;
  text-align: right;
  margin-top: 10px;
  margin-bottom: 15px;
  color: #111;
}

/* --- Contenedor de botones --- */
.cart-actions {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

/* --- Botones principales --- */
.checkout-btn,
.empty-cart-btn {
  flex: 1;
  padding: 12px 0;
  border: none;
  border-radius: 30px;
  font-size: 1.05em;
  font-weight: 600;
  color: #fff;
  cursor: pointer;
  transition: all 0.3s ease;
}

/* Finalizar pedido */
.checkout-btn {
  background: linear-gradient(135deg, #16a34a, #22c55e);
	color: #fff !important;
}
.checkout-btn:hover {
  background: linear-gradient(135deg, #15803d, #16a34a);
}

/* Vaciar carrito */
.empty-cart-btn {
  background: linear-gradient(135deg, #dc2626, #ef4444);
}
.empty-cart-btn:hover {
  background: linear-gradient(135deg, #b91c1c, #dc2626);
	  color: #fff !important;
}

/* --- Scroll estético para lista --- */
#cart-items-list::-webkit-scrollbar {
  width: 6px;
}
#cart-items-list::-webkit-scrollbar-thumb {
  background-color: rgba(0,0,0,0.2);
  border-radius: 3px;
}
#cart-items-list::-webkit-scrollbar-thumb:hover {
  background-color: rgba(0,0,0,0.3);
}

/* --- Estilos de la Notificación "Producto Agregado" --- */
.product-added-notification {
    position: fixed;
    top: 20px;
    right: 20px;
    background-color: #5cb85c; /* Un verde para éxito */
    color: white;
    padding: 12px 25px;
    border-radius: 8px;
    font-size: 1.1em;
    z-index: 10000; /* Asegura que esté por encima de todo */
    opacity: 0; /* Oculto por defecto */
    visibility: hidden; /* También oculto por defecto para accesibilidad */
    transform: translateY(-50px); /* Empieza un poco más arriba */
    transition: opacity 0.5s ease-out, transform 0.5s ease-out, visibility 0.5s ease-out;
}

.product-added-notification.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0); /* Se desliza hasta su posición */
}

/* --- Widget de Direcciones (Estilo App/Rappi) --- */
.directions-widget {
    /* Fuente más moderna. Usará la fuente nativa del dispositivo (Apple, Google, Windows) */
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    
    max-width: 450px;
    margin: 30px auto;
    
    /* Fondo blanco puro para el look de "tarjeta" limpia */
    background-color: #ffffff; 
    
    /* Bordes y padding más generosos */
    padding: 24px;
    border-radius: 20px; /* Bordes más redondeados */
    
    /* Sombra más suave y difusa para el efecto "flotante" */
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.08); 
    
    text-align: center;
}

.directions-widget h3 {
    margin-top: 0;
    color: #333;
    font-size: 1.7em; /* Título un poco más grande */
    font-weight: 700; /* Más bold */
    text-align: center; /* Alineado a la izquierda, look más de app */
    margin-bottom: 8px; /* Espacio justo debajo del título */
}

/* --- Estilo para el párrafo de descripción --- */
/* (Selecciona el <p> que está justo después del <h3>) */
.directions-widget h3 + p {
    text-align: left;
    color: #555;
    font-size: 1em;
    margin-bottom: 24px; /* Más espacio antes del mapa */
}




/* ESTILOS DE ESTADO ABIERTO - CERRADO */
/* --- Fuentes y Colores --- */
.widget-restaurante {
    font-family: "Poppins", sans-serif;
    max-width: 350px; /* Ancho máximo del widget */
    margin: 20px 0;
}

/* --- 1. El Botón de Estado "Abierto Ahora" --- */
.estado-badge {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 50px;
  padding: 10px 18px;
  background: #FFF8E3; /* verde fijo para el texto */
  color: #fff;
  font-weight: 600;
  max-width: 320px;
  margin: 0 auto 15px;
  transition: background 0.4s ease;
}

.estado-badge .badge-texto {
  font-size: 1.5rem;
}

.badge-texto {
    color: #525252;
    padding: 15px 25px;
    font-size: 1.2rem;
    font-weight: 700; /* Letra gruesa */
    display: flex;
    align-items: center;
    justify-content: center;
    flex-grow: 1; /* Ocupa el espacio disponible */
}

.badge-icono {
  background: #16a34a; /* verde por defecto */
  padding: 10px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.3s ease;
}

.badge-icono svg {
  width: 20px;
  height: 20px;
  stroke: #fff;
}

/* Cambia solo el color del icono según estado */
.icono-abierto {
  background: #16a34a; /* verde */
}
.icono-cerrado {
  background: #b91c1c; /* rojo */
}

.badge-icono .icon {
    width: 36px;
    height: 36px;
}

/* --- 2. Lista de Información (Horario y Dirección) --- */
.info-lista {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 15px; /* Espacio entre el horario y la dirección */
}

.info-lista li {
    display: flex;
    align-items: center; /* Centra el icono con el texto */
    gap: 15px; /* Espacio entre icono y texto */
    font-size: 16px;
    color: #555;
    line-height: 1.5;
}

/* Estilo de los iconos grises */
.info-lista .icon {
    width: 28px;
    height: 28px;
    color: #aaa; /* Color gris para los iconos */
    flex-shrink: 0; /* Evita que el icono se encoja */
}

/* ESTILOS DEL MAPA UBICACION DEL NEGOCIO */ 

/* estilos de mapa */

/* --- Estilos para el Mapa --- */
.map-container {
    height: 250px;
    width: 100%;
    border-radius: 16px;
    margin-bottom: 24px;
    z-index: 1;
    overflow: hidden;
}

/* --- ESTILO BASE PARA BOTONES Y CAMPOS --- */
/* (Esta es la nueva sección que unifica el diseño) */
.btn-detect-location,
.btn-get-directions,
.form-manual-location input[type="text"] {
    font-weight: 600;
    font-size: 1em;
    padding: 16px 20px;
    border-radius: 25px; /* Bordes de píldora para todos */
    width: 100%;
    border: none;
    box-sizing: border-box; /* Asegura que el padding no afecte el ancho */
    transition: all 0.3s ease;
}

/* Estilos de hover para los botones */
.btn-detect-location:hover,
.btn-get-directions:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

/* --- ESTILOS ESPECÍFICOS DE CADA BOTÓN --- */

.btn-detect-location {
    display: inline-flex;
    justify-content: center; /* Centra el contenido */
    align-items: center;
    gap: 8px; /* espacio entre icono y texto */
    background-color: #0ea5a4;
    color: #fff;
    cursor: pointer;
}

.btn-detect-location img {
    width: 20px;
    height: 20px;
    display: block;
}

.btn-detect-location:hover {
    background-color: #0b8584;
}

.btn-detect-location:disabled {
    background-color: #ccc;
    cursor: wait;
    transform: none; /* Sin efecto hover al estar deshabilitado */
    box-shadow: none;
}

.btn-get-directions {
    /* Añadimos flex para mantener la misma altura que el otro botón */
    display: inline-flex; 
    justify-content: center;
    align-items: center;
    background-color: #d9534f;
    color: white;
    cursor: pointer;
}

.btn-get-directions:hover {
    background-color: #c9302c;
}

/* --- Separador "o" --- */
.separator {
    display: flex;
    align-items: center;
    text-align: center;
    margin: 24px 0;
    color: #aaa;
}
.separator::before, .separator::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid #f0f0f0;
}
.separator span {
    padding: 0 15px;
}

/* --- Formulario Manual --- */
.form-manual-location {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.form-manual-location input[type="text"] {
    /* Hereda la mayoría de estilos del bloque base */
    border: 1px solid #e0e0e0;
    background-color: #fff;
}

.form-manual-location input[type="text"]:focus {
    outline: none;
    border-color: #f5b21a;
    box-shadow: 0 0 0 2px rgba(245, 178, 26, 0.2);
}

/* --- Mensaje de error --- */
.location-error {
    color: #d9534f;
    font-size: 0.9em;
    margin-top: 16px;
    display: none;
    font-weight: 600;
}

/* fin de estilos de mapa */

/* ESTILOS DE LAS RESEÑAS */

.reviews-widget {
  font-family: 'Poppins', sans-serif;
  max-width: 800px;
  margin: 0 auto;
  color: #333;
}

.reviews-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 2px solid #eee;
  padding-bottom: 10px;
}

.overall-rating {
  display: flex;
  align-items: center;
  gap: 6px;
}

.overall-rating .stars span {
  color: gold;
  font-size: 20px;
}

.btn-write-review {
  background: #222;
  color: #fff;
  padding: 8px 16px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}
.btn-write-review:hover {
  background: #444;
}

/* === FONDO OSCURO DEL MODAL === */
.review-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.55); /* Fondo semitransparente */
  display: none; /* Oculto por defecto */
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.review-modal.active {
  display: flex; /* Se muestra al activar */
  animation: fadeIn 0.3s ease;
}

/* === CONTENEDOR INTERNO === */
.review-modal-content {
  background: #fff;
  padding: 30px 25px;
  border-radius: 14px;
  width: 90%;
  max-width: 420px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
  position: relative;
  animation: scaleIn 0.3s ease;
  font-family: 'Poppins', sans-serif;
}

/* === BOTÓN CERRAR === */
.review-modal-content .close-modal {
  position: absolute;
  top: -15px;
  right: -15px;
  width: 36px;
  height: 36px;
  background: #d7156e; /* color corporativo de Las Pizzas de Watson */
  color: #fff;
  border: none;
  border-radius: 50%;
  font-size: 20px;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
  transition: all 0.25s ease;
}

.review-modal-content .close-modal:hover {
  background: #b0135d;
  transform: scale(1.1);
}

/* === CAMPOS === */
#reviewText,
#reviewName {
  width: 100%;
  padding: 12px;
  border: 2px solid #d7156e;
  border-radius: 8px;
  outline: none;
  resize: vertical;
  font-size: 15px;
  font-family: 'Poppins', sans-serif;
  transition: all 0.2s ease;
}

#reviewText:focus,
#reviewName:focus {
  border-color: #a90f52;
  box-shadow: 0 0 6px rgba(215, 21, 110, 0.3);
}

/* === ESTRELLAS === */
.star-selector span {
  cursor: pointer;
  font-size: 28px;
  color: #ccc;
  transition: color 0.2s;
}

.star-selector span.active {
  color: gold;
}

/* === BOTÓN ENVIAR === */
.btn-submit-review {
  background: #d7156e;
  color: white;
  border: none;
  padding: 12px 20px;
  border-radius: 8px;
  margin-top: 12px;
  cursor: pointer;
  font-size: 15px;
  font-weight: 500;
  width: 100%;
  transition: background 0.3s ease;
}

.btn-submit-review:hover {
  background: #b0135d;
}

/* === ANIMACIONES === */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.9); }
  to { opacity: 1; transform: scale(1); }
}

/* estilos de mostrar reseñas */

.reviews-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.review-card {
  background: #fff;
  border-radius: 12px;
  padding: 1rem;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
  transition: 0.3s ease;
}
.review-card:hover {
  transform: translateY(-3px);
}
.review-header {
  display: flex;
  align-items: center;
  gap: 10px;
}
.avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: #4CAF50;
  color: white;
  display: flex; align-items: center; justify-content: center;
  font-weight: bold;
  font-size: 1.2rem;
}
.review-rating {
  color: #FFD700;
  font-size: 1.1rem;
  margin: 0.5rem 0;
}
.review-text {
  color: #444;
	border-radius: 12px !important;
  font-style: italic;
}

/* --- Fuentes y Colores --- */
.widget-restaurante {
    font-family: "Poppins", sans-serif;
    max-width: 350px; /* Ancho máximo del widget */
    margin: 20px 0;
}

/* NOTIFICACION SIMULADOR */

/* estilos del simulador de comentarios */

.opiniones-live {
  max-width: 500px;
  margin: 40px auto;
  background: #fff;
  padding: 25px;
  border-radius: 16px;
  box-shadow: 0 0 15px rgba(0,0,0,0.1);
  font-family: "Poppins", sans-serif;
}
.opiniones-live h3 {
  text-align: center;
  color: #333;
  margin-bottom: 20px;
}
.comentario {
  opacity: 0;
  transform: translateY(10px);
  animation: aparecer 0.5s forwards;
  background: #f8f8f8;
  border-left: 5px solid #34c759;
  padding: 10px 15px;
  border-radius: 10px;
  margin-bottom: 12px;
}
@keyframes aparecer {
  to { opacity: 1; transform: translateY(0); }
}
.nombre {
  font-weight: 600;
  color: #111;
}
.ubicacion {
  color: #666;
  font-size: 0.85em;
}
.texto {
  color: #333;
  font-size: 0.95em;
  margin-top: 5px;
}
.tiempo {
  font-size: 0.8em;
  color: #999;
  margin-top: 3px;
  text-align: right;
}

/* === CONTENEDOR === */
.notificaciones-live {
  position: fixed;
  bottom: 100px;
  right: 20px;
  display: flex;
  flex-direction: column-reverse;
  gap: 10px;
  z-index: 200;
}

/* === TARJETA DE NOTIFICACIÓN === */
.notificacion {
  background: #fff;
  border-left: 5px solid #34c759;
  padding: 12px 16px;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
  font-family: "Poppins", sans-serif;
  min-width: 260px;
  max-width: 320px;
  animation: aparecer 0.8s ease forwards, desaparecer 1.5s ease 12s forwards;
  opacity: 0;
  transform: translateY(20px);
}

@keyframes aparecer {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes desaparecer {
  to { opacity: 0; transform: translateY(20px); }
}

.notificacion strong {
  display: block;
  font-weight: 600;
  color: #111;
}
.notificacion .ubicacion {
  color: #666;
  font-size: 0.85em;
}
.notificacion .texto {
  color: #333;
  font-size: 0.9em;
  margin-top: 4px;
}

/* estilos del login de ingreso */

/* Contenedor principal centrado */
    .custom-wp-login-wrapper {
        display: flex;
        justify-content: center;
        width: 100%;
    }

    .login-card {
        background: white;
        width: 100%;
        max-width: 380px;
        padding: 40px 30px;
        border-radius: 25px;
        box-shadow: 0 10px 25px rgba(0,0,0,0.2);
        position: relative;
        font-family: 'Segoe UI', sans-serif; /* O la fuente de tu tema global */
    }

    /* Flecha volver */
    .back-arrow {
        position: absolute;
        top: 20px;
        left: 20px;
        color: #6a1b9a;
        font-size: 18px;
        cursor: pointer;
    }

    /* Inputs */
    .custom-input-group {
        position: relative;
        margin-bottom: 20px;
        margin-top: 35px;
    }

    .custom-input-group i {
        position: absolute;
        left: 20px;
        top: 50%;
        transform: translateY(-50%);
        color: #888;
        font-size: 16px;
        z-index: 1;
    }

    .custom-field {
        width: 100%;
        /* Aumentamos el cuarto valor (izquierda) de 50px a 65px */
        padding: 15px 20px 15px 65px; 
        border: 1px solid #6a1b9a;
        border-radius: 30px;
        outline: none;
        font-size: 15px;
        color: #333;
        transition: 0.3s;
        background: #fff;
    }

    .custom-field:focus {
        box-shadow: 0 0 8px rgba(106, 27, 154, 0.3);
        border-color: #4a148c;
    }

    /* Botón Login */
    .btn-custom-login {
        width: 100%;
        padding: 15px;
        border: none;
        border-radius: 30px;
        background: linear-gradient(to right, #E8569D, #910765);
        color: white;
        font-size: 16px;
        font-weight: bold;
        cursor: pointer;
        margin-top: 10px;
        box-shadow: 0 5px 15px rgba(106, 27, 154, 0.3);
        transition: transform 0.2s;
    }

    .btn-custom-login:hover {
		color: #fff !important;
        opacity: 0.95;
    }

    .btn-custom-login:active {
		color: #FFD9F8 !important;
        transform: scale(0.98);
    }

    /* Textos extra */
    .extra-links {
        text-align: center;
        margin-top: 15px;
    }
    
    .extra-links a {
        color: #6a1b9a;
        text-decoration: none;
        font-size: 14px;
        display: inline-block;
    }

    .signup-text {
        text-align: center;
        margin-top: 30px;
        font-size: 14px;
        color: #333;
    }

    .divider {
        display: flex;
        align-items: center;
        margin: 25px 0;
        color: #888;
        font-size: 13px;
    }

    .divider::before, .divider::after {
        content: "";
        flex: 1;
        height: 1px;
        background: #ccc;
    }

    .divider span {
        padding: 0 10px;
    }

    /* Redes Sociales */
    .social-icons {
        display: flex;
        justify-content: center;
        gap: 15px;
        margin-top: 15px;
    }

    .social-circle {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        display: flex;
        justify-content: center;
        align-items: center;
        color: white;
        font-size: 18px;
        cursor: pointer;
        text-decoration: none;
    }

    .fb { background-color: #3b5998; }
    .go { background-color: #db4437; }
    .tw { background-color: #1da1f2; }

    /* Mensaje de error oculto por defecto */
    #login-message {
        text-align: center;
        color: red;
        font-size: 13px;
        margin-bottom: 10px;
        display: none;
    }

/* estilo del mapa del footer pagina de ingreso */

/* AQUI CAMBIAMOS EL NOMBRE DEL CONTENEDOR */
    #contenedor-mapa-ingreso {
        height: 400px;
        width: 100%;
        border-radius: 20px;
        box-shadow: 0 10px 25px rgba(0,0,0,0.15);
        border: 2px solid #6a1b9a;
        z-index: 1;
        cursor: pointer; /* Manito para indicar que es clickeable */
    }
    
    .leaflet-popup-content-wrapper {
        border-radius: 10px;
        font-family: 'Segoe UI', sans-serif;
    }
    .leaflet-popup-content {
        font-size: 14px;
        font-weight: bold;
        color: #4a148c;
        text-align: center;
    }


/* Importamos la fuente solo para este contenedor */
  @import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600&display=swap');

  /* Contenedor principal centrado */
  .sorteo-wst1 {
    font-family: 'Poppins', sans-serif; /* Forzamos la fuente aquí */
    background: #ffffff;
    width: 100%;
    max-width: 450px; /* Ancho máximo para que no se estire feo */
    margin: 40px auto; /* Centrado automático */
    padding: 30px;
    border-radius: 24px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08); /* Sombra elegante */
    box-sizing: border-box;
    text-align: center;
    border: 1px solid #f0f0f0; /* Borde sutil por si el fondo de tu WP es blanco */
  }

  .sorteo-wst1 h3.review-title {
    margin: 0 0 8px 0 !important;
    font-size: 1.4rem !important;
    color: #1a1a1a;
    font-weight: 700;
    line-height: 1.2;
  }

  .sorteo-wst1 p.review-subtitle {
    margin: 0 0 25px 0 !important;
    color: #666;
    font-size: 0.95rem;
  }

  /* Inputs Wrapper */
  .wst-field {
    position: relative;
    margin-bottom: 20px;
    text-align: left;
  }

  /* Estilos de los Inputs para sobreescribir estilos del Tema de WP */
  .wst-field input, 
  .wst-field select {
    width: 100%;
    padding: 24px 16px 8px 16px !important; /* Padding interno */
    height: 56px !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 16px !important;
    background-color: #f9f9f9 !important;
    font-size: 1rem !important;
    color: #333 !important;
    outline: none !important;
    transition: all 0.3s ease;
    box-sizing: border-box;
    -webkit-appearance: none; /* Resetear estilos nativos */
  }

  .wst-field input:focus,
  .wst-field select:focus {
    background-color: #fff !important;
    border-color: #ff445e !important;
    box-shadow: 0 0 0 4px rgba(255, 68, 94, 0.1) !important;
  }

  /* Labels Flotantes */
  .wst-field label {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: #999;
    font-size: 0.95rem;
    pointer-events: none;
    transition: 0.2s ease all;
    background: transparent;
    line-height: 1;
  }

  /* Animación del Label */
  .wst-field input:focus ~ label,
  .wst-field input:not(:placeholder-shown) ~ label,
  .wst-field select:focus ~ label,
  .wst-field select:valid ~ label {
    top: 14px;
    font-size: 0.75rem;
    color: #ff445e;
    font-weight: 600;
  }
  
  /* Flecha custom para el select */
  .wst-field select {
    cursor: pointer;
    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23333%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px top 50% !important;
    background-size: 10px auto !important;
  }

  /* Zona de carga */
  .video-upload-wrapper {
    margin-bottom: 25px;
  }
  .video-upload-wrapper input[type="file"] {
    display: none;
  }
  .upload-btn-custom {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 20px;
    border: 2px dashed #ddd;
    border-radius: 16px;
    background-color: #fafafa;
    color: #555;
    font-weight: 500;
    cursor: pointer;
    transition: 0.3s;
  }
  .upload-btn-custom:hover {
    background-color: #fff5f6;
    border-color: #ff445e;
    color: #ff445e;
  }
  .video-info-text {
    display: block;
    margin-top: 8px;
    color: #999;
    font-size: 0.75rem;
  }

  /* Botón Submit */
  .btn-submit-rappi {
    width: 100%;
    padding: 16px;
    border: none;
    border-radius: 16px;
    background: linear-gradient(135deg, #ff445e 0%, #ff8e53 100%);
    color: white !important;
    font-size: 1.1rem;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
    box-shadow: 0 4px 15px rgba(255, 68, 94, 0.3);
    margin-top: 10px;
  }
  .btn-submit-rappi:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(255, 68, 94, 0.4);
    background: linear-gradient(135deg, #ff2e4d 0%, #ff7b36 100%);
  }

.upload-btn-custom {
  transition: all 0.3s ease;
  cursor: pointer;
}

.upload-btn-custom.video-loaded {
  border: 2px dashed #28a745;
  background: rgba(40, 167, 69, 0.08);
  color: #28a745;
}

