/* Silicon Valley Building Service & Repair — design system
   "Warm Title-Block": warm paper, architectural accents, brick red, serif body. */

:root{
  --ink:#26211B; --ink-soft:#4a4138; --warm-dk:#2A2219;
  --paper:#F5F0E6; --paper-2:#ECE3D2; --card:#FCFAF4;
  --brick:#9E3B27; --brick-dk:#7e2e1d; --honey:#C2853B; --sage:#6E7657;
  --line:#DACFB9; --line-dk:#c5b89c; --muted:#6E6456; --muted-2:#9a8f7d;
  --display:'Archivo',system-ui,sans-serif; --serif:'Newsreader',Georgia,serif; --mono:'Spline Sans Mono',monospace;
  --wrap:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--serif);color:var(--ink);background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 32px}
.mono{font-family:var(--mono);text-transform:uppercase;letter-spacing:.17em;font-size:11px;font-weight:500}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ---------- title bar + nav ---------- */
.titlebar{background:var(--warm-dk);color:var(--paper)}
.titlebar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.titlebar .mono{color:var(--muted-2);font-size:10.5px}
.titlebar .mono b{color:var(--paper);font-weight:500}
.titlebar a:hover b{color:var(--honey)}

nav.site{background:var(--paper);position:sticky;top:0;z-index:40;border-bottom:1px solid var(--line)}
nav.site .wrap{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:var(--display);font-weight:700;font-size:17px;letter-spacing:-.01em;display:flex;align-items:center;gap:11px;color:var(--ink)}
.brand .mark{width:32px;height:32px;background:var(--brick);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--paper)}
.brand small{display:block;font-family:var(--mono);font-size:8.5px;letter-spacing:.13em;color:var(--muted);font-weight:400;margin-top:1px}
.logoimg{height:48px;width:auto;display:block}
@media(max-width:680px){.logoimg{height:40px}}
.navlinks{display:flex;gap:28px;font-family:var(--display);font-size:14.5px;font-weight:500;align-items:center}
.navlinks>li{position:relative;list-style:none}
.navlinks a{color:var(--ink-soft);padding:8px 0;display:inline-block}
.navlinks a:hover,.navlinks a[aria-current]{color:var(--brick)}
.navlinks .has>a::after{content:" ›";color:var(--muted-2)}
.submenu{position:absolute;top:100%;left:-14px;background:var(--card);border:1px solid var(--line);border-radius:8px;padding:8px;min-width:210px;display:none;box-shadow:0 12px 30px rgba(38,33,27,.10)}
.navlinks>li.has:hover>.submenu,.navlinks>li.has:focus-within>.submenu{display:block}
/* nested region submenus (Service Areas) */
.submenu .has{position:relative}
.submenu .submenu{position:absolute;top:-9px;left:100%;margin-left:3px}
.submenu .has:hover>.submenu,.submenu .has:focus-within>.submenu{display:block}
.submenu li{list-style:none}
.submenu a{display:block;padding:8px 12px;border-radius:5px;font-size:14px;color:var(--ink)}
.submenu a:hover{background:var(--paper-2);color:var(--brick)}
.navcta{font-family:var(--display);font-weight:600;font-size:14px;color:var(--paper);padding:11px 17px;border-radius:5px;background:var(--brick);white-space:nowrap}
.navcta:hover{background:var(--brick-dk);color:var(--paper)}
.navtoggle{display:none;background:none;border:1px solid var(--muted);border-radius:6px;padding:8px 10px;font-size:18px;color:var(--ink);cursor:pointer}

/* ---------- buttons ---------- */
.btn{font-family:var(--display);font-weight:600;font-size:15px;padding:14px 24px;border-radius:5px;display:inline-flex;align-items:center;gap:9px;transition:.15s;cursor:pointer;border:none}
.btn-pri{background:var(--brick);color:var(--paper)}.btn-pri:hover{background:var(--brick-dk);color:var(--paper)}
.btn-sec{border:1.5px solid var(--muted);color:var(--ink);background:transparent}.btn-sec:hover{border-color:var(--ink);background:var(--card)}
.btn-light{background:var(--paper);color:var(--brick)}.btn-light:hover{background:#fff;color:var(--brick-dk)}

/* ---------- shared bits ---------- */
.eyebrow{color:var(--brick);font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;font-size:11.5px;font-weight:500;display:inline-flex;align-items:center;gap:12px;margin-bottom:20px}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--brick)}
.dim{display:flex;align-items:center;gap:16px;margin:0 0 36px}
.dim .ln{flex:1;height:1px;background:var(--line-dk);position:relative}
.dim .ln::before,.dim .ln::after{content:"";position:absolute;top:-4px;width:1px;height:9px;background:var(--line-dk)}
.dim .ln::before{left:0}.dim .ln::after{right:0}
.dim .lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.17em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
section{padding:72px 0}
.shead{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:36px;gap:24px;flex-wrap:wrap}
.shead h2{font-family:var(--display);font-weight:700;font-size:33px;letter-spacing:-.02em;line-height:1.1;max-width:15em}
.shead p{color:var(--muted);max-width:25em;font-size:16px}
h1,h2,h3{font-family:var(--display);letter-spacing:-.02em}

/* ---------- home hero ---------- */
.hero .wrap{display:grid;grid-template-columns:1.02fr 1fr;gap:54px;align-items:center;padding:62px 32px 68px}
.hero h1{font-weight:800;font-size:54px;line-height:1.03;margin-bottom:22px}
.hero h1 .em{color:var(--brick)}
.hero .sub{font-size:19px;line-height:1.62;color:var(--ink-soft);max-width:31em;margin-bottom:28px}
.btns{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.reassure{margin-top:20px;font-size:14.5px;color:var(--muted);display:flex;align-items:center;gap:8px}
.heroimg{position:relative}
.heroimg img{width:100%;height:440px;object-fit:cover;border-radius:8px;background:var(--paper-2)}
.heroimg .tag{position:absolute;left:18px;bottom:18px;background:var(--card);border:1px solid var(--line);border-radius:5px;padding:11px 15px;display:flex;gap:22px}
.heroimg .tag .k{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.heroimg .tag .v{font-family:var(--display);font-size:13.5px;font-weight:600}

/* ---------- service cards (home) ---------- */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc{background:var(--card);border:1px solid var(--line);border-radius:9px;overflow:hidden;transition:.15s;display:block}
.svc:hover{border-color:var(--line-dk);transform:translateY(-3px)}
.svc .ph{height:150px;width:100%;object-fit:cover;background:var(--paper-2)}
.svc .bd{padding:18px 18px 22px}
.svc .code{font-family:var(--mono);font-size:9.5px;letter-spacing:.15em;color:var(--brick);text-transform:uppercase;margin-bottom:9px}
.svc h3{font-weight:700;font-size:18px;margin-bottom:7px}
.svc p{font-size:14px;color:var(--muted);line-height:1.55}

/* ---------- family / team ---------- */
.family{background:var(--paper-2)}
.family .wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:center;padding:66px 32px}
.family h2{font-weight:700;font-size:32px;line-height:1.1;margin-bottom:18px}
.family p{font-size:17px;color:var(--ink-soft);margin-bottom:14px;line-height:1.62}
.family .sig{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--muted)}
.faces{display:flex;flex-wrap:wrap;gap:14px}
.face{width:calc(33.333% - 10px);text-align:center}
.face img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:center top;border-radius:8px;border:1px solid var(--line);background:var(--card)}
.face .nm{font-family:var(--display);font-weight:600;font-size:13px;margin-top:9px}
.face .rl{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:2px}

/* ---------- process phases ---------- */
.phases{display:grid;grid-template-columns:repeat(4,1fr);border-top:2px solid var(--ink)}
.phase{padding:24px 22px 4px;border-right:1px solid var(--line)}
.phase:last-child{border-right:none}
.phase .num{font-family:var(--mono);font-size:30px;font-weight:500;color:var(--brick);line-height:1;margin-bottom:15px}
.phase h3{font-weight:700;font-size:17px;margin-bottom:7px}
.phase p{font-size:14px;color:var(--muted);line-height:1.55}

/* ---------- spec / trust strip ---------- */
.specwrap{background:var(--warm-dk);color:var(--paper)}
.specwrap .wrap{padding:58px 32px}
.specwrap .dim .ln,.specwrap .dim .ln::before,.specwrap .dim .ln::after{background:rgba(245,240,230,.25)}
.specwrap .dim .lbl{color:var(--muted-2)}
.spec{display:grid;grid-template-columns:repeat(4,1fr)}
.spec div{padding:6px 24px 6px 0}
.spec .k{font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--honey);margin-bottom:9px}
.spec .v{font-family:var(--display);font-weight:600;font-size:19px;line-height:1.2;color:var(--paper);margin-bottom:4px}
.spec .n{font-size:13.5px;color:var(--muted-2)}

/* ---------- proof ---------- */
.proof{text-align:center;max-width:780px;margin:0 auto}
.proof p{font-family:var(--serif);font-size:25px;line-height:1.45}
.proof .by{font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:22px}

/* ---------- cta band ---------- */
.cta{background:var(--brick);color:var(--paper)}
.cta .wrap{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:50px 32px;flex-wrap:wrap}
.cta h2{font-weight:700;font-size:29px;color:var(--paper)}
.cta .ph{font-family:var(--serif);font-size:15.5px;color:rgba(245,240,230,.85);margin-top:8px}
.cta .ph b{color:var(--paper);font-weight:600}

/* related-guide strip (internal linking) */
.relstrip{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.relstrip .wrap{padding:24px 32px}
.relstrip p{font-size:16px;color:var(--ink-soft);margin:0}
.relstrip a{color:var(--brick);font-weight:600}

/* sticky mobile call / estimate bar */
.mobilecta{display:none}
@media(max-width:680px){
  .mobilecta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;gap:1px;background:var(--line-dk);box-shadow:0 -4px 18px rgba(38,33,27,.16)}
  .mobilecta a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 8px;font-family:var(--display);font-weight:600;font-size:15px}
  .mobilecta .call{background:var(--card);color:var(--brick)}
  .mobilecta .est{background:var(--brick);color:var(--paper)}
  body{padding-bottom:54px}
}

/* ---------- footer ---------- */
footer.site{background:var(--warm-dk);color:var(--muted-2)}
footer.site .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding:54px 0 36px}
footer.site h4{font-family:var(--mono);font-size:10.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--honey);margin-bottom:14px;font-weight:500}
footer.site a{color:rgba(245,240,230,.78);font-size:14px;display:block;padding:4px 0}
footer.site a:hover{color:var(--paper)}
footer.site .fbrand{font-family:var(--display);font-weight:700;font-size:18px;color:var(--paper);margin-bottom:10px}
footer.site .fbrand+p{font-size:14px;line-height:1.6;max-width:26em}
footer.site .bottom{border-top:1px solid rgba(245,240,230,.12);padding:18px 0;display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;flex-wrap:wrap;gap:10px}

/* ---------- interior page hero ---------- */
.phero{border-bottom:1px solid var(--line)}
.phero .wrap{padding:54px 32px 48px}
.phero .crumbs{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:18px}
.phero .crumbs a:hover{color:var(--brick)}
.phero h1{font-weight:800;font-size:46px;line-height:1.05;max-width:16em;margin-bottom:18px}
.phero .lead{font-size:19px;color:var(--ink-soft);max-width:40em;line-height:1.6}

/* split hero for service pages (text + image) */
.shero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:56px 32px}
.shero h1{font-weight:800;font-size:44px;line-height:1.06;margin-bottom:18px}
.shero .lead{font-size:18px;color:var(--ink-soft);line-height:1.6;margin-bottom:26px}
.shero img{width:100%;height:400px;object-fit:cover;border-radius:8px;background:var(--paper-2)}

/* ---------- article / prose (guides, service body, about, process) ---------- */
.article{padding:64px 0}
.article .wrap{max-width:var(--wrap)}            /* full centered wrap so the column's left edge matches the hero */
.article .wrap>*{max-width:760px}                /* prose kept to a readable measure, left-aligned to the hero edge */
.article h2{font-weight:700;font-size:27px;margin:38px 0 14px;line-height:1.15}
.article h2:first-child{margin-top:0}
.article h3{font-weight:700;font-size:19px;margin:26px 0 8px}
.article p{font-size:17.5px;line-height:1.72;margin-bottom:18px;color:var(--ink-soft)}
.article p strong,.article li strong{color:var(--ink);font-weight:600}
.article ul{margin:0 0 20px;padding-left:0;list-style:none}
.article ul li{font-size:17px;line-height:1.65;color:var(--ink-soft);padding-left:26px;position:relative;margin-bottom:10px}
.article ul li::before{content:"";position:absolute;left:0;top:12px;width:12px;height:1px;background:var(--brick)}
.article .callout{background:var(--paper-2);border-left:3px solid var(--brick);border-radius:0;padding:20px 24px;margin:28px 0;font-size:16.5px}
.article .srcnote{font-size:13.5px;color:var(--muted);font-style:italic;margin:4px 0 14px;line-height:1.55}
/* body/prose links read as links — brand accent + underline on hover/focus */
.article p a,.article ul li a,.article .callout a{color:var(--brick);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:var(--line-dk)}
.article p a:hover,.article ul li a:hover,.article .callout a:hover,.article p a:focus-visible,.article ul li a:focus-visible{color:var(--brick-dk);text-decoration-color:var(--brick)}
.article .srclist li{font-size:13.5px;color:var(--muted);line-height:1.55}
.article .srclist a{color:var(--brick)}
.article .callout .mono{display:block;color:var(--brick);margin-bottom:6px}
/* service-area pages: full-width intro that lines up edge-to-edge with the sections above/below */
.cityintro .wrap{max-width:var(--wrap)}
.cityintro .wrap>*{max-width:none}               /* city intro fills full width (2-col), overrides the prose cap */
.cityintro .lede{display:grid;grid-template-columns:1fr 1fr;gap:8px 44px}
.cityintro .lede p{margin-bottom:0}
@media(max-width:760px){.cityintro .lede{grid-template-columns:1fr;gap:14px}}
/* city pages: tighter vertical rhythm — many stacked sections, so trim the air between them */
.citypage section{padding:46px 0}
.citypage .article{padding:46px 0}
.citypage .specwrap .wrap{padding:42px 32px}
.citypage .dim{margin-bottom:26px}
.cityintro .creds{margin:22px 0 0;font-size:18px;line-height:1.5;color:var(--ink)}
.cityintro .creds b{color:var(--brick);font-weight:600}

/* feature list (service pages) */
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.features .f{background:var(--card);padding:24px 24px}
.features .f .mono{color:var(--brick);display:block;margin-bottom:10px}
.features .f h3{font-weight:700;font-size:18px;margin-bottom:6px}
.features .f p{font-size:14.5px;color:var(--muted);line-height:1.55}

/* ---------- location grid (service areas list) ---------- */
.loclist{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.loccard{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:18px 20px;transition:.15s}
.loccard:hover{border-color:var(--brick);transform:translateY(-2px)}
.loccard .mono{color:var(--brick);display:block;margin-bottom:8px}
.loccard h3{font-weight:700;font-size:17px;margin-bottom:4px}
.loccard p{font-size:13.5px;color:var(--muted)}

/* blog */
.phero .postmeta{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.postcard{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:20px 22px;transition:.15s;display:block}
.postcard:hover{border-color:var(--brick);transform:translateY(-2px)}
.postcard .mono{color:var(--brick);display:block;margin-bottom:9px}
.postcard h3{font-weight:700;font-size:18px;line-height:1.25;margin-bottom:8px}
.postcard p{font-size:14px;color:var(--muted);line-height:1.55}

/* ---------- FAQ ---------- */
.faqs{max-width:820px;margin:0}  /* left-align FAQ with the hero/content edge */
.faq{border-bottom:1px solid var(--line)}
.faq summary{font-family:var(--display);font-weight:600;font-size:18px;padding:20px 36px 20px 0;cursor:pointer;position:relative;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:18px;font-size:24px;color:var(--brick);font-family:var(--display)}
.faq[open] summary::after{content:"–"}
.faq .a{padding:0 0 22px;font-size:16.5px;color:var(--ink-soft);line-height:1.7;max-width:60em}

/* ---------- gallery (our work) ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery figure{position:relative;border-radius:8px;overflow:hidden;background:var(--paper-2)}
.gallery img{width:100%;height:260px;object-fit:cover}
.gallery figcaption{position:absolute;left:0;bottom:0;right:0;padding:14px 16px;background:linear-gradient(transparent,rgba(38,33,27,.82));color:var(--paper);font-family:var(--display);font-weight:600;font-size:14px}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-info .row{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line)}
.contact-info .row .ic{color:var(--brick);font-size:20px;margin-top:2px}
.contact-info .k{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.contact-info .v{font-size:17px}
.form{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:28px}
.form label{display:block;font-family:var(--display);font-weight:600;font-size:13px;margin:14px 0 6px}
.form label:first-child{margin-top:0}
.form input,.form textarea,.form select{width:100%;font-family:var(--serif);font-size:15px;padding:11px 13px;border:1px solid var(--muted);border-radius:6px;background:var(--paper);color:var(--ink)}
.form input:focus,.form textarea:focus,.form select:focus{outline:2px solid var(--brick);border-color:var(--brick)}
.form .note{font-size:13px;color:var(--muted);margin-top:14px}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero .wrap,.family .wrap,.shero .wrap,.contact-grid{grid-template-columns:1fr;gap:34px}
  .hero .wrap{padding:42px 24px 48px}
  .hero h1{font-size:40px}.phero h1{font-size:36px}.shero h1{font-size:34px}
  .grid4{grid-template-columns:1fr 1fr}
  .phases,.spec{grid-template-columns:1fr 1fr}
  .phase:nth-child(2){border-right:none}.phase:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .features,.loclist,.gallery{grid-template-columns:1fr 1fr}
  footer.site .top{grid-template-columns:1fr 1fr}
  .wrap{padding:0 24px}
}
@media(max-width:680px){
  .navlinks{display:none}.navtoggle{display:block}
  nav.site.open .navlinks{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:var(--card);border-bottom:1px solid var(--line);padding:12px 24px;gap:6px;align-items:stretch}
  nav.site.open .submenu{display:block;position:static;border:none;box-shadow:none;padding:4px 0 4px 14px;background:transparent}
  .grid4,.features,.loclist,.gallery,.phases,.spec{grid-template-columns:1fr}
  .phase{border-right:none;border-bottom:1px solid var(--line)}
  .titlebar{display:none}
  .proof p{font-size:21px}.hero h1{font-size:34px}
}

/* honor reduced-motion: no hover lifts or transitions for users who ask for less motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{transition:none!important;animation:none!important}
  .svc:hover,.loccard:hover,.postcard:hover{transform:none}
}

/* ---------- accessibility ---------- */
/* skip-to-content link: off-screen until keyboard-focused (WCAG 2.4.1) */
.skip{position:absolute;left:-9999px;top:0;z-index:100;background:var(--brick);color:var(--paper);padding:10px 16px;font-family:var(--display);font-weight:600;border-radius:0 0 5px 0}
.skip:focus{left:0}
#main:focus{outline:none}
.form .opt{color:var(--muted);font-weight:400;font-size:13px}

/* keep focus/scroll targets clear of the sticky bars (WCAG 2.4.11) */
html{scroll-padding-top:88px}
@media(max-width:680px){html{scroll-padding-bottom:64px}}
/* visible keyboard focus everywhere (WCAG 2.4.7); brick = 5.95:1 on paper */
:focus-visible{outline:2px solid var(--brick);outline-offset:2px;border-radius:2px}
.btn-light:focus-visible,.navcta:focus-visible,.btn-pri:focus-visible{outline-color:var(--paper)}
footer.site a:focus-visible{outline-color:var(--honey)}

/* ---------- financing nudge: make links inside .reassure read as links ---------- */
.reassure a{color:var(--brick);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}
.reassure a:hover,.reassure a:focus-visible{color:var(--brick-dk)}

/* ---------- instant ballpark estimator ---------- */
.estbox{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:28px;max-width:760px}
.estfield{margin-bottom:26px}
.estfield>.lbl{font-family:var(--display);font-weight:600;font-size:14px;margin:0 0 11px;display:block}
.estfield .hint{font-size:13px;color:var(--muted);margin-top:9px;line-height:1.5}
.optrow{display:flex;flex-wrap:wrap;gap:10px}
.opt input{position:absolute;opacity:0;width:1px;height:1px}
.opt label{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:1.5px solid var(--line-dk);border-radius:6px;font-family:var(--display);font-weight:500;font-size:14px;cursor:pointer;background:var(--paper);color:var(--ink-soft);transition:.15s}
.opt input:checked+label{border-color:var(--brick);background:var(--brick);color:var(--paper)}
.opt input:focus-visible+label{outline:2px solid var(--brick);outline-offset:2px}
.estnum{width:170px;font-family:var(--serif);font-size:16px;padding:11px 13px;border:1px solid var(--muted);border-radius:6px;background:var(--paper);color:var(--ink)}
.estnum:focus{outline:2px solid var(--brick);border-color:var(--brick)}
.estresult{background:var(--paper-2);border-left:3px solid var(--brick);padding:22px 24px;margin:6px 0 0}
.estresult .rlbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);display:block;margin-bottom:8px}
.estresult .num{font-family:var(--display);font-weight:800;font-size:34px;letter-spacing:-.02em;color:var(--ink);line-height:1.1}
.estresult .det{font-size:14.5px;color:var(--ink-soft);margin-top:8px;line-height:1.5}
.estresult .fin{font-size:14px;margin-top:12px}
.estresult .fin a{color:var(--brick);text-decoration:underline;text-underline-offset:2px}
.estdisc{font-size:13px;color:var(--muted);line-height:1.6;margin-top:16px}
@media(max-width:680px){.estbox{padding:22px}.estresult .num{font-size:28px}}

/* ---------- lead-capture popup (budget worksheet) ---------- */
.lcp-overlay{position:fixed;inset:0;background:rgba(38,33,27,.55);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .2s ease}
.lcp-overlay.show{opacity:1}
.lcp{background:var(--card);border:1px solid var(--line);border-radius:12px;max-width:450px;width:100%;padding:32px 30px;position:relative;box-shadow:0 24px 64px rgba(38,33,27,.32)}
.lcp .eyb{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);display:block;margin-bottom:12px}
.lcp h2{font-family:var(--display);font-weight:700;font-size:24px;line-height:1.12;letter-spacing:-.02em}
.lcp p{font-size:15px;color:var(--ink-soft);margin:10px 0 18px;line-height:1.55}
.lcp input[type=email]{width:100%;font-family:var(--serif);font-size:15px;padding:12px 13px;border:1px solid var(--muted);border-radius:6px;background:var(--paper);color:var(--ink);margin-bottom:12px}
.lcp input[type=email]:focus{outline:2px solid var(--brick);border-color:var(--brick)}
.lcp .btn{width:100%;justify-content:center}
.lcp .fine{font-size:12px;color:var(--muted);margin-top:12px;line-height:1.5}
.lcp-close{position:absolute;top:10px;right:12px;background:none;border:none;font-size:24px;line-height:1;color:var(--muted);cursor:pointer;padding:6px;font-family:var(--display)}
.lcp-close:hover{color:var(--brick)}
@media(prefers-reduced-motion:reduce){.lcp-overlay{transition:none}}

/* ---------- printable worksheet ---------- */
.checklist{list-style:none;margin:0 0 22px;padding:0}
.checklist li{display:flex;gap:12px;align-items:flex-start;padding:8px 0;font-size:16.5px;color:var(--ink-soft);line-height:1.55}
.checklist li::before{display:none}
.checklist input[type=checkbox]{width:18px;height:18px;margin-top:4px;flex:0 0 auto;accent-color:var(--brick)}
.budtable{width:100%;border-collapse:collapse;margin:8px 0 24px;font-size:15.5px}
.budtable th,.budtable td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}
.budtable th{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:500}
.budtable td:last-child,.budtable th:last-child{text-align:right;white-space:nowrap}
.budtable tfoot td{font-weight:600;color:var(--ink);border-top:2px solid var(--ink);border-bottom:none}
.wsline{border:1px dashed var(--line-dk);border-radius:6px;min-height:34px;margin:6px 0}
.printbtn{margin:0 0 8px}
@media print{
  #site-header,#site-footer,.mobilecta,.lcp-overlay,.printbtn,.cta,.relstrip,.crumbs{display:none!important}
  body{background:#fff;color:#000;font-size:12pt;padding:0}
  .article{padding:0}
  .phero{border:none}
  .phero .wrap,.article .wrap{padding:0;max-width:100%}
  .article .wrap>*{max-width:100%}
  .checklist input[type=checkbox]{-webkit-appearance:none;appearance:none;border:1.5px solid #000;width:16px;height:16px}
  a{color:#000;text-decoration:none}
  .callout{border-left:3px solid #000;background:#f3f3f3}
}
