:root{
  --paper:#FAF5EC; --paper-2:#F3EBDC; --card:#FFFCF6;
  --ink:#241F1A; --ink-soft:#5A5147; --line:#E0D6C4;
  --accent:#1E4A38; --accent-soft:#2C6A4F; --gold:#B5832E; --gold-soft:#D8A94A; --rose:#9C4A33; --sky:#3F6B7A;
  --shadow:0 1px 2px rgba(40,30,15,.04),0 8px 30px rgba(40,30,15,.07);
  --shadow-lg:0 2px 6px rgba(40,30,15,.06),0 24px 60px rgba(40,30,15,.13);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:"Newsreader",Georgia,serif;font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(1100px 600px at 85% -10%,rgba(216,169,74,.10),transparent 60%),radial-gradient(900px 600px at -10% 15%,rgba(30,74,56,.06),transparent 55%);background-attachment:fixed;}
.wrap{max-width:1080px;margin:0 auto;padding:0 26px}
h1,h2,h3,legend,.brand{font-family:"Fraunces",Georgia,serif;font-weight:600;line-height:1.07;letter-spacing:-.01em}
em{font-style:italic}
a{color:var(--accent)}
.kicker{text-transform:uppercase;letter-spacing:.26em;font-size:.7rem;color:var(--ink-soft);font-weight:500}
.topbar{position:sticky;top:0;z-index:20;background:rgba(250,245,236,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:58px}
.brand{font-size:1.1rem}.brand span{color:var(--gold)}
.tnav{display:flex;align-items:center;gap:20px}.tnav a{text-decoration:none;color:var(--ink-soft);font-size:.93rem}.tnav a:hover{color:var(--accent)}
@media(max-width:640px){.tnav .ghlink{display:none}}
.sharebtn{font-family:"Newsreader",serif;font-size:.85rem;color:var(--ink-soft);background:transparent;border:1px solid var(--line);border-radius:999px;padding:6px 14px;cursor:pointer}
.sharebtn:hover{border-color:var(--gold);color:var(--accent)}
.sharebtn.copied{border-color:var(--accent);color:var(--accent)}
.hero{padding:64px 0 18px;max-width:760px}
.hero h1{font-size:clamp(2.4rem,6vw,4.2rem);margin:.1em 0 .25em}
.hero .sub{color:var(--ink-soft);font-size:1.12rem}
section{padding:38px 0}
.shead{margin-bottom:22px;max-width:760px}
.shead h2{font-size:clamp(1.7rem,3.6vw,2.4rem);margin:.12em 0 .2em}
.shead p{color:var(--ink-soft);margin:0}
/* calculator */
.calc-grid{display:grid;grid-template-columns:380px 1fr;gap:24px;align-items:start}
@media(max-width:860px){.calc-grid{grid-template-columns:1fr}}
.inputs fieldset{border:1px solid var(--line);border-radius:14px;padding:14px 16px 16px;margin:0 0 14px;background:var(--card)}
.inputs legend{padding:0 8px;font-size:.95rem;color:var(--accent)}
.inputs label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:var(--ink-soft);margin:8px 0}
.inputs input{font-family:"Fraunces",serif;font-weight:600;font-size:1.05rem;color:var(--ink);padding:8px 10px;border:1px solid var(--line);border-radius:9px;background:var(--paper)}
.inputs input:focus{outline:2px solid var(--gold-soft);outline-offset:1px}
.reset{font-family:"Newsreader",serif;font-size:.9rem;color:var(--ink-soft);background:transparent;border:1px solid var(--line);border-radius:999px;padding:8px 16px;cursor:pointer}
.reset:hover{border-color:var(--gold);color:var(--accent)}
.results{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:var(--shadow-lg)}
.metricbig{display:flex;flex-direction:column;gap:2px;margin-bottom:8px}
.metricbig .k{color:var(--ink-soft);font-size:.9rem}
.metricbig .v{font-family:"Fraunces",serif;font-weight:600;font-size:2.6rem;color:var(--accent);line-height:1}
.rrow{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:10px 0;border-top:1px solid var(--line);font-size:.98rem}
.rrow b{font-family:"Fraunces",serif;font-weight:600}
.verdict{margin:14px 0;border-radius:12px;padding:13px 15px;font-size:.98rem;line-height:1.5}
.verdict.good{background:rgba(30,74,56,.10);border:1px solid var(--accent-soft);color:var(--accent)}
.verdict.ok{background:rgba(181,131,46,.12);border:1px solid var(--gold);color:#7a5717}
.verdict.bad{background:rgba(156,74,51,.10);border:1px solid var(--rose);color:var(--rose)}
.micro{color:var(--ink-soft);font-size:.82rem;margin:.5em 0 0}
.about{color:var(--ink-soft);max-width:780px}
svg .gl{stroke:var(--line);stroke-width:1;stroke-dasharray:3 5;opacity:.7}
svg .axis{stroke:var(--line)}
svg text{font-family:"Newsreader",serif;fill:var(--ink-soft);font-size:13px}
svg .mk{font-family:"Fraunces",serif;font-weight:600;fill:var(--ink)}
/* filters + explorer */
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.filters button{font-family:"Newsreader",serif;font-size:.9rem;color:var(--ink-soft);background:transparent;border:1px solid var(--line);padding:7px 14px;border-radius:999px;cursor:pointer}
.filters button:hover{border-color:var(--gold-soft)}
.filters button.active{background:var(--accent);border-color:var(--accent);color:#F4EEDF}
.egrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:900px){.egrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.egrid{grid-template-columns:1fr}}
.ec{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow);cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s}
.ec:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--gold-soft)}
.ec:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.ec .flag{font-size:1.5rem}.ec h3{font-size:1.08rem;margin:6px 0 2px}
.ec .pr{font-family:"Fraunces",serif;font-weight:600;font-size:1.5rem;color:var(--accent)}.ec .pr small{font-size:.5em;color:var(--ink-soft);font-weight:400}
.ec .tag{font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);background:var(--paper-2);border-radius:999px;padding:3px 9px;display:inline-block;margin-top:9px}
.ec .tag.snow{color:var(--sky);background:rgba(63,107,122,.13)}
.ec .view{margin-top:9px;font-size:.8rem;color:var(--gold);font-style:italic}
/* planner */
.planner{display:grid;grid-template-columns:1.25fr 1fr;gap:0;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);overflow:hidden}
@media(max-width:840px){.planner{grid-template-columns:1fr}}
.pleft{padding:24px;border-right:1px solid var(--line)}
@media(max-width:840px){.pleft{border-right:none;border-bottom:1px solid var(--line)}}
.pright{padding:24px;background:var(--paper-2)}
.addrow{display:flex;gap:8px;margin-bottom:14px}
.addrow select{flex:1;font-family:"Newsreader",serif;font-size:.95rem;padding:10px;border:1px solid var(--line);border-radius:10px;background:var(--paper);color:var(--ink)}
.addrow button{font-family:"Fraunces",serif;font-weight:600;background:var(--gold);color:#fff;border:none;border-radius:10px;padding:0 18px;cursor:pointer}
.addrow button:hover{background:#9a6f22}
.leg{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.leg .nm{flex:1;font-size:.95rem}.leg .nm small{display:block;color:var(--ink-soft);font-size:.78rem}
.stepper{display:flex;align-items:center;gap:5px}
.stepper button{width:27px;height:27px;border-radius:7px;border:1px solid var(--line);background:var(--paper);font-size:1.05rem;line-height:1;cursor:pointer}
.stepper button:hover{border-color:var(--gold)}
.stepper .mo{width:50px;text-align:center;font-family:"Fraunces",serif;font-weight:600;font-size:.92rem}
.leg .cost{width:60px;text-align:right;font-family:"Fraunces",serif;font-weight:600;color:var(--accent)}
.leg .rm{background:none;border:none;color:var(--ink-soft);cursor:pointer;font-size:1rem}.leg .rm:hover{color:var(--rose)}
.empty{color:var(--ink-soft);font-style:italic;padding:14px 0}
.monthbar{height:11px;border-radius:999px;background:var(--paper-2);overflow:hidden;margin:14px 0 4px;border:1px solid var(--line)}
.monthbar i{display:block;height:100%;width:0;background:var(--accent-soft);transition:width .3s,background .3s}
.monthbar i.over{background:var(--rose)}
.monthlbl{font-size:.84rem;color:var(--ink-soft)}
.fixed{margin-top:16px}
.fixed label{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:9px 0;font-size:.9rem;color:var(--ink-soft)}
.fixed input{width:120px;font-family:"Fraunces",serif;font-weight:600;text-align:right;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink)}
.total{font-family:"Fraunces",serif;font-weight:700;font-size:2.8rem;color:var(--accent);line-height:1}
.totsub{color:var(--ink-soft);margin-bottom:14px}
/* modal */
.modal{position:fixed;inset:0;z-index:60;display:none;align-items:center;justify-content:center;padding:22px;background:rgba(28,22,14,.5);backdrop-filter:blur(6px)}
.modal.open{display:flex}
.modal-card{background:var(--paper);border:1px solid var(--line);border-radius:20px;max-width:860px;width:100%;max-height:92vh;overflow:auto;padding:32px;box-shadow:var(--shadow-lg);position:relative}
.mclose{position:absolute;top:15px;right:17px;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:var(--card);color:var(--ink-soft);font-size:1.25rem;cursor:pointer;line-height:1}
.mclose:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.meyebrow{font-family:"Fraunces",serif;font-style:italic;color:var(--gold)}
.modal-card h3{font-size:1.9rem;margin:.1em 0}
.modal-card .msub{color:var(--ink-soft);font-style:italic;margin-bottom:14px}
.mstats{display:flex;flex-wrap:wrap;gap:9px;margin:6px 0 14px}
.chip{flex:1 1 120px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:11px 13px}
.chip .k{display:block;color:var(--ink-soft);font-size:.78rem;margin-bottom:3px}
.chip .v{font-family:"Fraunces",serif;font-weight:600;font-size:1.35rem;color:var(--accent)}
footer{padding:36px 0 64px;color:var(--ink-soft);font-size:.84rem;border-top:1px solid var(--line);margin-top:24px}
