*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Segoe UI',Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.75;color:#333;background:#f0f2f5}
.css-njn7qma{max-width:860px;margin:0 auto;padding:0 20px}
.css-ncnrh28{background:#fff;padding:28px 0;margin-bottom:32px;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.css-ncnrh28 h1{font-size:22px;font-weight:700;margin-bottom:2px}
.css-ncnrh28 p{font-size:14px;color:#666}
.css-ncnrh28 a{color:#333;text-decoration:none;font-size:18px;font-weight:700}
.css-3q284a0{display:flex;flex-direction:column;gap:20px}
.css-lsrmu8h{background:#fff;border-radius:12px;box-shadow:0 1px 6px rgba(0,0,0,.06);padding:24px 28px;transition:transform .15s,box-shadow .15s}
.css-lsrmu8h:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.1)}
.css-lsrmu8h h2{font-size:19px;margin-bottom:6px}
.css-lsrmu8h h2 a{color:#1a1a1a;text-decoration:none}
.css-lsrmu8h .css-qb1eare{font-size:12px;color:#999;margin-bottom:8px}
.css-lsrmu8h p{font-size:14px;color:#555;margin-bottom:12px}
.css-6io08lr{display:inline-block;background:#5865f2;color:#fff;padding:6px 16px;border-radius:20px;font-size:13px;font-weight:600;text-decoration:none}
.css-6io08lr:hover{background:#4752c4}
.css-eps35lz{padding-bottom:60px}
.css-eps35lz h1{font-size:30px;font-weight:700;margin-bottom:8px}
.css-eps35lz time{font-size:12px;color:#999;display:block;margin-bottom:24px}
.css-eps35lz h2{font-size:22px;margin:32px 0 12px}
.css-eps35lz h3{font-size:18px;margin:24px 0 8px}
.css-eps35lz p{margin-bottom:16px}
.css-eps35lz ul,.css-eps35lz ol{margin:0 0 16px 24px}
.css-eps35lz a{color:#5865f2}
.css-eps35lz img{max-width:100%;height:auto;border-radius:12px;margin:16px 0}
.css-10dz9x0{padding:24px 0;margin-top:40px;text-align:center;font-size:12px;color:#999}
.css-10dz9x0 a{color:#999;text-decoration:none}
.css-fkxf0pp{background:#e8eaf0;border-radius:8px;padding:12px 16px;margin-bottom:20px;font-size:13px;color:#888;font-style:italic}
.css-jlxqiyg{background:#fff8e1;border-radius:8px;padding:12px 16px;margin-top:24px;font-size:12px;color:#9e8600}
.css-ckne1cw{display:inline-block;background:#f0f2f7;border-radius:12px;padding:4px 12px;margin:-18px 0 24px;font-size:12px;color:#777}
.css-gppxn9y{text-align:center;margin:0 0 24px}
.css-v87yhd5{max-width:100%;height:auto;border-radius:12px}
.css-td38wde{text-align:center;margin:24px 0}
.css-iq9k2kk{max-width:100%;height:auto;border-radius:12px}
.css-bv2okf4{margin-top:32px;padding-top:20px;border-top:1px solid #e0e0e0}
.css-bv2okf4 h3{font-size:16px;font-weight:700;margin-bottom:12px}
.crd-related-list{display:flex;flex-direction:column;gap:8px}
.crd-related-link{display:block;background:#fff;border-radius:8px;padding:10px 14px;color:#333;text-decoration:none;box-shadow:0 1px 3px rgba(0,0,0,.06);font-size:14px}
.crd-related-link:hover{box-shadow:0 2px 8px rgba(0,0,0,.1)}
/* === Theme === */
:root{--primary:#1F2630;--accent:#E08542;--bg:#F0EBDA;--fg:#0A0C12;--border:#C5BE9C;--r:3px;--fb:'Jost';--fh:'Caveat'}
/* === Custom === */
@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@400;500;700&family=Jost:ital,wght@0,400;0,500;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: 32px 0; }

:root > body > div:first-child { background: var(--primary); color: var(--bg); padding: 58px 0 38px; margin-bottom: 48px; border-bottom: 4px solid var(--accent); }
:root > body > div:first-child h1 { font-family: var(--fh), cursive; font-size: 50px; font-weight: 700; color: var(--bg); letter-spacing: -0.02em; line-height: 1.08; margin-bottom: 8px; }
:root > body > div:first-child p { font-family: var(--fb), system-ui, sans-serif; font-size: 15px; color: rgba(240, 235, 218, .80); font-style: italic; max-width: 600px; margin: 0 auto; }
:root > body > div:first-child a { font-family: var(--fh), cursive; font-size: 34px; 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), cursive; font-size: 42px; font-weight: 700; color: var(--primary); line-height: 1.10; margin: 8px 0 10px; letter-spacing: 0; }
:root main > hgroup > time, :root main > time, .css-ckne1cw { display: block; font-family: var(--fb), system-ui, sans-serif; font-size: 0.8rem; color: rgba(0,0,0,0.45); margin-bottom: 32px; letter-spacing: 0.02em; }

:root main > article > p { margin-bottom: 18px; font-size: 16.5px; line-height: 1.75; }
:root main > article > h2 { font-family: var(--fh), cursive; font-size: 30px; font-weight: 700; color: var(--primary); margin: 2.5em 0 0.5em; padding-bottom: 6px; border-bottom: 2px dashed var(--accent); letter-spacing: 0; }
:root main > article > h3 { font-family: var(--fh), cursive; font-size: 22px; font-weight: 500; color: var(--accent); margin: 26px 0 10px; }
:root main > article ul, :root main > article ol { margin: 0 0 18px 24px; }
: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(224, 133, 66, .08); 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: 500; }
: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/"] { background: var(--accent); color: var(--bg); padding: 3px 12px; border-radius: var(--r); text-decoration: none; font-weight: 700; font-family: var(--fb), system-ui, sans-serif; font-size: 14px; letter-spacing: .03em; }
: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 { background: var(--primary); }

: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 16px rgba(10, 12, 18, .12); }

:root main > article > aside { background: rgba(31, 38, 48, .06); border-left: 4px solid var(--primary); border-radius: 0 var(--r) var(--r) 0; padding: 14px 20px; margin: 36px 0 0; font-size: 13.5px; color: var(--fg); font-family: var(--fb), system-ui, sans-serif; font-style: italic; }

:root main > div:has(> h2) { background: var(--bg); border: 1.5px solid var(--border); border-left: 4px solid var(--accent); border-radius: 0 var(--r) var(--r) 0; padding: 22px 24px; margin-bottom: 22px; box-shadow: 0 1px 5px rgba(10, 12, 18, .04); transition: transform .15s ease, box-shadow .15s ease, border-left-color .15s ease; }
:root main > div:has(> h2):hover { transform: translateY(-2px); box-shadow: 0 4px 14px rgba(10, 12, 18, .10); border-left-color: var(--primary); }
:root main > 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:has(> h2) > h2 { font-family: var(--fh), cursive; font-size: 26px; font-weight: 700; margin-bottom: 8px; line-height: 1.16; letter-spacing: 0; }
: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), system-ui, sans-serif; font-size: 14.5px; color: var(--fg); opacity: .82; margin-bottom: 12px; }
:root main > div:has(> h2) > a:last-child { font-family: var(--fb), system-ui, sans-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: 1px solid var(--accent); }
:root main > div:has(> ul) > h3 { font-family: var(--fh), cursive; font-size: 22px; color: var(--primary); margin-bottom: 16px; font-weight: 500; }
: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), system-ui, sans-serif; font-size: 15px; 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: 24px 0 36px; margin-top: 56px; text-align: center; font-family: var(--fb), system-ui, sans-serif; font-size: 12px; color: var(--fg); opacity: .60; letter-spacing: .04em; }
: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-11T14:30:05.778705+00:00) === */

.css-lsrmu8h { padding-bottom: 2em; border-bottom: 1px solid rgba(0,0,0,0.08); margin-bottom: 2em; }

.crd-related-list { background: rgba(0,0,0,0.04); border-radius: 4px; padding: 1em 1.25em; display: flex; flex-direction: column; gap: 0.4em; }

header h1 { font-size: 1.6rem; font-weight: 700; letter-spacing: -0.02em; }

/* === R3 fixes (2026-06-11T15:10:05.360182+00:00) === */

/* Button: warm dark-brown replaces saturated blue/violet */
.bld-card a[class*='btn'],
article a[class*='read'],
[class*='card'] a[class*='button'],
a[class*='btn-primary'] {
  background-color: #4a3728;
  color: #FAF6EF;
  border-radius: 3px;
  font-size: 0.85rem;
  letter-spacing: 0.03em;
}

/* List items: scannable rhythm with subtle dividers */
.bld-content ul li,
article ul li {
  padding-top: 0.35em;
  padding-bottom: 0.35em;
  border-bottom: 1px solid rgba(0,0,0,0.07);
}

/* H3: uppercase-small label — clear hierarchy vs H2 without extra size */
:root main article h3 {
  font-size: 0.95rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(0,0,0,0.55);
  margin-top: 1.8em;
  margin-bottom: 0.4em;
}

/* First paragraph: slightly dominant entry pulls the reader in */
.bld-content > p:first-of-type,
article > .bld-content p:first-child {
  font-size: 1.1rem;
  line-height: 1.85;
  color: rgba(0,0,0,0.8);
}

/* Breathing room after inline images */
.bld-content img + p,
article img + p {
  margin-top: 1.5em;
}

/* === R4 fixes (2026-06-11T15:50:05.549538+00:00) === */

/* CTA button: dark-brown from beige palette, not alien template-blue */
.css-6io08lr {
  background-color: #3d2b1a;
  color: #FAF6EF;
  border-radius: 3px;
  font-size: 0.83rem;
  letter-spacing: 0.04em;
  padding: 0.45em 1.1em;
}

/* Related-articles box: blends into page as quiet article appendix */
.css-bv2okf4 {
  background-color: #ece4d4;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 4px;
  padding: 1.25em 1.5em;
  margin-top: 2.5em;
}

/* Related links: warm-brown editorial links, not ad-like blue CTAs */
.crd-related-link {
  color: #3d2b1a;
  text-decoration: underline;
  text-decoration-color: rgba(61,43,26,0.3);
  font-size: 0.9rem;
  line-height: 1.75;
  display: block;
  padding: 0.2em 0;
}

/* Opening paragraph: visual priority matches its role as scene-setter */
article > p:first-of-type {
  font-size: 1.08rem;
  line-height: 1.87;
  color: rgba(0,0,0,0.82);
}

/* List items: scannable rhythm for between-standup reading */
article ul li,
article ol li {
  padding-top: 0.28em;
  padding-bottom: 0.28em;
  border-bottom: 1px solid rgba(0,0,0,0.05);
}
