*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;line-height:1.7;color:#111;background:#fff}
.astro-hZfe2v2B{max-width:900px;margin:0 auto;padding:0 28px}
.astro-NOFTVG0m{background:#111;color:#fff;padding:64px 0;margin-bottom:48px}
.astro-NOFTVG0m h1{font-size:42px;font-weight:800;letter-spacing:-1px;margin-bottom:8px}
.astro-NOFTVG0m p{font-size:18px;opacity:.7}
.astro-NOFTVG0m a{color:#fff;text-decoration:none;font-size:22px;font-weight:800}
.astro-YzHlLVWk{padding:0}
.astro-ivgecYGq{padding:32px 0;border-left:4px solid #111;padding-left:24px;margin-bottom:28px}
.astro-ivgecYGq h2{font-size:24px;font-weight:700;margin-bottom:6px}
.astro-ivgecYGq h2 a{color:#111;text-decoration:none}
.astro-ivgecYGq h2 a:hover{text-decoration:underline}
.astro-ivgecYGq .astro-rX8l42sn{font-size:12px;font-weight:600;text-transform:uppercase;color:#888;letter-spacing:1px;margin-bottom:8px}
.astro-ivgecYGq p{font-size:15px;color:#444;margin-bottom:10px}
.astro-6TM2YjuB{display:inline-block;background:#111;color:#fff;padding:8px 20px;font-size:13px;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:1px}
.astro-6TM2YjuB:hover{background:#333}
.astro-fgMMX6Rn{padding-bottom:60px}
.astro-fgMMX6Rn h1{font-size:38px;font-weight:800;letter-spacing:-1px;margin-bottom:10px}
.astro-fgMMX6Rn time{font-size:12px;font-weight:600;text-transform:uppercase;color:#888;letter-spacing:1px;display:block;margin-bottom:28px}
.astro-fgMMX6Rn h2{font-size:26px;font-weight:700;margin:40px 0 14px}
.astro-fgMMX6Rn h3{font-size:20px;font-weight:700;margin:32px 0 10px}
.astro-fgMMX6Rn p{margin-bottom:18px;font-size:17px}
.astro-fgMMX6Rn ul,.astro-fgMMX6Rn ol{margin:0 0 18px 24px}
.astro-fgMMX6Rn a{color:#111;font-weight:600;text-decoration:underline}
.astro-fgMMX6Rn img{max-width:100%;height:auto;margin:20px 0}
.astro-T0HVJa4u{background:#111;color:#888;padding:28px 0;margin-top:48px;text-align:center;font-size:12px}
.astro-T0HVJa4u a{color:#888;text-decoration:none}
.astro-58Eu2pti{background:#222;color:#aaa;padding:14px 20px;margin-bottom:24px;font-size:13px;font-style:italic}
.astro-zylu01Fs{background:#1a1a1a;color:#888;padding:14px 20px;margin-top:32px;font-size:12px;border-top:3px solid #444}
.astro-BaXcdHP7{font-size:12px;font-weight:600;text-transform:uppercase;color:#666;letter-spacing:1px;margin:-20px 0 28px;padding-left:12px;border-left:2px solid #ccc}
.astro-oP6cMkz8{margin:0 0 24px}
.astro-ma5hF2LF{width:100%;height:auto;border-radius:0}
.astro-YVh9ATqf{margin:20px 0}
.astro-zY7VEgxn{width:100%;height:auto;border-radius:0}
.astro-RtkvVi9W{border-left:4px solid #111;padding-left:24px;margin-top:48px}
.astro-RtkvVi9W h3{font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.astro-RtkvVi9W ul{list-style:none;padding:0}
.astro-RtkvVi9W li{padding:6px 0}
.astro-RtkvVi9W a{color:#111;text-decoration:underline;font-weight:600}
/* === Theme === */
:root{--primary:#4A5C2E;--accent:#C8A052;--bg:#EFE7CD;--fg:#1F2410;--border:#C4B596;--r:10px;--fb:'Crimson Pro';--fh:'Oswald'}
/* === Custom === */
@import url('https://fonts.googleapis.com/css2?family=Crimson+Pro:ital,wght@0,400;0,600;1,400&family=Oswald:wght@500;700&display=swap');

:root body {
  font-family: var(--fb), Cambria, 'Times New Roman', serif;
  color: var(--fg);
  background: var(--bg);
  line-height: 1.72;
  font-size: 17px;
}
::selection { background: var(--accent); color: var(--fg); }
:root hr { border: 0; border-top: 1px solid var(--border); margin: 32px 0; }

:root > body > div:first-child {
  background: var(--primary);
  color: var(--bg);
  padding: 64px 0 44px;
  margin-bottom: 48px;
  border-bottom: 6px solid var(--accent);
}
:root > body > div:first-child h1 {
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 44px;
  font-weight: 700;
  color: var(--bg);
  letter-spacing: 0;
  line-height: 1.05;
  margin-bottom: 10px;
  text-transform: uppercase;
}
:root > body > div:first-child p {
  font-family: var(--fb), Cambria, serif;
  font-size: 17px;
  color: rgba(239, 231, 205, .82);
  font-style: italic;
  opacity: 1;
}
:root > body > div:first-child a {
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 24px;
  color: var(--bg);
  text-decoration: none;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0;
}

:root main { padding-bottom: 80px; }

:root main > hgroup > h1 {
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 38px;
  font-weight: 700;
  color: var(--fg);
  line-height: 1.12;
  margin: 8px 0 10px;
  letter-spacing: -.005em;
  text-transform: uppercase;
}
:root main > hgroup > time {
  display: block;
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 12px;
  color: var(--accent);
  margin-bottom: 32px;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 700;
}

:root main > article > p { margin-bottom: 18px; font-size: 17px; line-height: 1.75; }
:root main > article > h2 {
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: var(--primary);
  margin-top: 2.2em; margin-bottom: 0.5em;
  letter-spacing: 0;
  text-transform: uppercase;
  border-top: 3px solid var(--primary);
  padding-top: 12px;
}
:root main > article > h3 {
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 18px;
  font-weight: 500;
  color: var(--accent);
  margin-top: 1.5em; margin-bottom: 0.4em;
  text-transform: uppercase;
  letter-spacing: .04em;
}
:root main > article ul,
:root main > article ol { margin-top: 1em; margin-bottom: 1em; padding-left: 1.5em; }
:root main > article li { margin-bottom: 6px; }
:root main > article blockquote {
  border-left: 4px solid var(--accent);
  padding: 10px 0 10px 20px;
  margin: 28px 0;
  font-style: italic;
  color: var(--fg);
  background: rgba(200, 160, 82, .07);
  border-radius: 0 var(--r) var(--r) 0;
}

:root main > article > p a,
:root main > article > p a:visited {
  color: var(--primary);
  text-decoration: underline;
  text-decoration-color: var(--accent);
  text-underline-offset: 3px;
  text-decoration-thickness: 1.5px;
  font-weight: 600;
}
:root main > article > p a:hover {
  color: var(--accent);
  text-decoration-color: var(--primary);
}

:root main > article > p a[href^="/check/"],
:root main > article > p a[href^="/ref/"],
:root main > article > p a[href^="/try/"] {
  background: var(--accent);
  color: var(--fg);
  padding: 2px 10px;
  border-radius: var(--r);
  text-decoration: none;
  font-weight: 700;
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 14px;
  letter-spacing: .03em;
  text-transform: uppercase;
}
:root main > article > p a[href^="/check/"]:hover,
:root main > article > p a[href^="/ref/"]:hover,
:root main > article > p a[href^="/try/"]:hover {
  background: var(--primary);
  color: var(--bg);
}

:root main > article > section:has(> img) {
  margin: 0 0 32px;
}
:root main > article > section > img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--r);
  box-shadow: 0 4px 16px rgba(31, 36, 16, .14);
}

:root main > article > aside {
  background: rgba(74, 92, 46, .07);
  border-left: 4px solid var(--primary);
  border-radius: 0 var(--r) var(--r) 0;
  padding: 14px 20px;
  margin: 36px 0 0;
  font-size: 14px;
  color: var(--fg);
  font-family: var(--fb), Cambria, serif;
  font-style: italic;
  line-height: 1.65;
}

:root main > div:has(> h2) {
  background: var(--bg);
  border: 1px solid var(--border);
  border-left: 6px solid var(--primary);
  border-radius: 0 var(--r) var(--r) 0;
  padding: 24px 26px;
  margin-bottom: 22px;
  box-shadow: 0 1px 6px rgba(31, 36, 16, .05);
  transition: transform .15s ease, box-shadow .15s ease;
}
:root main > div:has(> h2):hover {
  transform: translateX(2px);
  box-shadow: 0 3px 14px rgba(31, 36, 16, .10);
}
:root main > div:has(> h2) > p:first-child {
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 11px;
  color: var(--accent);
  letter-spacing: .16em;
  text-transform: uppercase;
  margin-bottom: 8px;
  font-weight: 700;
}
:root main > div:has(> h2) > h2 {
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 8px;
  line-height: 1.18;
  letter-spacing: -.005em;
  text-transform: uppercase;
}
:root main > div:has(> h2) > h2 a {
  color: var(--fg);
  text-decoration: none;
}
:root main > div:has(> h2) > h2 a:hover { color: var(--primary); }
:root main > div:has(> h2) > p:not(:first-child) {
  font-family: var(--fb), Cambria, serif;
  font-size: 15px;
  color: var(--fg);
  opacity: .85;
  margin-bottom: 12px;
}
:root main > div:has(> h2) > a:last-child {
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 12px;
  color: var(--bg);
  background: var(--primary);
  padding: 7px 18px;
  border-radius: var(--r);
  text-decoration: none;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 700;
  display: inline-block;
  transition: background .15s ease;
}
:root main > div:has(> h2) > a:last-child:hover { background: var(--accent); color: var(--fg); }

:root main > div:has(> ul) {
  margin-top: 48px;
  padding-top: 28px;
  border-top: 2px solid var(--primary);
}
:root main > div:has(> ul) > h3 {
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 14px;
  color: var(--primary);
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-weight: 700;
}
:root main > div:has(> ul) > ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
:root main > div:has(> ul) > ul > li {
  padding: 10px 0;
  border-bottom: 1px dotted var(--border);
}
:root main > div:has(> ul) > ul > li:last-child { border-bottom: 0; }
:root main > div:has(> ul) > ul > li > a {
  color: var(--fg);
  text-decoration: none;
  font-family: var(--fb), Cambria, serif;
  font-size: 15.5px;
  line-height: 1.4;
}
:root main > div:has(> ul) > ul > li > a:hover { color: var(--primary); }

:root footer {
  background: transparent;
  border-top: 1px solid var(--border);
  padding: 24px 0 36px;
  margin-top: 48px;
  text-align: center;
  font-family: var(--fh), system-ui, sans-serif;
  font-size: 12px;
  color: var(--fg);
  opacity: .62;
  letter-spacing: .08em;
  text-transform: uppercase;
}
:root footer a {
  color: var(--fg);
  text-decoration: none;
  border-bottom: 1px dotted var(--border);
}
:root footer a:hover {
  color: var(--primary);
  border-bottom-color: var(--primary);
}

/* === R3 fixes (2026-06-07T23:00:05.622318+00:00) === */

/* H3: dark warm brown + amber left border for scan-ability */
:root main > article > h3 {
  color: #5C4A1E;
  padding-left: 12px;
  border-left: 3px solid var(--accent);
}

/* Body + article paragraphs: 18px for extended reading comfort */
:root body { font-size: 18px; }
:root main > article > p { font-size: 18px; }

/* Opening paragraph: visual invitation into Kate's hook writing */
:root main > article > p:first-of-type {
  font-size: 19px;
  line-height: 1.6;
  font-style: italic;
  border-left: 3px solid var(--accent);
  padding-left: 16px;
  margin-bottom: 28px;
}

/* Author page article directory: stronger separation from bio zone */
:root main > div:has(> ul) {
  margin-top: 64px;
  padding-top: 36px;
  border-top: 3px solid var(--accent);
}

/* === R4 fixes (2026-06-07T23:40:04.149651+00:00) === */

/* H2 section headers: remove uppercase — green border-top already marks section breaks */
:root main > article > h2 { text-transform: none; }

/* H3 subheads: remove uppercase — amber left border + dark brown already signal subsection */
:root main > article > h3 { text-transform: none; }

/* Opening paragraph: remove italic — amber border-left alone is the right entry-point cue */
:root main > article > p:first-of-type { font-style: normal; }

/* === R2 fixes (2026-06-07T22:20:04.713657+00:00) === */

/* homepage article list items — breathing room + subtle divider */
.astro-ivgecYGq {
  padding-bottom: 1.5em;
  border-bottom: 1px solid rgba(74, 93, 78, 0.15);
  margin-bottom: 1.5em;
}

/* site name in header nav — anchors the brand identity */
header h1 {
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  font-weight: 700;
}
