/* ============================================
   EMPYREAN — CALENDARIO
   ============================================ */

/* ─── Grid ──────────────────────────────────── */
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  margin-top: 15px;
}

/* ─── Día ───────────────────────────────────── */
.day {
  aspect-ratio: 1/1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  cursor: pointer;
  font-size: 0.95rem;
  background: white;
  border: 1px solid #fbf4fb;
  color: var(--text);
  font-weight: 600;
  transition: all 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  position: relative;
}
.day:not(.disabled):not(.full):not(.blocked-day):not(.selected):hover {
  border-color: var(--primary);
  background: #fdf2ff;
  transform: scale(1.08);
  z-index: 2;
  box-shadow: 0 8px 22px rgba(96, 32, 96, 0.2);
}
.day.today {
  border: 2px solid var(--primary);
  color: var(--primary);
  background: #fffbff;
  font-weight: 800;
}
.day.selected {
  background: linear-gradient(135deg, var(--primary), #8a2b8a) !important;
  color: white !important;
  border-color: var(--primary);
  transform: scale(1.08) translateY(-3px);
  box-shadow:
    0 12px 30px rgba(96, 32, 96, 0.5),
    0 0 0 3px rgba(96, 32, 96, 0.15) !important;
  z-index: 3;
}
.day.full {
  background: #f5f5f5;
  color: #b2bec3;
  text-decoration: line-through;
  pointer-events: auto;
}
.day.blocked-day {
  background: #f5f5f5;
  color: #b2bec3;
  text-decoration: line-through;
  pointer-events: auto;
}
.day.disabled { background: #f1f2f6; color: #c8ccd4; opacity: 0.55; pointer-events: none; border-color: #eaecf0; text-decoration: line-through; }
.cal-grid.cal-updating .day:not(.disabled) { opacity: 0.35; pointer-events: none; cursor: wait; }

/* ─── Day chip (selector de días) ───────────── */
.day-chip {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: white;
  border: 1px solid #fbf4fb;
  color: #b2bec3;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 0.85rem;
}
.day-chip.active {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
  transform: translateY(-3px);
  box-shadow: 0 5px 15px rgba(96, 32, 96, 0.2);
}

/* ─── Selectores de semana / fechas ─────────── */
.week-selector {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-bottom: 15px;
  flex-wrap: wrap;
}
.specific-dates-row {
  display: none;
  gap: 6px;
  margin-bottom: 18px;
  flex-wrap: nowrap;
  overflow-x: auto;
  background: #faf6ff;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1.5px solid #ede0ff;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.specific-dates-row::-webkit-scrollbar { display: none; }
