*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,system-ui,sans-serif;line-height:1.7;color:#333;background:#fff}
.astro-y0QHapeU{max-width:780px;margin:0 auto;padding:0 20px}
header{background:#1a1a2e;color:#fff;padding:32px 0;margin-bottom:40px}
header h1{font-size:28px;margin-bottom:4px}
header p{opacity:.7;font-size:15px}
header .astro-m72zzmam{color:#fff;text-decoration:none;font-size:18px;font-weight:600}
.astro-iidMCmdn{border-bottom:1px solid #eee;padding:24px 0}
.astro-iidMCmdn h2{font-size:20px;margin-bottom:8px}
.astro-iidMCmdn h2 a{color:#1a1a2e;text-decoration:none}
.astro-iidMCmdn h2 a:hover{color:#e94560}
.astro-iidMCmdn .date{font-size:13px;color:#999;margin-bottom:8px}
.astro-FCnnftyS{color:#e94560;text-decoration:none;font-size:14px;font-weight:600}
.astro-wjJpeulK{padding-bottom:60px}
.astro-wjJpeulK h1{font-size:32px;margin-bottom:8px}
.astro-wjJpeulK time{font-size:13px;color:#999;display:block;margin-bottom:24px}
.astro-wjJpeulK h2{font-size:22px;margin:32px 0 12px}
.astro-wjJpeulK h3{font-size:18px;margin:24px 0 8px}
.astro-wjJpeulK p{margin-bottom:16px}
.astro-wjJpeulK ul,.astro-wjJpeulK ol{margin:0 0 16px 24px}
.astro-wjJpeulK a{color:#e94560}
.astro-wjJpeulK img{max-width:100%;height:auto;border-radius:8px;margin:16px 0}
footer{border-top:1px solid #eee;padding:24px 0;margin-top:40px;text-align:center;font-size:13px;color:#999}
footer a{color:#999}
.astro-3XxbyCZx{background:#f5f5f5;border-left:3px solid #999;padding:10px 14px;margin-bottom:20px;font-size:13px;color:#777;font-style:italic}
.astro-gErK2ANP{background:#fef9e7;border:1px solid #f0c36d;padding:10px 14px;margin-top:20px;font-size:12px;color:#8a6d3b}
.astro-i5vOELsq{font-size:13px;color:#999;margin:-16px 0 24px;font-style:italic}
.astro-xEoVvCTN{text-align:center;margin:0 0 20px}
.astro-UQihLpcf{max-width:100%;height:auto;border-radius:6px}
.astro-UG6SfyLx{text-align:center;margin:24px 0}
.astro-P7q90A5W{max-width:100%;height:auto;border-radius:6px}
.astro-tO3GH5Xu{margin-top:40px;padding-top:24px;border-top:1px solid #eee}
.astro-tO3GH5Xu h3{font-size:18px;margin-bottom:12px}
.astro-tO3GH5Xu ul{list-style:none;padding:0}
.astro-tO3GH5Xu li{padding:4px 0}
.astro-tO3GH5Xu a{color:#e94560;text-decoration:none}
/* === Theme === */
:root{--primary:#7A4A26;--accent:#5C7A95;--bg:#EFEAD5;--fg:#1F140A;--border:#C4B095;--r:41px;--fb:'Mada';--fh:'Italiana'}
/* === Custom === */
@import url('https://fonts.googleapis.com/css2?family=Italiana&family=Mada:wght@400;500;600;700&display=swap');

:root body { font-family: var(--fb), system-ui, -apple-system, sans-serif; color: var(--fg); background: var(--bg); line-height: 1.74; font-size: 16.5px; }
::selection { background: var(--accent); color: var(--bg); }
:root hr { border: 0; border-top: 1px solid var(--border); margin: 30px 0; }

:root > body > header { background: var(--primary); color: var(--bg); padding: 50px 0 30px; margin-bottom: 44px; border-bottom: 3px solid var(--accent); }
:root > body > header > div { max-width: 740px; margin: 0 auto; padding: 0 24px; }
:root > body > header h1 { font-family: var(--fh), Cambria, serif; font-size: 36px; font-weight: 400; color: var(--bg); line-height: 1.16; margin-bottom: 8px; letter-spacing: .01em; }
:root > body > header p { font-family: var(--fb), system-ui, sans-serif; font-size: 14.5px; color: rgba(239, 234, 213, .82); max-width: 680px; font-style: italic; }
:root > body > header a { font-family: var(--fh), Cambria, serif; font-size: 26px; color: var(--bg); text-decoration: none; font-weight: 400; }

:root main { max-width: 740px; margin: 0 auto; padding: 0 24px 70px; }
:root main > h1 { font-family: var(--fh), Cambria, serif; font-size: 32px; font-weight: 400; color: var(--primary); line-height: 1.18; margin: 6px 0 6px; letter-spacing: .01em; }
:root main > time { display: block; font-family: var(--fb), system-ui, sans-serif; font-size: 12px; color: var(--accent); margin-bottom: 30px; letter-spacing: .14em; text-transform: uppercase; font-weight: 700; }

:root main > article > p { margin-bottom: 18px; font-size: 16.5px; }
:root main > article > h2 { font-family: var(--fh), Cambria, serif; font-size: 25px; font-weight: 400; color: var(--primary); margin: 38px 0 12px; padding-bottom: 6px; border-bottom: 1px solid var(--accent); letter-spacing: .01em; }
:root main > article ul, :root main > article ol { margin: 0 0 18px 24px; }
:root main > article li { margin-bottom: 6px; font-size: 16px; }
:root main > article li strong { color: var(--primary); font-weight: 700; }
:root main > article > p strong { color: var(--primary); font-weight: 700; }

: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: 700; }
:root main > article > p a:hover { color: var(--accent); text-decoration-color: var(--primary); }

:root main > article > p a[href^="/ref/"], :root main > article > p a[href^="/try/"], :root main > article > p a[href^="/check/"], :root main > article > p a[href^="/partner/"], :root main > article > p a[href^="/go/"], :root main > article > p a[href^="/out/"] { background: var(--accent); color: var(--bg); padding: 3px 14px; border-radius: var(--r); text-decoration: none; font-weight: 700; font-family: var(--fh), Cambria, serif; font-size: 14.5px; letter-spacing: .04em; }
:root main > article > p a[href^="/ref/"]:hover, :root main > article > p a[href^="/try/"]:hover, :root main > article > p a[href^="/check/"]:hover, :root main > article > p a[href^="/partner/"]:hover, :root main > article > p a[href^="/go/"]:hover, :root main > article > p a[href^="/out/"]:hover { background: var(--primary); color: var(--bg); }

:root main > article > img, :root main > article > figure { margin: 0 0 28px; }
:root main > article > img, :root main > article > figure > img { width: 100%; height: auto; display: block; border-radius: var(--r); box-shadow: 0 3px 14px rgba(31, 20, 10, .14); }

:root main > article:has(> p.date) { background: #FFFCEC; border: 1px solid var(--border); border-left: 4px solid var(--accent); border-radius: 0 var(--r) var(--r) 0; padding: 22px 26px; margin-bottom: 18px; box-shadow: 0 1px 6px rgba(31, 20, 10, .06); transition: border-left-color .12s ease; }
:root main > article:has(> p.date):hover { border-left-color: var(--primary); }
:root main > article:has(> p.date) > h2 { font-family: var(--fh), Cambria, serif; font-size: 21px; font-weight: 400; margin-bottom: 6px; line-height: 1.22; padding-bottom: 0; border-bottom: 0; letter-spacing: .01em; }
:root main > article:has(> p.date) > h2 a { color: var(--primary); text-decoration: none; }
:root main > article:has(> p.date) > p.date { font-family: var(--fb), system-ui, sans-serif; font-size: 11px; color: var(--accent); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 6px; font-weight: 700; }
:root main > article:has(> p.date) > p:not(.date) { font-family: var(--fb), system-ui, sans-serif; font-size: 14.5px; color: var(--fg); opacity: .82; margin-bottom: 12px; }
:root main > article:has(> p.date) > a:last-child { font-family: var(--fb), system-ui, sans-serif; font-size: 12.5px; color: var(--primary); background: transparent; padding: 0; text-decoration: none; letter-spacing: .04em; font-weight: 700; border-bottom: 1px solid var(--primary); }

:root footer { background: transparent; border-top: 1px solid var(--border); padding: 24px 0 36px; margin-top: 52px; text-align: center; font-family: var(--fb), system-ui, sans-serif; font-size: 12.5px; color: var(--fg); opacity: .60; letter-spacing: .03em; 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-06-10T00:10:06.490997+00:00) === */
:root main > article > p { line-height: 1.75; font-size: 17px; }
:root main > article > h2 { margin-top: 2.5em; margin-bottom: 0.6em; }
:root main > article li { font-size: 17px; }
:root > body > header p { font-size: 0.9rem; line-height: 1.4; opacity: 1; }
:root main > h1 { margin-bottom: 0.6em; }

/* === R3 fixes (2026-06-10T00:50:07.372550+00:00) === */
/* Related articles link color — replace template hot-pink with site palette */
.astro-tO3GH5Xu a { color: var(--primary); text-decoration: underline; text-decoration-color: var(--accent); text-underline-offset: 2px; }

/* Related articles heading — small-caps serif treatment matching site typography */
.astro-tO3GH5Xu h3 { font-family: var(--fh), Cambria, serif; font-size: 14px; font-weight: 400; color: var(--primary); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 14px; }

/* Disclaimer box — strip yellow box, render as discreet italic footer note */
.astro-gErK2ANP { background: transparent; border: 0; border-top: 1px solid var(--border); padding: 18px 0 0; margin-top: 36px; font-size: 12px; color: var(--fg); opacity: 0.55; font-style: italic; }

/* Article H3 — serif styled to match warm visual chain, not browser-default bold */
:root main > article > h3 { font-family: var(--fh), Cambria, serif; font-size: 20px; font-weight: 400; color: var(--primary); margin: 1.8em 0 0.4em; letter-spacing: 0.01em; }

/* Lead paragraph — slightly larger and primary-colored to signal article entry point */
:root main > article > p:first-of-type { font-size: 18px; line-height: 1.82; color: var(--primary); }

/* === R4 fixes (2026-06-10T01:30:07.368713+00:00) === */
/* Article title — larger weight for emotionally heavy titles about grief and lineage */
:root main > h1 { font-size: 36px; margin-bottom: 0.9em; }

/* Lead paragraph — italic marks the opening scene as storytelling entry before analysis */
:root main > article > p:first-of-type { font-style: italic; }

/* Listing cards — remove perimeter border, keep left accent; editorial cuaderno feel not product catalog */
:root main > article:has(> p.date) { border: 0; border-left: 4px solid var(--accent); }

/* Related articles list — strip browser-default bullets/indent; reads as handwritten margin notes */
.astro-tO3GH5Xu ul { list-style: none; padding: 0; margin: 0; }
.astro-tO3GH5Xu li { margin-bottom: 8px; }
