*{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}
.Nav_wrapper__zWZi9{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 .Page_item__wMFXS{color:#fff;text-decoration:none;font-size:18px;font-weight:600}
.Module_link__jTg6Z{border-bottom:1px solid #eee;padding:24px 0}
.Module_link__jTg6Z h2{font-size:20px;margin-bottom:8px}
.Module_link__jTg6Z h2 a{color:#1a1a2e;text-decoration:none}
.Module_link__jTg6Z h2 a:hover{color:#e94560}
.Module_link__jTg6Z .date{font-size:13px;color:#999;margin-bottom:8px}
.Content_link__RRxUt{color:#e94560;text-decoration:none;font-size:14px;font-weight:600}
.Content_area__snMK9{padding-bottom:60px}
.Content_area__snMK9 h1{font-size:32px;margin-bottom:8px}
.Content_area__snMK9 time{font-size:13px;color:#999;display:block;margin-bottom:24px}
.Content_area__snMK9 h2{font-size:22px;margin:32px 0 12px}
.Content_area__snMK9 h3{font-size:18px;margin:24px 0 8px}
.Content_area__snMK9 p{margin-bottom:16px}
.Content_area__snMK9 ul,.Content_area__snMK9 ol{margin:0 0 16px 24px}
.Content_area__snMK9 a{color:#e94560}
.Content_area__snMK9 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}
.Article_box__TxeIW{background:#f5f5f5;border-left:3px solid #999;padding:10px 14px;margin-bottom:20px;font-size:13px;color:#777;font-style:italic}
.Module_block__BDS9s{background:#fef9e7;border:1px solid #f0c36d;padding:10px 14px;margin-top:20px;font-size:12px;color:#8a6d3b}
.Article_inner__ESYA2{font-size:13px;color:#999;margin:-16px 0 24px;font-style:italic}
.Section_foot__SNdGW{text-align:center;margin:0 0 20px}
.Footer_root__PXIV5{max-width:100%;height:auto;border-radius:6px}
.Hero_box__GiLgr{text-align:center;margin:24px 0}
.Nav_block__nXoQs{max-width:100%;height:auto;border-radius:6px}
.Container_wrap__PHgPS{margin-top:40px;padding-top:24px;border-top:1px solid #eee}
.Container_wrap__PHgPS h3{font-size:18px;margin-bottom:12px}
.Container_wrap__PHgPS ul{list-style:none;padding:0}
.Container_wrap__PHgPS li{padding:4px 0}
.Container_wrap__PHgPS a{color:#e94560;text-decoration:none}
/* === Theme === */
:root{--primary:#7A4530;--accent:#7A8AA0;--bg:#EFE5DA;--fg:#1F140C;--border:#C4A8A0;--r:21px;--fb:'Hanken Grotesk';--fh:'Tenor Sans'}
/* === Custom === */
@import url('https://fonts.googleapis.com/css2?family=Tenor+Sans&family=Hanken+Grotesk:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root body { font-family: var(--fb), system-ui, -apple-system, sans-serif; color: var(--fg); background: var(--bg); line-height: 1.72; 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: 1rem; line-height: 1.5; color: rgba(255, 255, 255, 0.93); max-width: 660px; }
:root > body > header a { font-family: var(--fh), Cambria, serif; font-size: 26px; color: var(--bg); text-decoration: none; font-weight: 400; letter-spacing: .01em; }

: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.20; 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: 600; }

:root main > article > p { margin-bottom: 18px; font-size: 16.5px; line-height: 1.75; }
:root main > article > h2 { font-family: var(--fh), Cambria, serif; font-size: 25px; font-weight: 400; color: #4A2000; margin: 2.5em 0 0.75em; padding-bottom: 6px; border-bottom: 1px solid var(--accent); letter-spacing: .01em; }
:root main > article > h3 { font-family: var(--fh), Cambria, serif; font-size: 19px; font-weight: 400; color: var(--accent); margin: 24px 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; font-size: 16px; }
:root main > article li strong { color: var(--primary); font-weight: 700; }
:root main > article blockquote { border-left: 3px solid var(--accent); padding: 10px 0 10px 20px; margin: 26px 0; font-style: italic; color: var(--primary); background: rgba(122, 138, 160, .10); border-radius: 0 var(--r) var(--r) 0; }
: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: 600; }
: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: 600; font-family: var(--fh), Cambria, serif; font-size: 14.5px; letter-spacing: .02em; }
: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, :root main > article > section:has(> img) { margin: 0 0 30px; }
:root main > article > img, :root main > article > figure > img, :root main > article > section > img { width: 100%; height: auto; display: block; border-radius: var(--r); box-shadow: 0 4px 18px rgba(31, 20, 12, .12); }

:root main > article:has(> p.date) { background: rgba(255,255,255,0.55); border: 1px solid var(--border); border-left: 4px solid #7A3A00; border-radius: 0 var(--r) var(--r) 0; padding: 20px 24px 20px 1.25rem; margin-bottom: 16px; transition: border-left-color .15s ease, transform .12s ease; }
:root main > article:has(> p.date):hover { border-left-color: var(--primary); transform: translateX(2px); }
: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: 22px 0 32px; margin-top: 48px; text-align: center; font-family: var(--fb), system-ui, sans-serif; font-size: 12px; color: var(--fg); opacity: .60; letter-spacing: .03em; }
: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); }

/* === R2 fixes (2026-06-02T05:50:05.000626+00:00) === */
:root main > article > p a[href*='/choice/'] { font-weight: 600; text-decoration-thickness: 2px; color: #7A3A00; text-underline-offset: 3px; }

/* === R3 fixes (2026-06-02T06:30:04.227247+00:00) === */
article h2 + hr, .bld-content h2 + hr { margin-bottom: 1.25em; }

/* === R4 fixes (2026-06-02T07:10:07.172346+00:00) === */
:root main > article > p a[href*='/choice/'] { text-decoration-color: #7A3A00; }
:root main > article > blockquote { background: rgba(122, 69, 48, 0.08); border-left-color: #7A4530; }
