*{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}
.css-e77m2rh{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 .css-lr8uo1y{color:#fff;text-decoration:none;font-size:18px;font-weight:600}
.css-47ddee7{border-bottom:1px solid #eee;padding:24px 0}
.css-47ddee7 h2{font-size:20px;margin-bottom:8px}
.css-47ddee7 h2 a{color:#1a1a2e;text-decoration:none}
.css-47ddee7 h2 a:hover{color:#e94560}
.css-47ddee7 .date{font-size:13px;color:#999;margin-bottom:8px}
.css-gu3u05w{color:#e94560;text-decoration:none;font-size:14px;font-weight:600}
.css-eqjp0kp{padding-bottom:60px}
.css-eqjp0kp h1{font-size:32px;margin-bottom:8px}
.css-eqjp0kp time{font-size:13px;color:#999;display:block;margin-bottom:24px}
.css-eqjp0kp h2{font-size:22px;margin:32px 0 12px}
.css-eqjp0kp h3{font-size:18px;margin:24px 0 8px}
.css-eqjp0kp p{margin-bottom:16px}
.css-eqjp0kp ul,.css-eqjp0kp ol{margin:0 0 16px 24px}
.css-eqjp0kp a{color:#e94560}
.css-eqjp0kp 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}
.css-1ora4dd{background:#f5f5f5;border-left:3px solid #999;padding:10px 14px;margin-bottom:20px;font-size:13px;color:#777;font-style:italic}
.css-6g3eath{background:#fef9e7;border:1px solid #f0c36d;padding:10px 14px;margin-top:20px;font-size:12px;color:#8a6d3b}
.css-1t0psz7{font-size:13px;color:#999;margin:-16px 0 24px;font-style:italic}
.css-0kwzs6c{text-align:center;margin:0 0 20px}
.css-imaumz7{max-width:100%;height:auto;border-radius:6px}
.css-o8ywq9n{text-align:center;margin:24px 0}
.css-hothr8q{max-width:100%;height:auto;border-radius:6px}
.css-f3k9l0i{margin-top:40px;padding-top:24px;border-top:1px solid #eee}
.css-f3k9l0i h3{font-size:18px;margin-bottom:12px}
.css-f3k9l0i ul{list-style:none;padding:0}
.css-f3k9l0i li{padding:4px 0}
.css-f3k9l0i a{color:#e94560;text-decoration:none}
/* === Theme === */
:root{--primary:#467A2E;--accent:#C28A2E;--bg:#F5EFDB;--fg:#1A1F0F;--border:#C2C8B0;--r:18px;--fb:'DM Sans';--fh:'Spectral'}
/* === Custom === */
@import url('https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,400;0,500;0,600;0,700;1,400&family=DM+Sans: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.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: 760px; margin: 0 auto; padding: 0 24px; }
:root > body > header h1 { font-family: var(--fh), Cambria, serif; font-size: 36px; font-weight: 600; color: var(--bg); line-height: 1.16; margin-bottom: 8px; letter-spacing: -0.005em; }
:root > body > header p { font-family: var(--fb), system-ui, sans-serif; font-size: 14.5px; color: rgba(245, 239, 219, .82); max-width: 680px; }
:root > body > header a { font-family: var(--fh), Cambria, serif; font-size: 26px; color: var(--bg); text-decoration: none; font-weight: 600; }

:root main { max-width: 760px; margin: 0 auto; padding: 0 24px 70px; }
:root main > h1 { font-family: var(--fh), Cambria, serif; font-size: 34px; font-weight: 600; color: var(--primary); line-height: 1.18; margin: 6px 0 6px; letter-spacing: -0.005em; }
:root main > time { display: block; font-family: var(--fb), system-ui, sans-serif; font-size: 12px; color: var(--accent); margin-bottom: 28px; 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: 600; color: var(--primary); margin: 38px 0 12px; padding-bottom: 6px; border-bottom: 1px solid var(--accent); letter-spacing: -0.005em; }
:root main > article > h3 { font-family: var(--fh), Cambria, serif; font-size: 19px; font-weight: 500; color: var(--accent); margin: 24px 0 10px; }
: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: 12px 0 12px 22px; margin: 26px 0; font-style: italic; color: var(--primary); background: rgba(194, 138, 46, .08); 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/"], :root main > article > p a[href^="/view/"], :root main > article > p a[href^="/choice/"] { background: var(--accent); color: var(--bg); padding: 4px 16px; 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, :root main > article > p a[href^="/view/"]:hover, :root main > article > p a[href^="/choice/"]:hover { background: var(--primary); color: var(--bg); }

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

:root main > article > table, :root main > article table { width: 100%; border-collapse: collapse; margin: 26px 0; font-family: var(--fb), system-ui, sans-serif; font-size: 14.5px; background: #FCF9EE; border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
:root main > article table th { background: var(--primary); color: var(--bg); padding: 10px 14px; text-align: left; font-family: var(--fh), Cambria, serif; font-weight: 600; font-size: 13.5px; letter-spacing: .02em; }
:root main > article table td { padding: 9px 14px; border-bottom: 1px solid var(--border); vertical-align: top; }

:root main > div > div:has(> h2) { background: #FCF9EE; border: 1px solid var(--border); border-left: 4px solid var(--accent); border-radius: 0 var(--r) var(--r) 0; padding: 20px 24px; margin-bottom: 18px; transition: border-left-color .12s ease; }
:root main > div > div:has(> h2):hover { border-left-color: var(--primary); }
:root main > div > div:has(> h2) > p:first-child { font-family: var(--fb), system-ui, sans-serif; font-size: 11px; color: var(--accent); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 8px; font-weight: 700; }
:root main > div > div:has(> h2) > h2 { font-family: var(--fh), Cambria, serif; font-size: 22px; font-weight: 600; margin-bottom: 8px; line-height: 1.22; padding-bottom: 0; border-bottom: 0; letter-spacing: -0.005em; }
:root main > div > div:has(> h2) > h2 a { color: var(--primary); text-decoration: none; }
:root main > div > div:has(> h2) > h2 a:hover { color: var(--accent); }
:root main > div > div:has(> h2) > p:not(:first-child) { font-family: var(--fb), system-ui, sans-serif; font-size: 14.5px; color: var(--fg); opacity: .82; margin-bottom: 12px; }
:root main > div > div:has(> h2) > 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 main > div > div:has(> h2) > a:last-child:hover { color: var(--accent); border-bottom-color: var(--accent); }

:root footer { background: transparent; border-top: 1px solid var(--border); padding: 22px 0 32px; margin-top: 50px; text-align: center; font-family: var(--fb), system-ui, sans-serif; font-size: 12.5px; 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); }
