@import url('https://fonts.googleapis.com/css2?family=Newsreader:opsz,wght@6..72,400;6..72,500;6..72,600;6..72,700&family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#fbfbf9; --paper:#ffffff; --ink:#1a1a18; --ink-2:#44443e;
  --line:#e7e6e0; --line-2:#d8d7d0;
  --muted:#71706a; --dim:#a3a29a;
  --yellow:#f5c518; --yr:245,197,24;
  --gold:#9a7b0a;
  --accent:#1a1a18;
  --link:#1556c0;
  --r:8px; --pad:20px; --hdr:64px; --toc:240px; --maxw:1180px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;font-size:16px;line-height:1.75;color:var(--ink-2);background:var(--bg);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}

/* HEADER */
.hdr{position:sticky;top:0;z-index:100;height:var(--hdr);background:rgba(251,251,249,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.hdr__inner{max-width:var(--maxw);margin:0 auto;height:100%;padding:0 var(--pad);display:flex;align-items:center;gap:18px}
.hdr__logo{background:var(--ink);padding:6px 10px;border-radius:var(--r)}
.hdr__logo img{height:22px;width:auto}
.hdr__nav{display:none;list-style:none;flex:1;gap:2px}
.hdr__nav a{padding:8px 14px;border-radius:var(--r);font-size:13.5px;font-weight:600;color:var(--muted);transition:.15s}
.hdr__nav a:hover,.hdr__nav a.active{color:var(--ink);background:#f0efe9}
.hdr__cta{margin-left:auto;padding:9px 20px;border-radius:var(--r);background:var(--ink);color:#fff;font-weight:700;font-size:13px;white-space:nowrap;transition:.15s}
.hdr__cta:hover{background:#000}
.burger{width:40px;height:40px;border:1px solid var(--line-2);border-radius:var(--r);background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;margin-left:auto}
.burger__line{width:18px;height:2px;background:var(--ink);border-radius:2px}

.side{position:fixed;inset:0 0 0 auto;width:280px;z-index:200;background:#fff;border-left:1px solid var(--line);transform:translateX(100%);transition:transform .25s;padding:20px 0 40px}
.side.open{transform:translateX(0)}
.side__close{position:absolute;top:14px;right:16px;width:38px;height:38px;background:#f0efe9;border:none;border-radius:var(--r);cursor:pointer;display:grid;place-content:center}
.side__close::before,.side__close::after{content:'';position:absolute;width:15px;height:2px;background:var(--ink)}
.side__close::before{transform:rotate(45deg)}.side__close::after{transform:rotate(-45deg)}
.side nav{margin-top:58px;padding:0 14px}
.side nav a{display:flex;gap:10px;padding:13px 15px;border-radius:var(--r);font-weight:600;font-size:14.5px;color:var(--muted)}
.side nav a.active,.side nav a:hover{color:var(--ink);background:#f0efe9}
.overlay{position:fixed;inset:0;z-index:150;background:rgba(26,26,24,.4);display:none}
.overlay.show{display:block}

/* SHELL — content + right TOC */
.shell{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);display:flex;gap:48px;align-items:flex-start}
.page{flex:1;min-width:0;max-width:740px;padding:40px 0 80px}
.toc{display:none}
@media(min-width:1080px){
  .toc{display:block;width:var(--toc);flex-shrink:0;position:sticky;top:calc(var(--hdr) + 30px);padding:30px 0;max-height:calc(100vh - var(--hdr) - 40px);overflow-y:auto}
  .toc__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--dim);margin-bottom:14px}
  .toc__list{list-style:none}
  .toc__list a{display:block;padding:6px 0 6px 14px;border-left:2px solid var(--line);font-size:13px;color:var(--muted);transition:.15s;line-height:1.4}
  .toc__list a:hover{color:var(--ink);border-left-color:var(--yellow)}
  .toc__list a.active{color:var(--ink);border-left-color:var(--ink);font-weight:600}
}

/* HERO */
.hero{margin-bottom:30px;padding-bottom:28px;border-bottom:1px solid var(--line)}
.eyebrow{display:inline-block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);background:rgba(var(--yr),.14);padding:4px 12px;border-radius:999px;margin-bottom:16px}
.hero h1{font-family:'Newsreader',serif;font-size:clamp(28px,4.5vw,44px);font-weight:600;line-height:1.15;margin-bottom:16px;color:var(--ink);letter-spacing:-.01em}
.hero__meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px;font-size:13px;color:var(--dim)}
.hero__meta .avatar{width:30px;height:30px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-content:center;font-size:11px;font-weight:700}
.hero__meta .by{color:var(--ink);font-weight:600}
.hero__meta time{color:var(--muted)}
.hero__lead{font-size:18px;line-height:1.7;color:var(--ink-2)}
.lead-rest{display:none}.hero__lead.open .lead-rest{display:inline}
.lead-toggle{display:inline-block;margin-left:6px;background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;font-weight:700;color:var(--link);text-decoration:underline;text-underline-offset:3px}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:34px;background:var(--paper)}
@media(min-width:560px){.stats{grid-template-columns:repeat(3,1fr)}}
.stat{padding:18px 16px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat__val{font-family:'Newsreader',serif;font-size:26px;font-weight:600;color:var(--ink);line-height:1;margin-bottom:5px}
.stat__lbl{font-size:11.5px;color:var(--muted);font-weight:500}

/* SECTION */
.section{margin-bottom:36px;scroll-margin-top:calc(var(--hdr) + 20px)}
.section h2{font-family:'Newsreader',serif;font-size:clamp(21px,3vw,28px);font-weight:600;margin-bottom:14px;color:var(--ink);line-height:1.2;letter-spacing:-.01em}
.section h3{font-size:17px;font-weight:700;margin:22px 0 8px;color:var(--ink)}
.section p{margin-bottom:14px;color:var(--ink-2)}
.section p:last-child{margin-bottom:0}
.section strong{color:var(--ink);font-weight:600}
.section ul,.section ol{padding-left:22px;margin-bottom:14px}
.section li{margin-bottom:7px;color:var(--ink-2)}
.ilink{color:var(--link);text-decoration:underline;text-underline-offset:2px;font-weight:500}
.ilink:hover{text-decoration-thickness:2px}

/* TABLE */
.tbl-wrap{overflow-x:auto;margin:18px 0;border:1px solid var(--line);border-radius:var(--r)}
table{width:100%;border-collapse:collapse;font-size:14px}
th{background:#f4f3ee;color:var(--ink);font-weight:700;text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap;font-size:13px}
td{padding:11px 14px;border-bottom:1px solid var(--line);color:var(--ink-2)}
tr:last-child td{border-bottom:none}

/* FAQ */
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:18px 0;gap:12px;text-align:left;font-family:'Newsreader',serif;font-size:18px;font-weight:600;color:var(--ink)}
.faq__q:hover{color:var(--gold)}
.faq__icon{flex-shrink:0;width:24px;height:24px;display:grid;place-content:center;transition:.2s;font-size:18px;color:var(--gold);font-style:normal}
.faq__item.open .faq__icon{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .3s}
.faq__item.open .faq__a{max-height:900px}
.faq__a-inner{padding:0 0 18px;font-size:15.5px;color:var(--muted);line-height:1.75}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin:18px 0}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:18px;transition:.15s}
.card:hover{border-color:var(--line-2);box-shadow:0 4px 16px rgba(0,0,0,.04)}
.card__icon{font-size:24px;margin-bottom:10px}
.card__title{font-size:15px;font-weight:700;margin-bottom:5px;color:var(--ink)}
.card__text{font-size:13.5px;color:var(--muted);line-height:1.55}

/* STEPS */
.steps{counter-reset:s;display:flex;flex-direction:column;gap:0;margin:18px 0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.step{display:flex;gap:16px;background:var(--paper);padding:16px 18px;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:none}
.step__num{counter-increment:s;flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--yellow);color:var(--ink);display:grid;place-content:center;font-size:13px;font-weight:800;margin-top:2px}
.step__num::before{content:counter(s)}
.step__title{font-size:15px;font-weight:700;margin-bottom:3px;color:var(--ink)}
.step__text{font-size:14px;color:var(--muted)}

/* NOTICE */
.notice{background:rgba(var(--yr),.1);border:1px solid rgba(var(--yr),.3);border-radius:var(--r);padding:16px 18px;font-size:14.5px;color:var(--ink-2);margin:22px 0}
.notice strong{color:var(--gold)}

/* INTERNAL LINKS */
.internal-links{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0}
.internal-links a{padding:9px 16px;border-radius:999px;border:1px solid var(--line-2);background:var(--paper);font-size:13.5px;font-weight:600;color:var(--ink-2);transition:.15s}
.internal-links a:hover{border-color:var(--ink);color:var(--ink)}

/* BREADCRUMB */
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--dim);margin-bottom:22px;flex-wrap:wrap}
.breadcrumb a{color:var(--muted);font-weight:500}
.breadcrumb a:hover{color:var(--ink)}

/* FIGURE */
.article-figure{margin:24px 0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;line-height:0}
.article-figure img{width:100%}

/* ── CALCULATOR ── */
.calc{background:var(--paper);border:1px solid var(--line-2);border-radius:12px;padding:26px;margin:28px 0;box-shadow:0 6px 24px rgba(0,0,0,.04)}
.calc__head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.calc__title{font-family:'Newsreader',serif;font-size:22px;font-weight:600;color:var(--ink)}
.calc__badge{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--ink);background:var(--yellow);padding:4px 11px;border-radius:999px}
.calc__sub{font-size:14px;color:var(--muted);margin-bottom:22px}
.calc__field{margin-bottom:18px}
.calc__label{display:flex;justify-content:space-between;font-size:13.5px;font-weight:600;color:var(--ink-2);margin-bottom:8px}
.calc__input{width:100%;background:var(--bg);border:1.5px solid var(--line-2);border-radius:10px;padding:13px 15px;color:var(--ink);font-family:inherit;font-size:16px;font-weight:600}
.calc__input:focus{outline:none;border-color:var(--ink)}
.calc__range{width:100%;-webkit-appearance:none;height:6px;border-radius:3px;background:var(--line);outline:none;margin-top:10px}
.calc__range::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--yellow);cursor:pointer;border:3px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.calc__range::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--yellow);cursor:pointer;border:3px solid #fff}
.calc__select{width:100%;background:var(--bg);border:1.5px solid var(--line-2);border-radius:10px;padding:13px 15px;color:var(--ink);font-family:inherit;font-size:14.5px;font-weight:600;cursor:pointer}
.calc__select:focus{outline:none;border-color:var(--ink)}
.calc__results{margin-top:22px;border-top:1px solid var(--line);padding-top:20px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.calc__res{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:15px}
.calc__res-lbl{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px}
.calc__res-val{font-family:'Newsreader',serif;font-size:24px;font-weight:600;color:var(--ink);line-height:1.1}
.calc__res-val small{font-size:13px;color:var(--muted);font-weight:500;font-family:'Inter'}
.calc__res.wide{grid-column:1/-1}
.calc__res.accent{border-color:rgba(var(--yr),.5);background:rgba(var(--yr),.08)}
.calc__res.accent .calc__res-val{color:var(--gold)}
.calc__note{font-size:12px;color:var(--dim);margin-top:16px;line-height:1.6}

/* AUTHOR */
.author-section{margin:48px 0 28px;border-top:1px solid var(--line);padding-top:26px}
.author-section__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--dim);margin-bottom:16px}
.author-card{display:flex;gap:16px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:18px;max-width:380px}
.author-card__avatar{width:52px;height:52px;border-radius:50%;flex-shrink:0;display:grid;place-content:center;font-family:'Newsreader',serif;font-size:19px;font-weight:600;color:#fff;background:var(--ink)}
.author-card__name{font-size:15px;font-weight:700;color:var(--ink)}
.author-card__role{font-size:13px;color:var(--muted);margin-top:2px}
.author-card__date{font-size:12px;color:var(--dim);margin-top:4px}

/* FOOTER */
.ft{background:var(--paper);border-top:1px solid var(--line);padding:40px var(--pad) 26px;margin-top:30px}
.ft__inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:center}
.ft__logo{background:var(--ink);padding:6px 10px;border-radius:var(--r)}
.ft__logo img{height:20px}
.ft__nav{display:flex;flex-wrap:wrap;gap:8px 22px}
.ft__nav a{font-size:13.5px;color:var(--muted);font-weight:600}
.ft__nav a:hover{color:var(--ink)}
.ft__bottom{max-width:var(--maxw);margin:22px auto 0;display:flex;flex-wrap:wrap;gap:14px;align-items:center;border-top:1px solid var(--line);padding-top:20px}
.ft__logos{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.ft__logos img{height:24px;opacity:.5;transition:.15s}
.ft__logos img:hover{opacity:.85}
.ft__legal{flex:1;font-size:11.5px;color:var(--dim);line-height:1.6;max-width:600px}
.ft__copy{font-size:11.5px;color:var(--dim);width:100%;margin-top:4px}
p.disclaimer{font-size:13px;color:var(--dim);font-style:italic;margin-top:16px}

@media(min-width:768px){.hdr__nav{display:flex}.burger{display:none}}
