/* ==========================
   CALENDARIO MISIONERO
   ========================== */

.calendar-card {
  background: var(--brand-blanco_cruz_interior);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  padding: 1.25rem 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Header */
.calendar-header {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

.calendar-title h1 {
  margin: 0;
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: .3px;
  color: var(--brand-azul);
}

.calendar-title p {
  margin: .2rem 0 0;
  font-size: .9rem;
  color: var(--brand-gris-70);
}

.calendar-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
}

.calendar-current {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-weight: 700;
  font-size: .95rem;
}

.calendar-current #calMonth {
  text-transform: capitalize;
}

.calendar-current #calYear {
  font-size: .8rem;
  color: var(--brand-gris-70);
}

.cal-nav {
  padding-inline: .9rem;
  min-width: 0;
}

/* Cuerpo */
.calendar-body {
  background: var(--brand-blanco_cruz_interior);
  border-radius: 14px;
  border: 1px solid var(--brand-gris-10);
  padding: .75rem;
}

.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: .25rem;
  margin-bottom: .35rem;
  font-size: .75rem;
  text-align: center;
  font-weight: 700;
  color: var(--brand-gris-70);
}

.calendar-weekdays span {
  padding: .25rem 0;
  border-radius: 999px;
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: .25rem;
}

/* Día */
.calendar-day {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 12px;
  border: 1px solid transparent;
  background: #f7f7f7;
  font-size: .8rem;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  padding: .25rem .3rem;
  cursor: pointer;
  transition:
    background .12s ease,
    transform .07s ease,
    box-shadow .12s ease,
    border-color .12s ease;
}

.calendar-day span {
  z-index: 1;
}

.calendar-day.empty {
  background: transparent;
  cursor: default;
}

.calendar-day.has-event {
  background: var(--brand-amarillo-tint-40);
  border-color: var(--brand-amarillo-shade-20);
}

.calendar-day.today {
  border-color: var(--brand-azul);
  box-shadow: 0 0 0 1px var(--brand-azul-tint-40);
}

.calendar-day.selected {
  background: var(--brand-azul);
  color: white;
  border-color: var(--brand-azul-shade-40);
}

.calendar-day:not(.empty):active {
  transform: translateY(1px) scale(.98);
}

/* Punto indicador en esquina inferior */
.calendar-day::after {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 50%;
  transform: translateX(-50%);
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: transparent;
}

.calendar-day.has-event::after {
  background: var(--brand-rojo);
}

/* Footer */
.calendar-footer {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  font-size: .8rem;
}

.calendar-legend {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem;
  color: var(--brand-gris-70);
}

.calendar-legend .dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  display: inline-block;
  margin-right: .25rem;
}

.dot-today {
  background: var(--brand-azul);
}

.dot-event {
  background: var(--brand-rojo);
}

.calendar-info {
  padding: .5rem .75rem;
  border-radius: 10px;
  background: var(--brand-gris-10);
  color: var(--brand-gris-70);
}

/* Mobile friendly */
@media (min-width: 640px) {
  .calendar-card {
    padding: 1.5rem 1.25rem 1.75rem;
  }

  .calendar-header {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }

  .calendar-title h1 {
    font-size: 1.5rem;
  }
}
