/* ============================================================
   Wiz Kidz Blog · theme stylesheet
   Tokens inlined from the Wiz Kidz Design System.
   Post-body styles are deliberately simple (single column,
   element-level) so copied content survives email clients.
   ============================================================ */

:root {
  /* Brand primaries */
  --peacock-500: #006464; --peacock-700: #004545; --peacock-50: #e3f1f1; --peacock-100: #b9dede;
  --orchid-500: #a30078;  --orchid-700: #720054;  --orchid-50: #f8e4f1;
  /* Mascot secondaries */
  --fawn-500: #ffc832; --jay-500: #0aa4eb; --fox-500: #ff4747; --frog-500: #43a277;
  /* Accessible inks (AA on white) */
  --peacock-ink: #005555; --orchid-ink: #8b0066; --fawn-ink: #85681a;
  --jay-ink: #076e9d; --fox-ink: #b53232; --frog-ink: #307354;
  /* Neutrals */
  --jet: #2d2d2d; --seasalt: #fafafa; --white: #ffffff;
  --gray-50: #f4f5f5; --gray-100: #e8eaea; --gray-200: #d4d7d7;
  --gray-400: #8b9191; --gray-500: #676d6d; --gray-700: #3a3e3e;
  /* Type */
  --font-display: "Outfit", "Segoe UI", sans-serif;
  --font-body: "Nunito", "Segoe UI", sans-serif;
  /* Effects */
  --radius-md: 14px; --radius-lg: 20px; --radius-pill: 999px;
  --shadow-sm: 0 1px 3px rgba(45,45,45,.08), 0 4px 12px rgba(45,45,45,.06);
  --shadow-md: 0 2px 6px rgba(45,45,45,.09), 0 10px 24px rgba(45,45,45,.10);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--seasalt);
  color: var(--gray-700);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
}
img { max-width: 100%; height: auto; }
a { color: var(--peacock-ink); }

.wrap { max-width: 880px; margin: 0 auto; padding: 0 24px; }
.wrap-narrow { max-width: 680px; margin: 0 auto; padding: 0 24px; }

/* ---- Header: teal brand bar ---- */
.site-header { background: var(--peacock-500); }
.site-header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding-top: 14px; padding-bottom: 14px;
}
.site-logo { display: flex; align-items: center; }
.site-logo img { display: block; height: 44px; width: auto; }
.site-nav { display: flex; gap: 6px; }
.site-nav a {
  color: var(--seasalt); text-decoration: none;
  font-family: var(--font-display); font-weight: 600; font-size: 15px;
  padding: 8px 14px; border-radius: var(--radius-pill);
  transition: background .2s ease;
}
.site-nav a:hover { background: rgba(250,250,250,.14); }

/* ---- Home ---- */
.home-hero { padding: 56px 0 8px; }
.home-eyebrow {
  margin: 0 0 8px; font-family: var(--font-display); font-weight: 700;
  font-size: 14px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--orchid-ink);
}
.home-title {
  margin: 0 0 10px; font-family: var(--font-display); font-weight: 900;
  font-size: clamp(36px, 6vw, 56px); line-height: 1.1; color: var(--jet);
}
.home-sub { margin: 0; max-width: 560px; color: var(--gray-500); }

.post-list { display: grid; gap: 20px; padding-top: 40px; padding-bottom: 24px; }
.post-card {
  background: var(--white); border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm); overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}
.post-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.post-card-bar { height: 4px; background: var(--card-accent, var(--peacock-500)); }
.post-card-body { padding: 24px 28px 22px; }
.post-card-title { margin: 10px 0 6px; font-family: var(--font-display); font-weight: 800; font-size: 26px; line-height: 1.2; }
.post-card-title a { color: var(--jet); text-decoration: none; }
.post-card-title a:hover { color: var(--peacock-ink); }
.post-card-excerpt { margin: 0 0 12px; color: var(--gray-500); }

/* ---- Tags & meta ---- */
.tag-row { display: flex; flex-wrap: wrap; gap: 8px; }
.tag-pill {
  display: inline-block; padding: 3px 12px; border-radius: var(--radius-pill);
  background: var(--peacock-50); color: var(--peacock-ink);
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  text-decoration: none;
}
.tag-pill:hover { background: var(--peacock-100); }
.post-meta {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
  color: var(--gray-400); font-size: 14px;
}

/* ---- Post page ---- */
.post { padding: 48px 0 24px; }
.post-header { display: grid; gap: 14px; margin-bottom: 28px; }
.post-title {
  margin: 0; font-family: var(--font-display); font-weight: 900;
  font-size: clamp(32px, 5vw, 44px); line-height: 1.12; color: var(--jet);
}
.copy-email-row { display: flex; align-items: center; gap: 12px; }
.copy-email-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 20px; border: none; border-radius: var(--radius-pill);
  background: var(--orchid-500); color: var(--white);
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  cursor: pointer; transition: transform .12s ease, background .2s ease;
}
.copy-email-btn:hover { background: var(--orchid-700); }
.copy-email-btn:active { transform: scale(.97); }
.copy-email-hint { color: var(--frog-ink); font-size: 14px; font-weight: 700; }

.post-hero { display: block; width: 100%; border-radius: var(--radius-lg); margin: 0 0 24px; }

/* ---- Post body: email-safe typography ---- */
.post-body { font-size: 17px; line-height: 1.65; color: var(--gray-700); }
.post-body p { margin: 0 0 18px; }
.post-body h2 {
  margin: 32px 0 10px; font-family: var(--font-display); font-weight: 800;
  font-size: 26px; line-height: 1.25; color: var(--post-accent-ink, var(--peacock-ink));
}
.post-body h3 {
  margin: 26px 0 8px; font-family: var(--font-display); font-weight: 700;
  font-size: 20px; color: var(--jet);
}
.post-body a { color: var(--peacock-ink); }
.post-body ul, .post-body ol { margin: 0 0 18px; padding-left: 26px; }
.post-body li { margin-bottom: 6px; }
.post-body blockquote {
  margin: 0 0 18px; padding: 14px 20px;
  background: var(--gray-50); border-left: 4px solid var(--post-accent, var(--peacock-500));
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-style: italic; color: var(--gray-500);
}
.post-body blockquote p:last-child { margin-bottom: 0; }
.post-body img { border-radius: var(--radius-md); }
.post-body code {
  font-family: "SFMono-Regular", Consolas, monospace; font-size: 15px;
  background: var(--gray-100); padding: 2px 6px; border-radius: 6px;
}
.post-body pre { background: var(--gray-100); padding: 16px 18px; border-radius: var(--radius-md); overflow-x: auto; }
.post-body pre code { background: none; padding: 0; }
.post-body hr { border: none; border-top: 1px solid var(--gray-200); margin: 28px 0; }

.post-signoff { margin: 26px 0 0; color: var(--gray-500); font-size: 15px; }

/* ---- Newsletter box ---- */
.newsletter-box {
  max-width: 632px; margin: 40px auto 8px; padding: 26px 28px;
  background: var(--peacock-50); border-radius: var(--radius-lg);
}
.wrap-narrow .newsletter-box { margin-left: 0; margin-right: 0; }
.newsletter-title { margin: 0 0 4px; font-family: var(--font-display); font-weight: 800; font-size: 20px; color: var(--jet); }
.newsletter-blurb { margin: 0 0 14px; color: var(--gray-500); font-size: 15px; }
.newsletter-form { display: flex; flex-wrap: wrap; gap: 10px; }
.newsletter-input {
  flex: 1 1 220px; padding: 10px 18px; font-family: var(--font-body); font-size: 15px;
  border: 1px solid var(--gray-200); border-radius: var(--radius-pill); background: var(--white);
}
.newsletter-input:focus { outline: none; border-color: var(--peacock-500); box-shadow: 0 0 0 4px rgba(0,100,100,.22); }
.newsletter-btn {
  padding: 10px 24px; border: none; border-radius: var(--radius-pill);
  background: var(--peacock-500); color: var(--seasalt);
  font-family: var(--font-display); font-weight: 700; font-size: 15px; cursor: pointer;
  transition: background .2s ease, transform .12s ease;
}
.newsletter-btn:hover { background: var(--peacock-700); }
.newsletter-btn:active { transform: scale(.97); }

/* ---- Archive ---- */
.archive { padding: 48px 0 24px; }
.page-title { margin: 0 0 28px; font-family: var(--font-display); font-weight: 900; font-size: 40px; color: var(--jet); }
.archive-group { margin-bottom: 30px; }
.archive-tag { display: flex; align-items: center; gap: 10px; margin: 0 0 10px; font-size: 16px; }
.archive-tag .tag-pill { font-size: 14px; padding: 4px 14px; }
.archive-count { color: var(--gray-400); font-weight: 400; font-size: 14px; }
.archive-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 6px; }
.archive-list li { display: flex; justify-content: space-between; gap: 16px; align-items: baseline; }
.archive-list a { color: var(--gray-700); text-decoration: none; font-weight: 700; }
.archive-list a:hover { color: var(--peacock-ink); }
.archive-list time { color: var(--gray-400); font-size: 14px; white-space: nowrap; }

.empty-state { color: var(--gray-500); background: var(--white); border-radius: var(--radius-md); padding: 24px 28px; box-shadow: var(--shadow-sm); }

/* ---- Footer ---- */
.site-footer { margin-top: 56px; background: var(--jet); color: var(--gray-200); }
.site-footer-inner { padding: 36px 24px; text-align: center; display: grid; gap: 10px; }
.footer-motto { margin: 0; font-family: var(--font-display); font-weight: 800; font-size: 20px; color: var(--seasalt); }
.footer-social { display: flex; justify-content: center; flex-wrap: wrap; gap: 18px; }
.footer-social a { color: var(--gray-200); text-decoration: none; font-size: 14px; font-weight: 700; }
.footer-social a:hover { color: var(--seasalt); }
.footer-copy { margin: 0; color: var(--gray-400); font-size: 13px; }
.footer-copy a { color: var(--gray-400); }

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; }
}
