/* Import theme files */
@import url('themes/dark.css');
@import url('themes/seasonal-chinese-new-year.css');
@import url('themes/seasonal-valentines.css');
@import url('themes/seasonal-easter.css');
@import url('themes/seasonal-matariki.css');
@import url('themes/seasonal-mid-autumn.css');
@import url('themes/seasonal-black-friday.css');
@import url('themes/seasonal-christmas.css');

/* ─── Reset & base ────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--font-body);
  font-size: var(--font-size-md);
  line-height: var(--line-height-body);
  color: var(--colour-text);
  background-color: var(--colour-bg);
  transition: background-color var(--transition-med), color var(--transition-med);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main { flex: 1; }

img, video { max-width: 100%; height: auto; }

a {
  color: var(--colour-primary);
  text-decoration: none;
}
a:hover { text-decoration: underline; }
a:focus-visible {
  outline: 2px solid var(--colour-primary);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ─── Typography ──────────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  line-height: var(--line-height-heading);
  color: var(--colour-text);
  font-weight: 700;
}
h1 { font-size: var(--font-size-3xl); }
h2 { font-size: var(--font-size-2xl); }
h3 { font-size: var(--font-size-xl); }
h4 { font-size: var(--font-size-lg); }

p + p { margin-top: var(--space-md); }

/* ─── Utilities ───────────────────────────────────────────────────────────── */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); border: 0;
}
.text-centre { text-align: center; }
.mt-sm  { margin-top: var(--space-sm); }
.mt-md  { margin-top: var(--space-md); }
.mt-lg  { margin-top: var(--space-lg); }
.mt-xl  { margin-top: var(--space-xl); }

/* ─── Skip link ───────────────────────────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -100px;
  left: var(--space-md);
  background: var(--colour-primary);
  color: white;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md);
  z-index: 9999;
  transition: top var(--transition-fast);
}
.skip-link:focus { top: var(--space-md); }

/* ─── Prose (rich text) ───────────────────────────────────────────────────── */
.prose h2, .prose h3, .prose h4 { margin-top: var(--space-xl); margin-bottom: var(--space-sm); }
.prose p, .prose ul, .prose ol { margin-bottom: var(--space-md); }
.prose ul, .prose ol { padding-left: var(--space-xl); }
.prose li { margin-bottom: var(--space-xs); }
.prose blockquote {
  border-left: 4px solid var(--colour-primary);
  padding-left: var(--space-md);
  color: var(--colour-text-muted);
  font-style: italic;
  margin: var(--space-lg) 0;
}
.prose code {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  background: var(--colour-surface-alt);
  padding: 0.1em 0.4em;
  border-radius: var(--radius-sm);
}
.prose pre {
  background: var(--colour-surface-alt);
  padding: var(--space-md);
  border-radius: var(--radius-md);
  overflow-x: auto;
}
.prose pre code { background: none; padding: 0; }
