/* ============================================================
   Utility classes — 跨頁原子化工具
   .grid-{n}       — N 欄等寬 grid,mobile 自動收 1 欄
   .date / .date__ym / .date__d
                   — 月年小字 + 日大字 日期顯示
   .title          — 共用 display 標題樣式
   ============================================================ */

/* ----- Grid utilities ----- */
.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--grid-gap, 24px);
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--grid-gap, 24px);
}

.grid-5 {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: var(--grid-gap, 24px);
}

@media (max-width: 1023px) {
  .grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grid-5 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .grid-2,
  .grid-3,
  .grid-5 {
    grid-template-columns: 1fr;
  }
}

/* ----- Date display ----- */
.date {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  font-family: "Lustria", "Noto Serif TC", serif;
  white-space: nowrap;
  color: var(--svc-ink);
}

.date__ym {
  font-size: var(--date-ym, 11px);
  font-weight: 400;
  letter-spacing: 0.04em;
}

.date__d {
  font-size: var(--date-d, 32px);
  font-weight: 400;
  line-height: 1;
}

@media (max-width: 767px) {
  .date__d {
    font-size: 24px;
  }
}

/* ----- Title (display heading) ----- */
.title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--svc-ink);
}
