/* Estilos Globales */
body {
    font-family: 'Arial', sans-serif;
    margin: 0;
    padding: 0;
    background-color: #f4f7f6;
    color: #333;
}

h1 {
    text-align: center;
    color: #007bff; /* Azul primario */
    padding: 20px 0;
}

/* Contenedor Principal: Uso de CSS Grid para el layout anual */
.calendario-anual {
    display: grid;
    /* Por defecto, 1 columna para móviles (diseño responsivo) */
    grid-template-columns: 1fr; 
    gap: 30px; /* Espacio entre meses */
    padding: 20px;
    max-width: 1200px;
    margin: 0 auto;
}

/* Estilo para cada Mes (section) */
.mes {
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    padding: 15px;
}

.mes h2 {
    color: #28a745; /* Verde para el encabezado del mes */
    border-bottom: 2px solid #28a745;
    padding-bottom: 10px;
    margin-top: 0;
}

/* Lista de Eventos */
.lista-eventos {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Cada Evento (li) con Flexbox para ordenar elementos */
.evento {
    display: flex;
    justify-content: space-between; /* Espacio uniforme entre los elementos */
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px dotted #eee;
    font-size: 0.95em;
}

.evento:last-child {
    border-bottom: none;
}

.evento .fecha {
    font-weight: bold;
    color: #dc3545; /* Rojo para la fecha */
    flex-basis: 15%; /* Toma un 15% del espacio */
    min-width: 70px;
}

.evento .curso {
    flex-grow: 1; /* Ocupa el espacio restante */
    padding: 0 10px;
}

.evento .horario {
    font-style: italic;
    color: #6c757d;
    flex-basis: 25%; /* Toma un 25% del espacio */
    text-align: right;
    min-width: 120px;
}

/* Estilo para eventos destacados (clase 'destacado') */
.evento.destacado {
    background-color: #ffc1071a; /* Fondo amarillo muy suave */
    border-left: 5px solid #ffc107; /* Barra lateral amarilla */
    padding-left: 10px;
    margin: 5px 0;
    border-radius: 4px;
}

/* Media Query: Diseño Adaptable (Responsivo) para Tabletas y Escritorio */
@media (min-width: 768px) {
    .calendario-anual {
        /* En pantallas más grandes, 2 columnas de igual tamaño */
        grid-template-columns: repeat(2, 1fr); 
    }
}

@media (min-width: 1024px) {
    .calendario-anual {
        /* En pantallas grandes, 3 columnas */
        grid-template-columns: repeat(3, 1fr); 
    }
}
/* 1. Ajuste del Contenedor del Evento (Importante) */
.evento {
    /* Cambiamos a 'block' o 'column' para que los detalles quepan debajo */
    display: flex;
    flex-wrap: wrap; /* Permite que los elementos pasen a la siguiente línea */
    flex-direction: column; /* Apila Fecha, Curso, Horario y luego el Temario */
    align-items: flex-start; /* Alinea los elementos a la izquierda */
    padding: 15px 0;
}

/* Reajustamos los spans para que vuelvan a la estructura horizontal */
.evento > span {
    display: inline-block;
    /* Usamos un ancho fijo para que no se desordenen */
    margin-right: 10px;
}

.evento .curso {
    /* Aseguramos que el curso se vea bien */
    width: 100%; /* Ocupa todo el ancho disponible */
    padding: 5px 0;
    font-size: 1.1em;
}

/* 2. Estilos para el Temario Desplegable (<details>) */
.temario-curso {
    width: 98%; /* Ocupa casi todo el ancho, un poco de margen para estética */
    margin-top: 10px;
    padding: 10px;
    background-color: #f9f9f9;
    border: 1px solid #eee;
    border-radius: 4px;
}

/* 3. Estilos para el Título Desplegable (<summary>) */
.temario-curso summary {
    font-weight: bold;
    color: #007bff; /* Color azul para el clic */
    cursor: pointer;
    list-style: none; /* Elimina la flecha predeterminada del navegador */
    padding-left: 20px; /* Espacio para el icono personalizado */
    position: relative;
}

/* Icono personalizado (CSS puro, simula la flecha) */
.temario-curso summary::before {
    content: "▶"; /* Triángulo para indicar cerrado */
    position: absolute;
    left: 0;
    transition: transform 0.2s;
}

/* Rotar el icono cuando está abierto */
.temario-curso[open] summary::before {
    content: "▼"; /* Flecha hacia abajo para indicar abierto */
}


/* 4. Estilos para la Lista de Módulos (ul/li) */
.temario-curso ul {
    list-style-type: disc; /* Puntos de lista */
    margin: 10px 0 10px 20px;
    padding: 0;
    font-size: 0.9em;
    line-height: 1.6;
}

/* 5. Estilo para el Botón de Registro dentro del Temario */
.boton-registro {
    display: inline-block;
    margin-top: 10px;
    padding: 8px 15px;
    background-color: #28a745; /* Verde */
    color: white;
    text-decoration: none;
    border-radius: 5px;
    font-weight: bold;
    transition: background-color 0.3s;
}

.boton-registro:hover {
    background-color: #218838;
}