@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;700&display=swap');

/* --- Estilos para la Campaña de Donación --- */

body, h3, p, label, span, select, button, input, textarea {
    font-family: 'Montserrat', sans-serif;
}

/* Contenedor de los beneficiarios */
.lista-beneficiarios {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 20px;
}

/* Tarjeta de cada beneficiario */
.lista-beneficiarios .beneficiario-card {
    background-color: #ffffff;
    border: 3px solid #e0e0e0; /* Borde más grueso para consistencia */
    border-radius: 8px;
    padding: 15px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
    transition: all 0.3s ease;
    cursor: pointer;
}
.lista-beneficiarios .beneficiario-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}
.lista-beneficiarios .beneficiario-card.selected {
    border-color: #008A8A;
}
.beneficiario-card label { display: block; cursor: pointer; }
.beneficiario-card h3 { margin-top: 10px; margin-bottom: 5px; color: #008A8A; font-size: 1rem; }
.beneficiario-card p { margin: 0; font-size: 0.9em; color: #555; }

/* Estilo para el checkbox nativo */
.beneficiario-checkbox {
    accent-color: #008A8A;
    width: 1.3em;
    height: 1.3em;
    vertical-align: middle;
    margin-right: 5px;
}

/* --- Selector de Tipo de Donación --- */
.selector-tipo-donacion {
    display: flex;
    flex-wrap: nowrap; /* Evita que las tarjetas salten a la siguiente línea */
    gap: 20px;
}
.selector-tipo-donacion .tipo-donacion-card {
    flex-basis: 50%; /* Cada tarjeta ocupa el 50% */
    background-color: #ffffff;
    border: 2px solid #008A8A;
    border-radius: 8px;
    padding: 45px 20px 20px 20px; /* Aumentar padding superior */
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative; /* Para posicionar el check */
}
.selector-tipo-donacion .tipo-donacion-card:hover { 
    border-color: #008A8A; 
    box-shadow: 0 0 10px rgba(0, 138, 138, 0.5);
}
.tipo-donacion-card label { display: block; cursor: pointer; }
.selector-tipo-donacion .tipo-donacion-card.disabled {
    opacity: 0.6;
    cursor: not-allowed;
    background-color: #f9f9f9;
}
.selector-tipo-donacion .tipo-donacion-card.disabled:hover { 
    border-color: #008A8A;
    box-shadow: none;
}

/* Círculo para todas las tarjetas de tipo de donación */
.selector-tipo-donacion .tipo-donacion-card::before {
    content: "";
    position: absolute;
    top: 15px; /* Ajustar posición superior */
    left: 20px; /* Alinear a la izquierda */
    transform: none; /* Quitar transformación */
    width: 28px;
    height: 28px;
    border: 2px solid #e0e0e0; /* Borde gris por defecto */
    border-radius: 50%;
    background-color: #fff;
    z-index: 2;
    transition: border-color 0.3s ease;
}

/* Estilo para cuando una opción está seleccionada */
.selector-tipo-donacion .tipo-donacion-card.selected {
     border-color: #008A8A;
     box-shadow: 0 0 10px rgba(0, 138, 138, 0.5);
}

/* Cambia el color del borde del círculo cuando está seleccionado */
.selector-tipo-donacion .tipo-donacion-card.selected::before {
    border-color: #008A8A;
}

/* Punto interior que aparece solo cuando está seleccionado (estilo radio button) */
.selector-tipo-donacion .tipo-donacion-card.selected::after {
    content: "";
    position: absolute;
    z-index: 3; /* Encima del círculo */
    top: 22px; /* Ajustar posición superior */
    left: 27px; /* Alinear a la izquierda (20px + 7px de radio) */
    transform: none; /* Quitar transformación */
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background-color: #008A8A;
}

.tipo-donacion-card h3 {
    color: #008A8A;
    font-size: 1.1rem; /* Reducir tamaño de fuente */
    text-align: left; /* Asegurar que el título esté centrado */
    margin-bottom: 10px;
}


/* --- Formulario del Donante (para fondo verde) --- */
#bloque-formulario-donante {
    color: #ffffff; /* Color de texto general blanco */
}
#bloque-formulario-donante label, 
#bloque-formulario-donante p {
    color: #ffffff; /* Asegura que etiquetas y párrafos sean blancos */
}
#bloque-formulario-donante input[type="text"],
#bloque-formulario-donante input[type="email"],
#bloque-formulario-donante textarea {
    background-color: #ffffff;
    color: #333333; /* Texto oscuro dentro de los inputs */
    border: 1px solid #ccc;
    border-radius: 4px;
}
#bloque-formulario-donante #resumen-final {
    background-color: rgba(255, 255, 255, 0.1) ; /* Fondo semi-transparente para el resumen */
    border-radius: 8px;
}

/* --- Estilos para Contenido Interno de Tarjetas de Donación --- */

/* Contenedor que envuelve las 2 columnas */
.card-content-wrapper {
    display: grid;
    grid-template-columns: 2fr 1fr;
    align-items: flex-start;
    gap: 20px; /* Espacio entre columnas */
}

/* Columna izquierda para el texto */
.card-columna-izquierda {
    text-align: left;
}

.card-columna-izquierda h3 {
    margin-top: 0;
}

.card-columna-izquierda p {
    font-size: 0.9em;
    margin-bottom: 1em;
}

/* Columna derecha para la imagen */
.card-columna-derecha {
    text-align: center;
}

.card-columna-derecha img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
}

/* Ajustes para el selector de puntos de entrega */
.puntos-entrega-select {
    width: 100%;
    padding: 8px;
    margin-top: 10px;
    border-radius: 4px;
    border: 1px solid #ccc;
}

/* Ajustes para el monto dinámico */
.monto-dinamico {
    margin-top: 15px;
    padding: 10px;
    background-color: #f8f9fa;
    border-radius: 6px;
    border: 1px solid #e9ecef;
}

.monto-dinamico p {
    margin: 0 0 5px 0;
    font-size: 0.9em;
    color: #6c757d;
    font-weight: bold;
}

.monto-dinamico .monto-valor {
    font-size: 1.5em;
    font-weight: bold;
    color: #008A8A;
}

/* Ajuste para que el label principal no interfiera con el flex */
.tipo-donacion-card > label.card-content-wrapper {
    width: 100%;
}

/* --- Estilos para la Sección de Mensajes de Navidad --- */
#seccion-mensajes-navidad {
    margin-top: 20px;
}

#seccion-mensajes-navidad > label {
    font-weight: bold;
    display: block;
    margin-bottom: 15px;
}

#mensajes-beneficiarios-container {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.mensaje-item {
    display: flex;
    flex-direction: column;
}

.mensaje-item label {
    font-size: 0.9em;
    margin-bottom: 5px;
    color: #f0f0f0;
}

.mensaje-item textarea {
    width: 100%;
    min-height: 80px;
    padding: 8px;
    border-radius: 4px;
    border: 1px solid #ccc;
    font-family: 'Montserrat', sans-serif;
    resize: vertical;
}

/* --- Estilos para el Botón Principal --- */
#bloque-formulario-donante .boton-apadrinar {
    display: block;
    width: 100%;
    padding: 1rem;
    margin-top: 2rem;
    background-color: #EB5D04;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
    cursor: pointer;
    transition: background-color 0.2s;
    text-decoration: none; /* En caso de que se use una etiqueta <a> */
}

#bloque-formulario-donante .boton-apadrinar:hover {
    background-color: #d35400; /* Naranja un poco más oscuro para el hover */
}

/* --- Estilos para el Modal de Errores --- */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
}

.modal-content {
    background-color: #fff;
    padding: 30px;
    border-radius: 8px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
    width: 90%;
    max-width: 500px;
    position: relative;
    color: #333;
}

.modal-close {
    position: absolute;
    top: 10px;
    right: 15px;
    font-size: 2rem;
    font-weight: bold;
    color: #aaa;
    background: none;
    border: none;
    cursor: pointer;
    line-height: 1;
}
.modal-close:hover {
    color: #333;
}

.modal-content h3 {
    margin-top: 0;
    color: #EB5D04;
    font-family: 'Montserrat', sans-serif;
}

#lista-errores-modal {
    list-style: none;
    padding: 0;
    margin-top: 15px;
}

#lista-errores-modal li {
    padding: 8px 0;
    border-bottom: 1px solid #eee;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.95em;
}

#lista-errores-modal li:last-child {
    border-bottom: none;
}
