/* ============================================================
   Month view — the calendar grid is the hero.
   ============================================================ */

.cal-page {
  padding-block: var(--sp-6) var(--sp-5);
}

/* ---------- Toolbar ---------- */
/* Title block on top, controls row always below it (left-aligned). */
.cal-toolbar {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
}

.cal-title {
  font-size: var(--text-display);
  letter-spacing: -0.01em;
}
.cal-title .cal-year {
  font-weight: 400;
  font-style: italic;
  color: var(--accent);
  margin-left: 0.12em;
}
.cal-subtitle {
  margin: var(--sp-1) 0 0;
  font-size: var(--text-sm);
  color: var(--ink-faint);
}

.cal-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3);
}

.cal-nav {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.cal-picker {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

/* Action button groups */
.cal-actions {
  display: contents; /* children slot into parent flex naturally on desktop */
}

.cal-actions-top,
.cal-actions-bottom {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

/* ---------- Mobile toolbar ---------- */
@media (max-width: 768px) {
  .cal-controls {
    flex-direction: column;
    align-items: stretch;
    gap: var(--sp-2);
  }

  .cal-nav {
    width: 100%;
    justify-content: space-between;
  }
  .cal-nav a:first-child { order: 0; }
  .cal-nav a:last-child  { order: 2; }
  .cal-nav a:nth-child(2) { order: 1; flex: 1; justify-content: center; }

  .cal-picker {
    width: 100%;
  }
  .cal-picker select.field {
    flex: 1;
  }

  .cal-actions {
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
  }

  .cal-actions-top {
    width: 100%;
    justify-content: space-between;
  }

  .cal-actions-bottom {
    width: 100%;
    gap: var(--sp-2);
  }
  .cal-actions-bottom .cal-btn-dl,
  .cal-actions-bottom .cal-btn-print {
    flex: 1;
    justify-content: center;
  }
}

/* ---------- Grid shell ---------- */
.cal-grid {
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  box-shadow: var(--shadow-2);
  overflow: hidden;
  animation: cal-enter var(--t-med) var(--ease) both;
}

@keyframes cal-enter {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: none; }
}

/* ---------- Day-of-week header ---------- */
.cal-dow {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--line);
  background: var(--paper-raised);
}
.cal-dow > div {
  padding: var(--sp-3) var(--sp-3);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-faint);
  text-align: right;
}

/* ---------- Weeks & days ---------- */
.cal-week {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
.cal-week + .cal-week .cal-day { border-top: 1px solid var(--line-soft); }
.cal-day + .cal-day { border-left: 1px solid var(--line-soft); }

.cal-day {
  position: relative;
  min-height: clamp(58px, 10.5vw, 124px);
  padding: var(--sp-2) var(--sp-3);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  transition: background var(--t-fast) var(--ease);
  cursor: pointer;
}
.cal-day:hover { background: var(--paper-sunken); }
.cal-day:focus-visible { outline-offset: -2px; }

.cal-day .num {
  font-size: var(--text-md);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
  line-height: 1;
  padding: 0.3em 0;
  color: var(--ink);
}

/* Weekend: gentle tonal shift */
.cal-day.is-weekend { background: var(--c-weekend); }
.cal-day.is-weekend:hover { background: var(--paper-sunken); }
.cal-day.is-weekend .num { color: var(--ink-soft); }

/* Days outside the current month */
.cal-day.is-outside .num {
  color: var(--ink-faint);
  opacity: 0.55;
  font-weight: 400;
}

/* Today: terracotta badge around the number */
.cal-day.is-today .num {
  background: var(--c-today);
  color: #fff;
  font-weight: 600;
  width: 1.9em;
  height: 1.9em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  padding: 0;
  box-shadow: 0 1px 4px rgba(154, 65, 29, 0.35);
}

/* Holidays: rendered server-side, revealed by the "Add holidays" toggle */
.cal-day .holiday-label {
  display: none;
  font-size: var(--text-xs);
  color: var(--c-holiday);
  font-weight: 500;
  margin-top: auto;
  align-self: flex-start;
  line-height: 1.25;
}
.show-holidays .cal-day.has-holiday { background: var(--c-holiday-wash); }
.show-holidays .cal-day.has-holiday:hover { background: var(--paper-sunken); }
.show-holidays .cal-day .holiday-label { display: block; }

/* Notes */
.cal-day .note {
  font-size: var(--text-xs);
  color: var(--c-note);
  background: var(--c-note-wash);
  border-radius: var(--r-1);
  padding: 2px 6px;
  margin-top: var(--sp-1);
  align-self: stretch;
  overflow-wrap: break-word;
  white-space: pre-line;
}
.cal-day .note-input {
  align-self: stretch;
  margin-top: var(--sp-1);
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  color: var(--ink);
  background: var(--paper-raised);
  border: 1px solid var(--accent);
  border-radius: var(--r-1);
  padding: 2px 6px;
  resize: none;
  min-width: 0;
}
.cal-day .note-input:focus { outline: none; }

.cal-hint {
  margin-top: var(--sp-3);
  font-size: var(--text-xs);
  color: var(--ink-faint);
  text-align: center;
}

/* ---------- Countdown pages ---------- */
.countdown-hero {
  text-align: center;
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  box-shadow: var(--shadow-2);
  padding: var(--sp-7) var(--sp-4);
}
.countdown-num {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(5rem, 18vw, 11rem);
  line-height: 1;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
}
.countdown-label {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xl);
  color: var(--ink-soft);
  margin-top: var(--sp-2);
}
.countdown-clock {
  margin-top: var(--sp-4);
  font-size: var(--text-md);
  color: var(--ink-faint);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.04em;
}
.countdown-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
}

/* ---------- Holidays page ---------- */
.holiday-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  box-shadow: var(--shadow-2);
  overflow: hidden;
}
.holiday-table th {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-faint);
  text-align: left;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--line);
}
.holiday-table td {
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--line-soft);
  font-size: var(--text-md);
}
.holiday-table tr:last-child td { border-bottom: none; }
.holiday-table tbody tr { transition: background var(--t-fast) var(--ease); }
.holiday-table tbody tr:hover { background: var(--paper-sunken); }

.ht-right { text-align: right; }
.ht-date { white-space: nowrap; }
.ht-day {
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  margin-right: var(--sp-2);
}
.ht-dow { color: var(--ink-faint); font-size: var(--text-sm); }
.ht-until { font-variant-numeric: tabular-nums; color: var(--ink-soft); }

.holiday-table .is-past td { color: var(--ink-faint); }
.holiday-table .is-past a { color: var(--ink-faint); }
.holiday-table .is-next td { background: var(--accent-wash); }
.holiday-table .is-next .ht-until { color: var(--accent-deep); font-weight: 600; }

.ht-badge {
  background: var(--accent);
  color: #fff;
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: var(--r-pill);
  padding: 2px 10px;
}

@media (max-width: 640px) {
  .holiday-table th, .holiday-table td { padding: var(--sp-2) var(--sp-3); }
  .ht-dow { display: none; }
}

/* ---------- Excel templates hub ---------- */
.excel-h {
  font-size: var(--text-lg);
  margin: var(--sp-5) 0 var(--sp-3);
}
.excel-years {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.excel-year-btn { font-weight: 600; }
.excel-months {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: var(--sp-2);
}
.excel-months .btn { justify-content: center; }

/* ---------- About / SEO copy under the grid ---------- */
.cal-about {
  margin-top: var(--sp-7);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--line-soft);
}
.cal-about h2 {
  font-size: var(--text-xl);
  margin-bottom: var(--sp-3);
}
.cal-about > p {
  max-width: 62ch;
  color: var(--ink-soft);
  margin: 0 0 var(--sp-5);
}
.cal-about strong { color: var(--ink); font-weight: 600; }

.about-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-5);
}
.about-grid h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--sp-2);
}
.about-grid p {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--ink-soft);
  line-height: 1.6;
}

.cal-related {
  margin: var(--sp-5) 0 0;
  font-size: var(--text-sm);
  color: var(--ink-faint);
}

/* ---------- Responsive ---------- */
@media (max-width: 640px) {
  .cal-page { padding-block: var(--sp-4); }
  .cal-toolbar { align-items: stretch; }
  .cal-controls { justify-content: space-between; width: 100%; }
  .cal-dow > div {
    padding: var(--sp-2);
    text-align: center;
    letter-spacing: 0.04em;
  }
  .cal-day {
    min-height: 52px;
    padding: var(--sp-1) var(--sp-2);
    align-items: center;
  }
  .cal-day .num { font-size: var(--text-sm); }
}
