*{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}
.sc-dGthbq{max-width:900px;margin:0 auto;padding:0 28px}
.sc-zunJxe{background:#111;color:#fff;padding:64px 0;margin-bottom:48px}
.sc-zunJxe h1{font-size:42px;font-weight:800;letter-spacing:-1px;margin-bottom:8px}
.sc-zunJxe p{font-size:18px;opacity:.7}
.sc-zunJxe a{color:#fff;text-decoration:none;font-size:22px;font-weight:800}
.sc-iHXRlF{padding:0}
.sc-cVTxXE{padding:32px 0;border-left:4px solid #111;padding-left:24px;margin-bottom:28px}
.sc-cVTxXE h2{font-size:24px;font-weight:700;margin-bottom:6px}
.sc-cVTxXE h2 a{color:#111;text-decoration:none}
.sc-cVTxXE h2 a:hover{text-decoration:underline}
.sc-cVTxXE .sc-eBsRiV{font-size:12px;font-weight:600;text-transform:uppercase;color:#888;letter-spacing:1px;margin-bottom:8px}
.sc-cVTxXE p{font-size:15px;color:#444;margin-bottom:10px}
.sc-CbnQNT{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}
.sc-CbnQNT:hover{background:#333}
.sc-NLUmVR{padding-bottom:60px}
.sc-NLUmVR h1{font-size:38px;font-weight:800;letter-spacing:-1px;margin-bottom:10px}
.sc-NLUmVR time{font-size:12px;font-weight:600;text-transform:uppercase;color:#888;letter-spacing:1px;display:block;margin-bottom:28px}
.sc-NLUmVR h2{font-size:26px;font-weight:700;margin:40px 0 14px}
.sc-NLUmVR h3{font-size:20px;font-weight:700;margin:32px 0 10px}
.sc-NLUmVR p{margin-bottom:18px;font-size:17px}
.sc-NLUmVR ul,.sc-NLUmVR ol{margin:0 0 18px 24px}
.sc-NLUmVR a{color:#111;font-weight:600;text-decoration:underline}
.sc-NLUmVR img{max-width:100%;height:auto;margin:20px 0}
.sc-LgSBVH{background:#111;color:#888;padding:28px 0;margin-top:48px;text-align:center;font-size:12px}
.sc-LgSBVH a{color:#888;text-decoration:none}
.sc-HFjHoe{background:#222;color:#aaa;padding:14px 20px;margin-bottom:24px;font-size:13px;font-style:italic}
.sc-JiJHPx{background:#1a1a1a;color:#888;padding:14px 20px;margin-top:32px;font-size:12px;border-top:3px solid #444}
.sc-zBQmbp{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}
.sc-Ovnjfd{margin:0 0 24px}
.sc-BvYQUD{width:100%;height:auto;border-radius:0}
.sc-VSvgvo{margin:20px 0}
.sc-GWnmQX{width:100%;height:auto;border-radius:0}
.sc-BtThkv{border-left:4px solid #111;padding-left:24px;margin-top:48px}
.sc-BtThkv h3{font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.sc-BtThkv ul{list-style:none;padding:0}
.sc-BtThkv li{padding:6px 0}
.sc-BtThkv a{color:#111;text-decoration:underline;font-weight:600}
/* === Theme === */
:root{--primary:#3F5E36;--accent:#C2843D;--bg:#E8E0CB;--fg:#1A1F26;--border:#B8B6A0;--r:9px;--fb:'Lustria';--fh:'Fraunces'}
/* === Custom === */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,700&family=Lustria&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(--primary); color: var(--bg); }
: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: 60px 0 40px;
  margin-bottom: 48px;
  border-bottom: 5px solid var(--accent);
}
:root > body > div:first-child h1 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 42px;
  font-weight: 700;
  color: var(--bg);
  letter-spacing: -.01em;
  line-height: 1.08;
  margin-bottom: 10px;
}
:root > body > div:first-child p {
  font-family: var(--fb), Cambria, serif;
  font-size: 16px;
  color: rgba(232, 224, 203, .82);
  font-style: italic;
}
:root > body > div:first-child a {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 24px;
  color: var(--bg);
  text-decoration: none;
  font-weight: 700;
}

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

:root main > hgroup > h1,
:root main > h1 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 36px;
  font-weight: 700;
  color: var(--primary);
  line-height: 1.14;
  margin: 8px 0 10px;
  letter-spacing: -.005em;
}
:root main > hgroup > time,
:root main > time {
  display: block;
  font-family: var(--fb), Cambria, serif;
  font-size: 12px;
  color: var(--accent);
  margin-bottom: 32px;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-style: italic;
}

:root main > article > p { margin-bottom: 18px; font-size: 17px; }
:root main > article > h2 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 24px;
  font-weight: 700;
  color: var(--primary);
  margin: 40px 0 14px;
  padding-top: 12px;
  border-top: 2px solid var(--accent);
  letter-spacing: -.005em;
}
:root main > article > h3 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 19px;
  font-weight: 500;
  color: var(--accent);
  margin: 26px 0 10px;
  font-style: italic;
}
:root main > article ul,
:root main > article ol { margin: 0 0 18px 26px; }
: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(--primary);
  background: rgba(194, 132, 61, .06);
  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(--bg);
  padding: 2px 10px;
  border-radius: var(--r);
  text-decoration: none;
  font-weight: 700;
  font-family: var(--fh), Cambria, serif;
  font-size: 14.5px;
  letter-spacing: .02em;
}
: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 3px 14px rgba(26, 31, 38, .14);
  border: 1px solid var(--border);
}

:root main > article > aside {
  background: rgba(63, 94, 54, .06);
  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: 5px solid var(--primary);
  border-radius: 0 var(--r) var(--r) 0;
  padding: 22px 24px;
  margin-bottom: 20px;
  box-shadow: 0 1px 6px rgba(26, 31, 38, .05);
  transition: transform .15s ease, box-shadow .15s ease;
}
:root main > div:has(> h2):hover {
  transform: translateX(2px);
  box-shadow: 0 4px 14px rgba(63, 94, 54, .10);
}
:root main > div:has(> h2) > p:first-child {
  font-family: var(--fb), Cambria, serif;
  font-size: 11px;
  color: var(--accent);
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 8px;
  font-style: italic;
}
:root main > div:has(> h2) > h2 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 8px;
  line-height: 1.2;
  letter-spacing: -.005em;
}
:root main > div:has(> h2) > h2 a {
  color: var(--primary);
  text-decoration: none;
}
:root main > div:has(> h2) > h2 a:hover { color: var(--accent); }
: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), Cambria, serif;
  font-size: 13px;
  color: var(--bg);
  background: var(--primary);
  padding: 7px 18px;
  border-radius: var(--r);
  text-decoration: none;
  letter-spacing: .04em;
  font-weight: 700;
  display: inline-block;
}
:root main > div:has(> h2) > a:last-child:hover { background: var(--accent); }

: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), Cambria, serif;
  font-size: 16px;
  color: var(--primary);
  margin-bottom: 16px;
  letter-spacing: .02em;
  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: 26px 0 36px;
  margin-top: 48px;
  text-align: center;
  font-family: var(--fb), Cambria, serif;
  font-size: 12px;
  color: var(--fg);
  opacity: .62;
  letter-spacing: .04em;
  font-style: italic;
}
:root footer a {
  color: var(--fg);
  text-decoration: none;
  border-bottom: 1px dotted var(--border);
  font-style: normal;
}
:root footer a:hover {
  color: var(--primary);
  border-bottom-color: var(--primary);
}

/* === R2 fixes (2026-05-30T16:30:11.832184+00:00) === */

/* Fix 1+4: article paragraphs — more breathing room between lines and between paragraphs */
:root main > article > p {
  line-height: 1.75;
  margin-bottom: 1.25em;
}

/* Fix 2: article h2 — larger top gap so section breaks read as chapter breaks at scroll speed */
:root main > article > h2 {
  margin-top: 2.2em;
  margin-bottom: 0.5em;
}

/* Fix 3: article h3 — stronger sub-section breathing room to complement the She/He tag-team labels */
:root main > article > h3 {
  margin-top: 1.6em;
  margin-bottom: 0.4em;
}

/* Fix 5: homepage card date stamps — larger and higher contrast so dates are readable at a glance */
:root main > div:has(> h2) > p:first-child {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--primary);
}

/* Fix 7: homepage article cards — subtle border divides cards into discrete scannable items */
:root main > div:has(> h2) {
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  padding-bottom: 1.5rem;
  margin-bottom: 1.5rem;
}

/* Fix 6 (.sc-zunJxe header bar): omitted — structural selector already uses padding: 60px 0 40px
   which exceeds the requested 1.5rem; applying would reduce existing padding. */

/* === R3 fixes (2026-05-30T17:10:04.061507+00:00) === */

/* Fix 1: article body text — 1.0625rem ensures sustained-reading comfort via sc-* and structural */
:root main > article > p,
.sc-NLUmVR p {
  font-size: 1.0625rem;
}

/* Fix 2: site header tagline — bump from ~0.75rem whisper to 0.9rem with gentle opacity */
.sc-zunJxe p {
  font-size: 0.9rem;
  opacity: 0.85;
  letter-spacing: 0.01em;
}

/* Fix 3: Related Articles block — tinted whisper replaces dark green storefront feel */
.sc-BtThkv {
  background-color: rgba(45, 90, 45, 0.07);
  border-top: 2px solid rgba(45, 90, 45, 0.25);
  padding: 1.25rem 1.5rem;
  border-radius: 4px;
  color: inherit;
}

/* Fix 4: Refreshed date metadata — suppress CMS-output feel without removing */
.sc-zBQmbp {
  font-size: 0.7rem;
  opacity: 0.45;
  font-style: italic;
}

/* Fix 5: author page hgroup — accent rule distinguishes it from a regular article hgroup */
.sc-NLUmVR hgroup {
  border-bottom: 2px solid rgba(45, 90, 45, 0.35);
  padding-bottom: 1.25rem;
  margin-bottom: 2rem;
}

/* === R4 fixes (2026-05-30T17:50:05.143633+00:00) === */

/* Fix 1: Related Articles block — muted amber border-top wins specificity battle over structural dark-green rule */
:root main > .sc-BtThkv {
  border-top: 2px solid rgba(194, 132, 61, 0.30);
  padding-top: 28px;
  margin-top: 48px;
}

/* Fix 2: homepage card CTA button — amber accent matches article interior warmth over primary green */
:root main > div:has(> h2) > a:last-child {
  background: var(--accent);
  color: var(--bg);
}
:root main > div:has(> h2) > a:last-child:hover { background: var(--primary); }

/* Fix 3: author page post list — body-text size and green color invite browsing over footnote feel */
:root main > div:has(> ul) > ul > li > a {
  font-size: 17px;
  line-height: 1.65;
  color: var(--primary);
}
