*{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}
.sc-loCLVs{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 .sc-OPNNCO{color:#fff;text-decoration:none;font-size:18px;font-weight:600}
.sc-ItRbZs{border-bottom:1px solid #eee;padding:24px 0}
.sc-ItRbZs h2{font-size:20px;margin-bottom:8px}
.sc-ItRbZs h2 a{color:#1a1a2e;text-decoration:none}
.sc-ItRbZs h2 a:hover{color:#e94560}
.sc-ItRbZs .date{font-size:13px;color:#999;margin-bottom:8px}
.sc-CDJEWN{color:#e94560;text-decoration:none;font-size:14px;font-weight:600}
.sc-pEAtEN{padding-bottom:60px}
.sc-pEAtEN h1{font-size:32px;margin-bottom:8px}
.sc-pEAtEN time{font-size:13px;color:#999;display:block;margin-bottom:24px}
.sc-pEAtEN h2{font-size:22px;margin:32px 0 12px}
.sc-pEAtEN h3{font-size:18px;margin:24px 0 8px}
.sc-pEAtEN p{margin-bottom:16px}
.sc-pEAtEN ul,.sc-pEAtEN ol{margin:0 0 16px 24px}
.sc-pEAtEN a{color:#e94560}
.sc-pEAtEN 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}
.sc-RdkyrW{background:#f5f5f5;border-left:3px solid #999;padding:10px 14px;margin-bottom:20px;font-size:13px;color:#777;font-style:italic}
.sc-QEFxcS{background:#fef9e7;border:1px solid #f0c36d;padding:10px 14px;margin-top:20px;font-size:12px;color:#8a6d3b}
.sc-oCBdJi{font-size:13px;color:#999;margin:-16px 0 24px;font-style:italic}
.sc-Hnilqj{text-align:center;margin:0 0 20px}
.sc-PbFEIA{max-width:100%;height:auto;border-radius:6px}
.sc-vGAWhO{text-align:center;margin:24px 0}
.sc-gauWUl{max-width:100%;height:auto;border-radius:6px}
.sc-sZeGBn{margin-top:40px;padding-top:24px;border-top:1px solid #eee}
.sc-sZeGBn h3{font-size:18px;margin-bottom:12px}
.sc-sZeGBn ul{list-style:none;padding:0}
.sc-sZeGBn li{padding:4px 0}
.sc-sZeGBn a{color:#e94560;text-decoration:none}
/* === Theme === */
:root{--primary:#2A1F4A;--accent:#B89B47;--bg:#ECE4D0;--fg:#1A171F;--border:#C5BBA8;--r:18px;--fb:'Sora';--fh:'Cinzel'}
/* === Custom === */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;700&family=Sora:wght@400;500;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(--primary); color: var(--bg); }
:root hr { border: 0; border-top: 1px solid var(--border); margin: 28px 0; }

:root header { background: var(--primary); color: var(--bg); padding: 40px 0 26px; margin-bottom: 40px; border-bottom: 4px solid var(--accent); }
:root header h1 { font-family: var(--fh), Cambria, serif; font-size: 30px; font-weight: 700; color: var(--bg); letter-spacing: .04em; margin-bottom: 4px; text-transform: uppercase; line-height: 1.15; }
:root header h1 + p { font-family: var(--fb), system-ui, sans-serif; font-size: 14px; color: rgba(236, 228, 208, .80); font-style: italic; }
:root header a { font-family: var(--fh), Cambria, serif; font-size: 22px; color: var(--bg); text-decoration: none; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }

:root main { padding-bottom: 60px; }
:root main > h1 { font-family: var(--fh), Cambria, serif; font-size: 30px; font-weight: 700; color: var(--primary); line-height: 1.16; margin: 10px 0 6px; letter-spacing: .03em; text-transform: uppercase; }
: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: 600; }

:root main > article:not(:has(> .date)) > p { margin-bottom: 16px; font-size: 16.5px; }
:root main > article:not(:has(> .date)) > h2 { font-family: var(--fh), Cambria, serif; font-size: 22px; font-weight: 700; color: var(--primary); margin: 36px 0 12px; padding-bottom: 4px; border-bottom: 2px solid var(--accent); text-transform: uppercase; letter-spacing: .03em; }
:root main > article:not(:has(> .date)) > h3 { font-family: var(--fh), Cambria, serif; font-size: 17px; font-weight: 400; color: var(--accent); margin: 24px 0 8px; text-transform: uppercase; letter-spacing: .04em; }
:root main > article:not(:has(> .date)) ul, :root main > article:not(:has(> .date)) ol { margin: 0 0 18px 22px; }
:root main > article:not(:has(> .date)) li { margin-bottom: 6px; }
:root main > article:not(:has(> .date)) blockquote { border-left: 4px solid var(--accent); padding: 8px 0 8px 18px; margin: 24px 0; font-style: italic; color: var(--primary); background: rgba(184, 155, 71, .06); }

:root main > article:not(:has(> .date)) > p a, :root main > article:not(:has(> .date)) > 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: 500; }
:root main > article:not(:has(> .date)) > p a:hover { color: var(--accent); text-decoration-color: var(--primary); }

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

:root main > article:not(:has(> .date)) > div:has(> img) { margin: 0 0 28px; }
:root main > article:not(:has(> .date)) > div:has(> img) > img { width: 100%; height: auto; display: block; border: 1px solid var(--accent); border-radius: var(--r); }

:root main > article:not(:has(> .date)) > div:has(> em) { border-top: 1px solid var(--accent); border-bottom: 1px solid var(--accent); padding: 12px 14px; margin-top: 36px; font-size: 13px; color: var(--fg); font-family: var(--fb), system-ui, sans-serif; font-style: italic; background: rgba(42, 31, 74, .04); }
:root main > article:not(:has(> .date)) > div:has(> em) em { font-family: var(--fh), Cambria, serif; font-style: normal; color: var(--primary); text-transform: uppercase; font-size: 11px; letter-spacing: .14em; display: inline-block; margin-right: 8px; font-weight: 700; }

:root main > article:has(> .date) { padding: 22px 0; border-bottom: 1px solid var(--border); }
:root main > article:has(> .date):last-of-type { border-bottom: 0; }
:root main > article:has(> .date) > h2 { font-family: var(--fh), Cambria, serif; font-size: 21px; font-weight: 700; margin-bottom: 4px; line-height: 1.24; letter-spacing: .02em; text-transform: uppercase; }
:root main > article:has(> .date) > h2 a { color: var(--fg); text-decoration: none; }
:root main > article:has(> .date) > h2 a:hover { color: var(--primary); }
:root main > article:has(> .date) > .date { font-family: var(--fb), system-ui, sans-serif; font-size: 11px; color: var(--accent); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 8px; display: block; font-weight: 600; }
:root main > article:has(> .date) > p:not(.date) { font-size: 14.5px; color: var(--fg); opacity: .85; margin-bottom: 10px; }
:root main > article:has(> .date) > a:last-child { font-family: var(--fh), Cambria, serif; font-size: 12px; color: var(--bg); background: var(--primary); padding: 6px 14px; border-radius: var(--r); text-decoration: none; letter-spacing: .08em; text-transform: uppercase; font-weight: 700; }
:root main > article:has(> .date) > a:last-child:hover { background: var(--accent); }

:root main > section { margin-top: 40px; padding-top: 20px; border-top: 2px solid var(--primary); }
:root main > section > h3 { font-family: var(--fh), Cambria, serif; font-size: 15px; color: var(--primary); margin-bottom: 14px; text-transform: uppercase; letter-spacing: .14em; font-weight: 700; }
:root main > section > ul { list-style: none; margin: 0; padding: 0; }
:root main > section > ul > li { padding: 9px 0; border-bottom: 1px dotted var(--border); }
:root main > section > ul > li:last-child { border-bottom: 0; }
:root main > section > ul > li > a { color: var(--fg); text-decoration: none; font-family: var(--fb), system-ui, sans-serif; font-size: 14.5px; }
:root main > section > ul > li > a:hover { color: var(--primary); }

:root footer { background: transparent; border-top: 1px solid var(--accent); padding: 22px 0 32px; margin-top: 40px; text-align: center; font-family: var(--fh), Cambria, serif; font-size: 12px; color: var(--fg); opacity: .60; letter-spacing: .12em; 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); }
