@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@700&family=Oswald:wght@700&display=swap');
@font-face {
    font-family: 'Cattle Trail JNL';
    src: url('fonts/cattle-trail-jnl.otf') format('opentype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'Octin Vintage';
    src: url('fonts/octin-vintage-b-bold.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

body { margin: 0; padding: 0; font-family: 'Arial Rounded MT Bold', Arial, sans-serif;  }
.agenda-title { 
    text-align: center; 
    font-size: 2.5rem; 
    margin: 32px 0 24px 0; 
    letter-spacing: 2px; 
    color: #fff; 
    text-shadow: 2px 2px 0 #444; 
    font-family: 'Octin Vintage', Arial, sans-serif;
}
.event-list { display: flex; flex-wrap: wrap; justify-content: center; gap: 24px; max-width: 1200px; margin: 0 auto; }
.event-card { background: #181818; border-radius: 16px; box-shadow: 0 4px 16px rgba(0,0,0,0.15); padding: 18px 18px 12px 18px; width: 320px; display: flex; flex-direction: column; align-items: center; transition: transform 0.2s; }
.event-card:hover { transform: translateY(-6px) scale(1.03); }
.event-date { 
    color: #ffe082; 
    font-size: 1.1rem; 
    font-weight: bold; 
    margin-bottom: 8px; 
    letter-spacing: 1px; 
    font-family: 'Cattle Trail JNL', Arial, sans-serif;
}
.event-title { 
    color: #fff; 
    font-size: 1.15rem; 
    font-weight: 600; 
    text-align: center; 
    margin-bottom: 12px; 
    font-family: 'Montserrat', Arial, sans-serif;
}
.event-price { 
    color: #fff;
    font-family: 'Oswald', Arial, sans-serif;
} 
.event-img { width: 100%; max-width: 260px; border-radius: 10px; object-fit: cover; margin-bottom: 6px; box-shadow: 0 2px 8px rgba(0,0,0,0.12); }
@media (max-width: 900px) { .event-list { flex-direction: column; align-items: center; gap: 20px; } .event-card { width: 90vw; max-width: 400px; } }
@media (max-width: 500px) {
    .agenda-title { font-size: 1.5rem; margin: 18px 0 12px 0; }
    /* Añadimos estilos para el carrusel en .event-list */
    .event-list {
        display: flex; /* Aseguramos que sea flex */
        overflow-x: auto; /* Habilitamos scroll horizontal */
        flex-wrap: nowrap; /* Evitamos que los elementos salten de línea */
        scroll-snap-type: x mandatory; /* Habilitamos el snap horizontal */
        -webkit-overflow-scrolling: touch; /* Scroll suave en iOS */
        padding: 0 10px; /* Añadimos padding lateral para que las tarjetas no peguen a los bordes */
        gap: 15px; /* Mantenemos o ajustamos el espacio entre tarjetas */
        /* Quitamos align-items si estaba para la vista de columna */
        /* align-items: initial; */
    }
    .event-card {
        padding: 12px 8px 8px 8px;
        /* Ajustamos el ancho para el carrusel, p.ej. 85% del viewport width */
        width: 85vw;
        max-width: 85vw; /* Aseguramos que no exceda */
        flex: 0 0 auto; /* Evitamos que se encoja o estire */
        scroll-snap-align: center; /* Centramos la tarjeta al hacer snap */
        /* El margin-bottom puede no ser necesario si gap funciona bien */
        /* margin-bottom: 0; */
    }
    .event-title { font-size: 1rem; }
    .event-date { font-size: 1rem; }
    .event-price { color: #fff;}
}



  /* Estilo para el fondo oscuro */
  .popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
  }

  /* Estilo de la ventana emergente */
  .popup-box {
    background: white;
    padding: 30px;
    border-radius: 12px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
    max-width: 400px;
    width: 90%;
    text-align: center;
    font-family: 'Segoe UI', sans-serif;
    animation: fadeIn 0.3s ease;
  }

  /* Botón de cerrar */
  .popup-box button {
    background-color: #ff4d4f;
    color: white;
    border: none;
    padding: 10px 20px;
    margin-top: 20px;
    border-radius: 8px;
    font-size: 16px;
    cursor: pointer;
    transition: background 0.2s ease;
  }

  .popup-box button:hover {
    background-color: #e04344;
  }

  @keyframes fadeIn {
    from { opacity: 0; transform: scale(0.9); }
    to   { opacity: 1; transform: scale(1); }
  }

@font-face {
    font-family: 'Playfair Display Black Italic';
    src: url('fonts/playfair-display-black-italic.ttf') format('truetype');
    font-weight: normal;
    font-style: italic;
} 
/* Nueva regla @font-face para cargar la fuente local */
@font-face {
    font-family: 'Playfair Display'; /* Nombre que le daremos a la fuente */
    src: url('/static/fonts/playfair-display-black-italic.ttf') format('truetype'); /* Ruta al archivo de fuente */
    font-weight: 900; /* Black */
    font-style: italic;
}

:root {
    --primary-bg: #000000;
    --card-bg: #f1f1ed;
    --accent: #e0c97f;
    --text-main: #222;
    --text-secondary: #444;
    --border-radius: 16px;
    --shadow: 0 4px 24px rgba(0,0,0,0.10);
    --transition: 0.2s cubic-bezier(.4,0,.2,1);
}
body {
    background: var(--primary-bg);
    margin: 0;
    font-family: 'Montserrat', Arial, sans-serif; /* Fuente por defecto */
    color: var(--text-main);
    overflow-x: hidden; /* Evitar desplazamiento horizontal */
}

.detalle-container {
    display: flex;
    flex-wrap: nowrap; /* Evita que los elementos salten a la siguiente línea */
    justify-content: center;
    align-items: flex-start;
    gap: 30px;
    padding: 30px;
    max-width: 1200px;
    margin: 0 auto;
    list-style-type: none; /* Eliminar los bullets de la lista */
}

.detalle-container li {
    padding: 0;
    margin: 0;
}
.detalle-img-wrapper {
    /* Eliminado flex: 1 1 0; */
    display: flex;
    justify-content: center;
    align-items: center; /* Centrar imagen si es más pequeña que el wrapper */
    /* Eliminado min-width, max-width, height: 100vh */
    width: clamp(300px, 40vw, 480px); /* Ancho adaptable con límites */
    border-radius: var(--border-radius);
    box-shadow: var(--shadow);
    /* Eliminado background: #fff; si no se quiere fondo */
    overflow: hidden; /* Asegurar que la imagen no se desborde */
}
.detalle-img {
    width: 100%; /* Ocupar el ancho del wrapper */
    height: auto; /* Altura automática para mantener proporción */
    /* Eliminado max-width: none; max-height: none; */
    object-fit: contain;
    border-radius: var(--border-radius); /* Puede quitarse si el wrapper ya lo tiene */
    transition: transform var(--transition);
    display: block;
}
.detalle-img:hover {
    transform: scale(1.03);
}
.detalle-info {
    /* Eliminado flex: 1 1 0; */
    background: #000000; /* Cambiado el color de fondo */
    color: #ffffff; /* Cambiado el color de texto principal a blanco */
    border-radius: var(--border-radius);
    padding: 36px 40px;
    /* Eliminado min-width */
    width: clamp(300px, 45vw, 480px); /* Ancho adaptable con límites */
    max-width: 480px; /* Mantenido como límite superior */
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    gap: 18px;
    height: fit-content; /* Ajustar altura al contenido */
}
.detalle-fecha {
    font-size: 1.1em;
    color: #f0f0f0; /* Cambiado a un gris claro para contraste */
    font-weight: 600;
    margin-bottom: 4px;
}
.detalle-titulo {
    font-size: 2.1em;
    color: #ffffff; /* Asegurado que el título sea blanco */
    font-weight: 700;
    margin-bottom: 10px;
    letter-spacing: 0.5px;
}
.detalle-precio {
    font-size: 1.1em;
    color: #f9b61a; /* Cambiado de var(--accent) al color solicitado */
    font-weight: 600;
    margin-bottom: 10px;
}
label {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1em;
    margin-bottom: 8px;
    /* El color del texto del label heredará #ffffff de .detalle-info */
}
input[type="number"] {
    width: 60px;
    padding: 6px 8px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 1em;
    background: #fafafa;
    transition: border-color var(--transition);
}
input[type="number"]:focus {
    border-color: var(--accent);
    outline: none;
}
select {            
    text-align:left;
    direction: ltr;
    font-family: sans-serif;
    padding: 6px 8px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 0.8em;
    background: #fafafa;
    margin-right: 5px;
    height: 2.8em;
}
#resumen-compra {
    background: #000000; /* Fondo oscuro por defecto */
    color: #ffffff; /* Texto blanco por defecto */
    /*padding: 18px 12px;*/
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    margin-top: 10px;
    overflow: hidden; /* Para que el border-radius afecte a la tabla */
}
table {
    width: 100%;
    border-collapse: collapse;
    font-size: 1em;
}
th, td {
    padding: 8px 6px;
    text-align: center;
    /* El color por defecto será blanco, heredado de #resumen-compra */
}
th {
    background: #f9b61a; /* Fondo del encabezado */
    color: #000000; /* Texto oscuro para el encabezado */
    font-weight: 700;
    /* Eliminado border-radius aquí, se maneja en #resumen-compra */
}
/* Eliminamos las reglas de filas alternas */
/* tr:nth-child(odd) td { ... } */
/* tr:nth-child(even) td { ... } */

/* Estilo para la última fila (Total General) */
tr:last-child td {
    border-top: 2px solid #f9b61a; /* Usamos el color del encabezado para la línea */
    font-size: 1.1em;
    font-weight: bold; /* Mantenemos el texto en negrita */
    color: #ffffff; /* Aseguramos texto blanco */
    background: #000000; /* Aseguramos fondo oscuro */
}
/* Asegurar que todas las celdas td tengan el fondo y color correctos por defecto */
#resumen-compra tbody td {
        background: #000000;
        color: #ffffff;
}
/* Ajuste específico para la celda del total general si es necesario (ya cubierto por tr:last-child td) */
/* #res-total-general { ... } */

/* Nuevo estilo para el mensaje de localidad */
.mensaje-localidad {
    color: #f9b61a; /* Cambiado al color solicitado */
    font-family: 'Playfair Display', serif; /* Fuente solicitada, con fallback genérico */
    font-size: 1.2em; /* Aumentado el tamaño de fuente para que sea mayor que 1.1em */
    text-align: center; /* Centrar el texto */
    margin-top: 15px; /* Espacio superior */
    font-weight: 900; /* Asegurar que use la variante Black */
    font-style: italic; /* Asegurar que use la variante Italic */
}

/* Ajustes en Media Queries */
@media (max-width: 900px) {
    .detalle-container {
        flex-direction: row; /* Mantener dirección horizontal */
        flex-wrap: nowrap !important; /* Forzar nowrap */
        align-items: center;
        padding: 24px 10px; /* Ajustado padding */
        gap: 24px;
        overflow-x: auto; /* Permitir desplazamiento horizontal */
    }
    .detalle-img-wrapper {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%; /* Cambiar a 100% para ocupar todo el ancho */
        border-radius: var(--border-radius);
        box-shadow: var(--shadow);
        overflow: hidden;
    }             
    .detalle-info {
        min-width: unset;
        width: 90vw; /* Ancho relativo */
        max-width: 420px; /* Límite */
        padding: 24px 15px; /* Ajustado padding */
    }
}
@media (max-width: 768px) {
    .container {
        flex-direction: column;
        padding: 10px;
    }

    .detalle-container {
        flex-direction: column !important; /* Cambiar a dirección vertical */
        align-items: center;
        padding: 15px 10px;
        overflow-x: hidden; /* Evitar scroll horizontal */
    }
    
    .detalle-info {
        width: 90% !important; /* Ancho relativo */
        max-width: none !important; /* Eliminar límite máximo */
        padding: 20px 15px; /* Reducir padding */
        order: 1; /* Colocar primero en el orden visual */
    }
    
    .detalle-img-wrapper {
        width: 90% !important; /* Ancho relativo */
        max-width: none !important;
        order: 2; /* Colocar segundo en el orden visual */
        margin-top: 15px;
    }
    
    .detalle-titulo {
        font-size: 1.8em; /* Reducir tamaño del título */
    }
    
    /* Ajustes para formulario */
    label {
        flex-direction: row; /* Apilar elementos */
        align-items: flex-start;
        gap: 5px;
    }
    
    input[type="number"] {
        width: 80px; /* Aumentar ancho para mejor usabilidad */
    }
    
    /* Ajustes para tabla */
    table, th, td {
        font-size: 0.9em; /* Reducir tamaño de texto */
    }
    
    th, td {
        padding: 6px 4px; /* Reducir padding */
    }
    
    /* Ajustes para campos de entrada */
    .nombre-container {
        flex-direction: row;
        align-items: flex-start;
    }
    
    #nombre-usuario {
        width: 100%;
        box-sizing: border-box;
    }
    
    .whatsapp-input-container input[type="tel"] {
        width: 100%;
        box-sizing: border-box;
    }
}
        /* Ajustes específicos para pantallas muy pequeñas */
@media (max-width: 480px) {
    .detalle-info {
        width: 95% !important;
        padding: 15px 10px;
    }
    
    .detalle-titulo {
        font-size: 1.5em; /* Reducir tamaño del título */
    }
    
    .detalle-fecha, .detalle-precio {
        font-size: 0.9em; /* Reducir tamaño de fuente para fecha y precio */
    }
    
    label {
        font-size: 0.9em; /* Reducir tamaño de fuente para etiquetas */
        display: flow;
    }
    
    input[type="number"] {
        width: 70px; /* Ajustar ancho para mejor usabilidad */
    }
    
    table, th, td {
        font-size: 0.85em; /* Reducir tamaño de texto en la tabla */
    }
    
    .mensaje-localidad {
        font-size: 1em; /* Ajustar tamaño de fuente para el mensaje de localidad */
    }
    
    .boton-accion {
        font-size: 0.9em; /* Reducir tamaño de fuente para botones */
    }
}


@media (max-width: 600px) {
        .detalle-container {
        flex-direction: row; /* Mantener dirección horizontal */
        flex-wrap: nowrap !important; /* Forzar nowrap */
        /*padding: 15px 0; /* Menos padding */
        overflow-x: auto; /* Permitir desplazamiento horizontal */
        }
    .detalle-img-wrapper {
            width: 100vw; /* Ancho completo */
            max-width: 100vw;
            border-radius: 0; /* Sin bordes redondeados */
    }
    .detalle-img {
        width: 90%; /* Asegurar que la imagen ocupe todo el ancho del contenedor */
        height: auto;
        object-fit: cover; /* Cambiar a cover para que la imagen ocupe todo el espacio */
        border-radius: var(--border-radius);
        transition: transform var(--transition);
        display: block;
    }
    .detalle-info {
        width: 90vw;
        max-width: 90vw;
        border-radius: 0;
        padding: 18px 5vw; /* Padding relativo */
    }
    #resumen-compra {
        padding: 10px 3vw; /* Padding relativo */
    }
    table, th, td {
        font-size: 0.95em; /* Ligeramente más pequeño */
    }
    /* Ajuste para botones en pantallas pequeñas */
    .botones-accion {
        flex-direction: column; /* Apilar botones verticalmente */
        gap: 10px;
    }
    .boton-accion {
        width: 90%; /* Ocupar todo el ancho */
    }

    #prefijo-whatsapp {
        font-size: 0.8em;
        height: 2.4em;
    }
}

/* Estilo común para los botones */
.boton-accion {
    padding: 12px 20px;
    border: none;
    border-radius: 8px;
    font-size: 1em;
    font-weight: 600;
    cursor: pointer;
    transition: background-color var(--transition), transform var(--transition);
    text-align: center;
    text-decoration: none; /* Para el enlace 'Volver' */
    flex-grow: 1; /* Permitir que los botones crezcan */
    min-width: 150px; /* Ancho mínimo para evitar que sean demasiado pequeños */
}

/* Estilo específico para el botón Continuar */
.boton-continuar {
    background-color: #f9b61a; /* Color principal */
    color: #000000; /* Texto oscuro */
}

.boton-continuar:hover {
    background-color: #e0a818; /* Un poco más oscuro al pasar el ratón */
    transform: translateY(-2px);
}

/* Estilo específico para el botón Volver */
.boton-volver {
    background-color: #676a5c; /* Color solicitado */
    color: #ffffff; /* Texto blanco */
}

.boton-volver:hover {
    background-color: #575a4c; /* Un poco más oscuro al pasar el ratón */
    transform: translateY(-2px);
}

/* Estilos para el selector de prefijo y contenedor de WhatsApp */
#prefijo-whatsapp {
    font-family: sans-serif;
    padding: 6px 8px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 0.8em;
    background: #fafafa;
    margin-right: 5px;
    height: 2.8em;
}

#nombre-usuario {
    font-size: 1.2em; /* Tamaño de fuente aumentado */
    font-family: Arial, sans-serif; /* Cambiado a Arial */
    vertical-align: middle;
}
#cedula {
    font-size: 1.2em; /* Tamaño de fuente aumentado */
    font-family: Arial, sans-serif; /* Cambiado a Arial */
    vertical-align: middle;
}
#correo {
    font-size: 1.2em; /* Tamaño de fuente aumentado */
    font-family: Arial, sans-serif; /* Cambiado a Arial */
    vertical-align: middle;
}
.nombre-container {
    display: flow;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}
.whatsapp-input-container {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 5px;
    margin-bottom: 15px;
}

.whatsapp-input-container label {
    flex-basis: 100%;
    margin-bottom: 5px;
}

.whatsapp-input-container input[type="tel"] {
    flex-grow: 1;
    height: 35px;
    box-sizing: border-box;
    padding: 6px 8px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 1em;
    background: #fafafa;
}

.whatsapp-input-container input[type="tel"]:focus {
    border-color: var(--accent);
    outline: none;
}

/* Nuevo estilo para el mensaje de error */
.error-mensaje {
    color: #ff4d4d; /* Un color rojo para errores */
    font-size: 0.85em; /* Tamaño de fuente pequeño */
    margin-top: 4px; /* Pequeño espacio superior */
    min-height: 1em; /* Para evitar saltos de diseño cuando está vacío */
    width: 100%; /* Ocupar el ancho disponible */
    text-align: left; /* Alinear a la izquierda */
    flex-basis: 100%; /* Ocupar toda la línea si es necesario */
}

/* Nuevo contenedor para los botones */
.botones-accion {
    display: flex;
    justify-content: space-between; /* Espacio entre botones */
    gap: 15px; /* Espacio si se envuelven */
    margin-top: 25px; /* Espacio sobre los botones */
    flex-wrap: wrap; /* Permitir que los botones se envuelvan */
}



/* Estilo específico para el botón Continuar */
.boton-continuar {
    background-color: #f9b61a; /* Color principal */
    color: #000000; /* Texto oscuro */
}

.boton-continuar:hover {
    background-color: #e0a818; /* Un poco más oscuro al pasar el ratón */
    transform: translateY(-2px);
}

/* Estilo específico para el botón Volver */
.boton-volver {
    background-color: #585656; /* Color solicitado */
    color: #ffffff; /* Texto blanco */
    border-radius: 8px;
    display: inline-block;
}

.boton-volver:hover {
    background-color: #615757; /* Un poco más oscuro al pasar el ratón */
    transform: translateY(-2px);
}    

.bodystatus {
  height: 100%;
  margin: 0;
  padding: 0;
  background-color: #000000; /* o el color que estás usando */
  font-family: 'Segoe UI', sans-serif;
}

.main-.containerstatus 
 {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100vh; /* 100% del alto de la pantalla */
  flex-direction: column;
}

.form-box {
  height: 100%;
  width: 100%;
  margin: 0;
  /*
  background-color: #ddd;
  padding: 30px;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  min-width: 320px;*/
}

/* Centra el contenedor del botón en la página usando flexbox */
.main-containerstatus {
    display: flex;
    flex-direction: column;
    align-items: center; /* Centra horizontalmente los elementos */
    justify-content: center; /* Centra verticalmente si el contenedor tiene un alto definido */
}

/* El resto de los estilos del botón son los mismos que en la Opción 1 */
.link-style {
    display: inline-block;
    padding: 12px 24px;
    background-color: #bbb6e3;
    color: #fff !important;
    text-decoration: none;
    border-radius: 5px;
    font-weight: bold;
    transition: background-color 0.3s ease;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.link-style:hover {
    background-color: #d7d4e0;
    box-shadow: 0 6px 8px rgba(0, 0, 0, 0.15);
}