:root {
  --bg: #ffffff;
  --fg: #0a0a0a;
  --muted: #6b6b6b;
  --subtle: #f5f5f5;
  --border: #ebebeb;
  --accent: #0070f3;
  --hero-grad-from: rgba(0, 112, 243, 0.06);
  --hero-grad-via: rgba(0, 112, 243, 0.02);
  --hero-grad-to: rgba(0, 112, 243, 0);
  color-scheme: light;
}
@media (prefers-color-scheme: dark) {
  :root {
    --bg: #0a0a0a;
    --fg: #fafafa;
    --muted: #a1a1a1;
    --subtle: #161616;
    --border: #1f1f1f;
    --accent: #3291ff;
    --hero-grad-from: rgba(50, 145, 255, 0.10);
    --hero-grad-via: rgba(50, 145, 255, 0.04);
    --hero-grad-to: rgba(50, 145, 255, 0);
    color-scheme: dark;
  }
}

* { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body { background: var(--bg); color: var(--fg); margin: 0;
       font-family: "Geist", system-ui, -apple-system, "Segoe UI", sans-serif;
       line-height: 1.55; }
a { color: inherit; text-decoration: none; }
.nums { font-variant-numeric: tabular-nums; }
.mono { font-family: "Geist Mono", ui-monospace, monospace; }

main.container {
  max-width: 768px; margin: 0 auto; padding: 0.75rem 1.25rem 6rem;
}
@media (min-width: 640px) { main.container { padding: 1rem 2rem 6rem; max-width: 768px; } }
@media (min-width: 1024px) { main.container { max-width: 896px; } }

.eyebrow { font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.18em; color: var(--muted); margin-bottom: 0.5rem; }
.page-header { display: flex; flex-direction: column; gap: 0.25rem; margin-bottom: 0.625rem; }
@media (min-width: 640px) { .page-header { gap: 0.25rem; margin-bottom: 0.75rem; } }
.page-header .eyebrow { margin-bottom: 0; }
.page-title { font-size: 1.25rem; font-weight: 600; letter-spacing: -0.04em; line-height: 1; }
@media (min-width: 640px) { .page-title { font-size: 1.75rem; } }
@media (min-width: 1024px) { .page-title { font-size: 2rem; } }
.title-row { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 1rem; }
@media (min-width: 640px) { .title-row { gap: 1.5rem; } }

.cal-block { display: flex; align-items: baseline; gap: 0.5rem; border-left: 1px solid var(--border); padding-left: 0.75rem; }
@media (min-width: 640px) { .cal-block { flex-direction: row; align-items: baseline; gap: 0.5rem; padding-left: 1rem; text-align: right; } }
.cal-wday { font-size: 10px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.18em; color: var(--muted); }
@media (min-width: 640px) { .cal-wday { font-size: 11px; } }
.cal-day { font-size: 1.25rem; font-weight: 500; line-height: 1; letter-spacing: -0.04em; font-variant-numeric: tabular-nums; }
@media (min-width: 640px) { .cal-day { font-size: 1.75rem; } }
.cal-month { font-size: 10px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.18em; color: var(--muted); }
@media (min-width: 640px) { .cal-month { font-size: 11px; } }

/* The legacy "Wednesday, May 13, 2026" paragraph beneath the title row
   duplicated information the eyebrow + calendar block already convey, so
   it's hidden by default; the <time> remains in the DOM for accessibility
   tools that prefer a single, readable date string. */
.date-label { display: none; }

.day-nav {
  display: flex; justify-content: space-between; align-items: center;
  gap: 0.5rem; padding: 0.25rem 0;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  margin-bottom: 1rem;
}
@media (min-width: 640px) { .day-nav { gap: 0.75rem; padding: 0.375rem 0; } }
.day-nav button, .day-nav .today-indicator {
  display: inline-flex; align-items: center; gap: 0.375rem;
  padding: 0.3rem 0.5rem; border: 0; background: transparent;
  font: inherit; font-size: 0.8125rem; font-weight: 500; color: var(--fg);
  border-radius: 0.375rem; cursor: pointer;
  transition: background-color 0.15s ease-out;
}
@media (min-width: 640px) { .day-nav button { padding: 0.3rem 0.75rem; } }
.day-nav button:hover:not(:disabled) { background: var(--subtle); }
.day-nav button:disabled { opacity: 0.5; cursor: not-allowed; }
.day-nav .today-button { border: 1px solid var(--border); }
.day-nav .today-indicator { color: var(--muted); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.18em; padding: 0 0.5rem; }

.section-divider {
  display: flex; align-items: center; gap: 0.75rem;
  margin: 0;
  font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--muted);
}
.section-divider::after { content: ""; flex: 1; height: 1px; background: var(--border); }

.day-content { display: flex; flex-direction: column; gap: 1.5rem; transition: opacity 0.3s; }
@media (min-width: 640px) { .day-content { gap: 2rem; } }
.day-content.pending { opacity: 0.6; }

.primary-section { display: flex; flex-direction: column; gap: 0.625rem; }

.hero-block {
  display: flex; flex-direction: column; gap: 0.75rem;
  border: 1px solid var(--border); border-radius: 0.75rem;
  padding: 1rem 1.25rem; background: color-mix(in srgb, var(--subtle) 40%, transparent);
  position: relative; isolation: isolate; overflow: hidden;
  transition: border-color 0.2s, background 0.2s;
}
@media (min-width: 640px) { .hero-block { padding: 1.25rem 1.5rem; gap: 0.875rem; } }
.hero-block::before {
  content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background: radial-gradient(120% 120% at 0% 0%, var(--hero-grad-from) 0%, var(--hero-grad-via) 35%, var(--hero-grad-to) 70%);
}
a.hero-block:hover { border-color: color-mix(in srgb, var(--fg) 30%, transparent); background: var(--subtle); }

.hero-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; }
.primary-name { font-size: 1.875rem; font-weight: 600; letter-spacing: -0.025em; line-height: 1.1; text-wrap: balance; }
@media (min-width: 640px) { .primary-name { font-size: 2.25rem; } }
@media (min-width: 1024px) { .primary-name { font-size: 2.75rem; } }
.note { font-size: 1rem; color: var(--muted); line-height: 1.6; text-wrap: pretty; }
.titles-line { font-size: 0.875rem; font-weight: 500; color: color-mix(in srgb, var(--fg) 80%, transparent); }
.primary-summary { font-size: 1rem; color: color-mix(in srgb, var(--fg) 85%, transparent); line-height: 1.6; text-wrap: pretty; }
@media (min-width: 640px) { .primary-summary { font-size: 1.05rem; } }
.short-desc { font-size: 1rem; color: var(--muted); line-height: 1.6; text-wrap: pretty; }
.meta-line { font-size: 0.875rem; color: var(--muted); line-height: 1.6; font-variant-numeric: tabular-nums; }
.status-line { font-size: 11px; font-weight: 500; text-transform: uppercase; color: var(--muted); letter-spacing: -0.01em; }

.rank-badge {
  display: inline-flex; align-items: center; padding: 0.125rem 0.625rem;
  border-radius: 9999px; font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: -0.01em;
}
.rank-badge[data-rank="solemnity"] { background: var(--fg); color: var(--bg); }
.rank-badge[data-rank="feast"] { background: color-mix(in srgb, var(--fg) 10%, transparent); color: var(--fg); }
.rank-badge[data-rank="memorial"] { background: var(--subtle); color: var(--fg); }
.rank-badge[data-rank="optional"] { background: transparent; color: var(--muted); border: 1px solid var(--border); }

.additional-section { display: flex; flex-direction: column; gap: 1.25rem; }
.additional-header { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; }
.additional-count { font-size: 0.75rem; color: var(--muted); font-variant-numeric: tabular-nums; }

.extra-celebrations { display: grid; gap: 0.75rem; }
@media (min-width: 640px) { .extra-celebrations { grid-template-columns: 1fr 1fr; } }
.extra-celebration {
  display: flex; flex-direction: column; gap: 0.5rem;
  border: 1px solid var(--border); border-radius: 0.5rem;
  padding: 1rem; background: var(--bg);
}
@media (min-width: 640px) { .extra-celebration { padding: 1.25rem; } }
.extra-celebration h4 { margin: 0; font-size: 1rem; font-weight: 500; letter-spacing: -0.025em; text-wrap: balance; }

.additional-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.75rem; }
@media (min-width: 640px) { .additional-list { grid-template-columns: 1fr 1fr; } }
.saint-card {
  display: block; border: 1px solid var(--border); border-radius: 0.5rem;
  padding: 1rem; background: var(--bg);
  transition: border-color 0.2s ease-out, background-color 0.2s ease-out, transform 0.2s ease-out;
}
@media (min-width: 640px) { .saint-card { padding: 1.25rem; } }
a.saint-card:hover { border-color: color-mix(in srgb, var(--fg) 30%, transparent); background: var(--subtle); transform: translateY(-1px); }
.saint-card h3 { margin: 0; font-size: 1rem; font-weight: 500; letter-spacing: -0.025em; line-height: 1.3; text-wrap: balance; }
.saint-card .row { display: flex; align-items: baseline; justify-content: space-between; gap: 0.75rem; }
.saint-card .titles { font-size: 0.75rem; font-weight: 500; margin-top: 0.25rem; color: color-mix(in srgb, var(--fg) 80%, transparent); }
.saint-card .short { font-size: 0.875rem; color: var(--muted); line-height: 1.6; margin-top: 0.5rem; text-wrap: pretty; }
.saint-card .meta { font-size: 0.75rem; color: var(--muted); margin-top: 0.75rem; font-variant-numeric: tabular-nums; line-height: 1.6; }
.saint-card .arrow {
  display: inline-block; color: var(--muted); font-size: 0.875rem;
  opacity: 0; transform: translateX(-4px);
  transition: opacity 0.2s, transform 0.2s;
}
a.saint-card:hover .arrow { opacity: 1; transform: translateX(0); }

.nav-error {
  border: 1px solid var(--border); background: var(--subtle);
  padding: 0.75rem; border-radius: 0.375rem; color: var(--fg); font-size: 0.875rem;
}

.site-footer {
  border-top: 1px solid var(--border); margin-top: 4rem;
  padding: 1.5rem 2rem;
  max-width: 768px; margin-left: auto; margin-right: auto;
  display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
  gap: 0.5rem; font-size: 0.75rem; color: var(--muted); line-height: 1.7;
}
@media (min-width: 1024px) { .site-footer { max-width: 896px; } }
.site-footer .sep { color: color-mix(in srgb, var(--muted) 60%, transparent); padding: 0 0.5rem; }
.site-footer a { text-decoration: none; }
.site-footer a:hover { text-decoration: underline; text-underline-offset: 2px; }
.site-footer .visits { color: var(--accent); font-weight: 600; font-variant-numeric: tabular-nums; }

.fire-btn {
  background: linear-gradient(180deg, #2a1410, #1a0a07);
  border: 1px solid #5a2412;
  color: #ffb38a; font: inherit; cursor: pointer;
  padding: 2px 10px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; line-height: 1;
  transition: transform 0.12s, box-shadow 0.2s;
}
.fire-btn:hover { transform: translateY(-1px); box-shadow: 0 0 18px #e6572233; }
.fire-btn:active { transform: scale(0.96); }
.fire-btn .flame { font-size: 13px; }
.fire-btn .fire-count { color: #e67e22; font-weight: 700; font-variant-numeric: tabular-nums; min-width: 1.5ch; }

.fire-fly {
  position: fixed; pointer-events: none; font-size: 1.6rem; z-index: 9999;
  animation: flyUp 1.3s ease-out forwards; will-change: transform, opacity;
}
@keyframes flyUp {
  0%   { opacity: 1; transform: translate(0, 0) scale(1) rotate(0deg); }
  40%  { opacity: 1; transform: translate(var(--dx), -60px) scale(1.4) rotate(var(--rot)); }
  100% { opacity: 0; transform: translate(calc(var(--dx) * 1.6), -200px) scale(2) rotate(var(--rot)); }
}

.anim-day-forward { animation: slide-from-right 420ms cubic-bezier(0.22, 1, 0.36, 1) both; }
.anim-day-back    { animation: slide-from-left  420ms cubic-bezier(0.22, 1, 0.36, 1) both; }
.anim-enter       { animation: fade-up 480ms cubic-bezier(0.22, 1, 0.36, 1) both; }
@keyframes slide-from-right { from { opacity: 0; transform: translate3d(28px, 0, 0); } to { opacity: 1; transform: translate3d(0, 0, 0); } }
@keyframes slide-from-left  { from { opacity: 0; transform: translate3d(-28px, 0, 0); } to { opacity: 1; transform: translate3d(0, 0, 0); } }
@keyframes fade-up          { from { opacity: 0; transform: translate3d(0, 8px, 0); } to { opacity: 1; transform: translate3d(0, 0, 0); } }
@media (prefers-reduced-motion: reduce) {
  .anim-day-forward, .anim-day-back, .anim-enter { animation: none; }
  *, *::before, *::after { transition-duration: 0ms !important; }
}
