:root {
  --color-national: #ff5656; /* Rojo suave */
  --color-provincial: #74b9ff; /* Azul suave */
  --color-local: #55e6c1; /* Verde suave */
  --color-text: #333;
  --color-bg: #f9f9f9;
  --color-border: #ddd;
  --color-today-highlight: #ffd240; /* Amarillo suave para hoy */
}

body {
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  background-color: var(--color-bg);
  color: var(--color-text);
  margin: 0;
  padding: 20px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  min-height: 100vh;
}

.calendar-container {
  background-color: white;
  padding: 20px;
  border-radius: 8px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  width: 100%;
  max-width: 900px;
}

.calendar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}

.calendar-header h2 {
  margin: 0;
  font-size: 1.5em;
  color: var(--color-text);
  text-align: center;
  flex-grow: 1;
}

.calendar-header button {
  background-color: var(--color-provincial);
  color: white;
  border: none;
  padding: 8px 12px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 1em;
  min-width: 40px;
}
.calendar-header button:hover {
  opacity: 0.8;
}

.filter-controls {
  margin-bottom: 20px;
  display: flex;
  gap: 15px;
  align-items: center;
  flex-wrap: wrap;
}

.filter-controls label {
  font-weight: bold;
}

.filter-controls select {
  padding: 8px;
  border-radius: 4px;
  border: 1px solid var(--color-border);
  background-color: white;
  min-width: 150px; /* Para que no se encojan demasiado */
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px; /* Bordes finos entre celdas */
  text-align: center;
  background-color: var(--color-border); /* Color para los gaps */
  border: 1px solid var(--color-border); /* Borde exterior */
}

.calendar-grid div {
  /* Estilo base para todas las celdas, incluyendo nombres de día */
  background-color: white; /* Fondo blanco para celdas */
  padding: 5px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;

  align-items: center;
  font-size: 0.9em;
  box-sizing: border-box;
}

.calendar-grid .day-name {
  font-weight: bold;
  background-color: #f0f0f0;
  min-height: auto;
  padding: 8px 5px;
  border-bottom: 1px solid var(--color-border);
}

.day-cell {
  position: relative; /* Para tooltips si se hacen más avanzados */
}

.day-cell.other-month .day-number-container .day-number {
  color: #aaa;
}
.day-cell.today .day-number-container {
  /* Destacar el día actual con un fondo diferente si no es festivo */
  /* background-color: var(--color-today-highlight); */ /* Opción para resaltar todo el contenedor */
}
.day-cell.today .day-number-container .day-number {
  /* Si es hoy, y no tiene círculo de festivo, darle estilo */
  /* font-weight: bold; */
  /* color: var(--color-text); */ /* Asegurar que el número es visible */
}
.day-cell.today:not(
    :has(
        .holiday-circle-national,
        .holiday-circle-provincial,
        .holiday-circle-local
      )
  )
  .day-number-container {
  background-color: var(--color-today-highlight);
  color: var(--color-text); /* Asegurar contraste */
}

.day-number-container {
  display: flex; /* Para centrar el número dentro del círculo */
  justify-content: center;
  align-items: center;
  width: 2em;
  height: 2em;
  border-radius: 50%;
  margin-bottom: 5px;
  font-weight: bold;
}
.day-number-container .day-number {
  line-height: 1; /* Ajustar si es necesario */
}

/* Círculos de colores para los números de día festivo */
.day-number-container.holiday-circle-nacional {
  background-color: var(--color-national) !important;
  color: white !important;
}

.day-number-container.holiday-circle-provincial {
  background-color: var(--color-provincial);
  color: white;
}
.day-number-container.holiday-circle-local {
  background-color: var(--color-local);
  color: black; /* Texto negro para mejor contraste con verde claro */
}

.holiday-name {
  font-size: 0.75em;
  line-height: 1.1;
  /*  max-height: 2.6em; */ /* Aprox. 2 líneas */
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--color-text);
  padding: 2px;
  width: 100%; /* Para que el text-overflow funcione bien */
}

.day-cell.has-tooltip {
  cursor: help;
}

.legend {
  margin-top: 20px;
  padding-top: 15px;
  border-top: 1px solid var(--color-border);
}
.legend h4 {
  margin: 0 0 10px 0;
  font-size: 1em;
}
.legend .legend-item {
  display: inline-flex; /* Para alinear el color y el texto */
  align-items: center;
  margin-right: 15px;
  font-size: 0.9em;
}
.legend-color {
  display: inline-block;
  width: 15px;
  height: 15px;
  margin-right: 5px;
  border-radius: 50%; /* Círculos en la leyenda también */
  border: 1px solid rgba(0, 0, 0, 0.1);
}
.legend-color.national {
  background-color: var(--color-national);
}
.legend-color.provincial {
  background-color: var(--color-provincial);
}
.legend-color.local {
  background-color: var(--color-local);
}

#generate-embed-code {
  margin-top: 20px;
  padding: 10px 15px;
  background-color: #28a745; /* Verde */
  color: white;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 1em;
}
#generate-embed-code:hover {
  background-color: #218838;
}
#embed-code-output {
  font-family: monospace;
  font-size: 0.9em;
}

/* Responsive */
@media (max-width: 768px) {
  .calendar-grid div {
    min-height: 0px; /* Reducir un poco */
    font-size: 0.8em;
    padding: 3px;
  }
  .day-number-container {
    width: 1.8em;
    height: 1.8em;
  }
  .holiday-name {
    font-size: 0.7em;
  }
  .filter-controls {
    flex-direction: column;
    align-items: stretch;
  }
  .filter-controls select,
  .filter-controls label {
    width: 100%;
    margin-bottom: 5px;
    box-sizing: border-box;
  }
}
@media (max-width: 480px) {
  body {
    padding: 10px;
  }
  .calendar-container {
    padding: 15px;
  }
  .calendar-header h2 {
    font-size: 1.3em;
  }
  .calendar-header button {
    padding: 6px 10px;
    font-size: 0.9em;
  }
  .calendar-grid div {
    min-height: 0px;
  }
  .legend .legend-item {
    font-size: 0.8em;
    margin-right: 10px;
  }
}

/* Al final de style.css */

.calendar-app-wrapper {
  /* Puedes añadir estilos específicos para cuando el calendario está embebido */
  /* Por ejemplo, un borde si no lo tiene la página contenedora */
  /* border: 1px solid #e0e0e0; */
  /* border-radius: 8px; */
  /* box-shadow: 0 2px 8px rgba(0,0,0,0.05); */
  /* padding: 10px; */ /* Si el contenedor principal no da padding */
  background-color: white; /* Asegurar fondo blanco si la página contenedora es oscura */
}
