/* BuildCalc — design tokens from projects/concrete-calculator/06-design.md */
:root{
  --bg:#fff; --surface:#f4f5f7; --ink:#1b1f24; --muted:#5b6471;
  --line:#e2e5ea; --brand:#1f4e79; --brand-d:#163a5c; --accent:#f08c00; --ok:#1e7d4f;
  --maxw:860px; --maxw-hub:1040px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font:16px/1.6 system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:34px;line-height:1.2;font-weight:700;margin:.2em 0 .3em}
h2{font-size:22px;font-weight:600;margin:1.6em 0 .5em}
p{margin:.5em 0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px}
.wrap-hub{max-width:var(--maxw-hub);margin:0 auto;padding:0 16px}

/* header */
.site-header{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--line)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:16px;height:58px}
.brand{font-weight:700;font-size:19px;color:var(--ink)}
.brand b{color:var(--brand)}
.nav a{margin-left:16px;color:var(--muted);font-size:15px}
.nav a.active,.nav a:hover{color:var(--brand)}

/* hero */
.hero{padding:28px 0 8px}
.lead{font-size:18px;color:var(--muted);max-width:60ch}

/* calculator card */
.calc{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:20px;margin:18px 0}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:13px;color:var(--muted);font-weight:600}
.field input,.field select{
  padding:10px;border:1px solid var(--line);border-radius:6px;font-size:16px;background:#fff;color:var(--ink)
}
.row-inline{display:flex;gap:8px}
.btn{
  display:inline-block;margin-top:14px;padding:12px 22px;background:var(--brand);color:#fff;
  border:0;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer
}
.btn:hover{background:var(--brand-d)}

/* result */
.result{margin-top:16px;padding:16px;border-left:4px solid var(--accent);background:#fff;border-radius:6px;display:none}
.result.show{display:block}
.result .big{font-size:26px;font-weight:700;color:var(--ink)}
.result .big b{color:var(--accent)}
.result .sub{color:var(--muted);font-size:14px;margin-top:4px}
.result ul{margin:8px 0 0;padding-left:18px}

/* affiliate */
.affiliate{margin-top:14px;padding:12px;border:1px dashed var(--line);border-radius:6px;background:#fff;font-size:14px}
.affiliate a{font-weight:600}

/* tables */
table{border-collapse:collapse;width:100%;margin:.5em 0;font-size:15px}
th,td{border:1px solid var(--line);padding:8px 10px;text-align:left}
th{background:var(--surface)}

/* faq */
.faq details{border:1px solid var(--line);border-radius:6px;margin:8px 0;padding:0 14px;background:#fff}
.faq summary{cursor:pointer;font-weight:600;padding:12px 0}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq details p{padding:10px 0}

/* hub cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:20px 0}
.card{border:1px solid var(--line);border-radius:8px;padding:18px;background:#fff;transition:box-shadow .15s}
.card:hover{box-shadow:0 2px 8px rgba(0,0,0,.07)}
.card h3{margin:.2em 0;color:var(--brand)}
.card p{color:var(--muted);font-size:14px;margin:.3em 0 0}
.why{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:14px 0}
.why div{background:var(--surface);border-radius:8px;padding:14px;font-size:15px}

/* footer */
.site-footer{margin-top:40px;border-top:1px solid var(--line);background:var(--surface)}
.site-footer .wrap-hub{padding:20px 16px}
.disclaimer{font-size:13px;color:var(--muted);max-width:80ch}
.foot-links{margin-top:10px;font-size:14px}
.foot-links a{margin-right:14px;color:var(--muted)}

@media(max-width:560px){
  h1{font-size:27px}
  .grid{grid-template-columns:1fr}
  .nav a{margin-left:10px;font-size:14px}
}
