:root{
  --ink:#17191b;--ink2:#23262a;--steel:#5b636b;--paper:#f3f1ec;--white:#ffffff;
  --accent:#f4b81c;--accent-d:#d99e00;--muted:rgba(23,25,27,.66);--line:rgba(23,25,27,.14);
  --shadow:0 24px 80px rgba(23,25,27,.16);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);background:var(--paper);
  font-family:Archivo,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-family:"Source Serif 4",Georgia,serif;line-height:.98;letter-spacing:0}

/* header — white, real logo */
.topbar{position:sticky;top:0;z-index:20;min-height:78px;display:flex;align-items:center;
  justify-content:space-between;gap:22px;padding:10px clamp(18px,4vw,62px);
  background:var(--white);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;min-width:0}
.brand img{height:50px;width:auto}
nav{display:flex;align-items:center;gap:clamp(12px,2.1vw,26px);font-size:12px;font-weight:800;
  letter-spacing:.13em;text-transform:uppercase}
nav a.navlink{padding:6px 0;border-bottom:2px solid transparent;color:var(--ink)}
nav a.navlink:hover{color:var(--accent-d)}
nav a.navlink.active{border-bottom-color:var(--accent)}
.call-pill{min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0 18px;
  background:var(--accent);color:var(--ink);border:0;font-weight:900}
.call-pill:hover{background:var(--accent-d)}

/* sections */
.section{padding:clamp(56px,8vw,118px) clamp(20px,5vw,76px)}
.eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:var(--accent-d);
  font-size:12px;font-weight:900;letter-spacing:.2em;text-transform:uppercase}
.eyebrow::before{content:"";width:40px;height:3px;background:var(--accent)}
.eyebrow.on-dark{color:var(--accent)}
h2{color:var(--ink);font-size:clamp(38px,6vw,80px)}
.lead{margin:0;color:var(--muted);font-size:18px;line-height:1.65;max-width:62ch}
.section-head{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(280px,.7fr);
  gap:clamp(24px,5vw,68px);align-items:end;margin-bottom:34px}
.prose{max-width:70ch}
.prose p{color:var(--muted);font-size:18px;line-height:1.7}
.prose h3{color:var(--ink);font-size:26px;margin:30px 0 8px}
.prose strong{color:var(--ink)}

/* buttons */
.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.button{min-height:54px;display:inline-flex;align-items:center;justify-content:center;padding:0 24px;
  border:2px solid var(--ink);color:var(--ink);font-size:12px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}
.button:hover{background:var(--ink);color:var(--white)}
.button.primary{border-color:var(--accent);background:var(--accent);color:var(--ink)}
.button.primary:hover{background:var(--accent-d);border-color:var(--accent-d)}
.button.light{border-color:rgba(255,255,255,.6);color:var(--white)}
.button.light:hover{background:var(--white);color:var(--ink)}

/* home hero — charcoal, type-forward */
.hero{position:relative;overflow:hidden;padding:clamp(70px,10vw,120px) clamp(20px,5vw,76px) clamp(56px,7vw,92px);
  color:var(--white);background:
    radial-gradient(1200px 600px at 85% -10%,rgba(244,184,28,.14),transparent 60%),
    linear-gradient(180deg,#1c1f22,#141618)}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;background:var(--accent)}
.hero h1{max-width:15ch;font-size:clamp(46px,8vw,116px);color:var(--white)}
.hero p{max-width:60ch;margin:24px 0 0;color:rgba(255,255,255,.74);font-size:clamp(17px,2vw,22px);line-height:1.55}
.kicker{display:inline-block;margin-bottom:20px;padding:8px 14px;background:rgba(255,255,255,.08);
  border:1px solid rgba(244,184,28,.5);color:var(--accent);font-size:12px;font-weight:900;letter-spacing:.2em;text-transform:uppercase}
.trustline{margin-top:20px;color:rgba(255,255,255,.6);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.lead strong{color:var(--ink)}

/* interior page hero */
.page-hero{position:relative;overflow:hidden;padding:clamp(78px,9vw,116px) clamp(20px,5vw,76px) clamp(46px,6vw,64px);
  color:var(--white);background:linear-gradient(180deg,#1c1f22,#141618)}
.page-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;background:var(--accent)}
.page-hero h1{font-size:clamp(40px,7vw,82px);max-width:18ch;color:var(--white)}
.page-hero p{margin:18px 0 0;max-width:60ch;color:rgba(255,255,255,.74);font-size:18px;line-height:1.6}

/* proof strip */
.proof{display:grid;grid-template-columns:repeat(5,1fr);background:var(--white);border-bottom:1px solid var(--line)}
.proof div{min-height:128px;padding:24px;border-right:1px solid var(--line)}
.proof b{display:block;color:var(--ink);font-family:"Source Serif 4",Georgia,serif;font-size:40px;line-height:1}
.proof b::after{content:"";display:block;width:30px;height:3px;background:var(--accent);margin-top:10px}
.proof span{display:block;margin-top:10px;color:var(--muted);font-size:12px;font-weight:900;
  letter-spacing:.11em;line-height:1.35;text-transform:uppercase}

/* text-keyword promo band */
.sms{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:center;
  padding:clamp(28px,4vw,44px) clamp(20px,5vw,76px);background:var(--accent);color:var(--ink)}
.sms h2{color:var(--ink);font-size:clamp(28px,4vw,46px)}
.sms p{margin:8px 0 0;font-weight:700;font-size:16px;max-width:52ch}
.sms-btn{min-height:62px;display:inline-flex;align-items:center;justify-content:center;padding:0 30px;
  background:var(--ink);color:var(--white);font-size:15px;font-weight:900;letter-spacing:.06em;
  text-transform:uppercase;white-space:nowrap}
.sms-btn:hover{background:#000}

/* cards */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.card{min-height:206px;display:grid;align-content:space-between;gap:16px;padding:24px;
  background:var(--white);border:1px solid var(--line);border-top:4px solid var(--ink)}
.card:hover{border-top-color:var(--accent)}
.card b{color:var(--steel);font-size:12px;letter-spacing:.16em;text-transform:uppercase}
.card h3{font-size:28px;line-height:1.05}
.card p{margin:0;color:var(--muted);line-height:1.55;font-size:15px}
.card .more{color:var(--accent-d);font-weight:900;font-size:12px;letter-spacing:.1em;text-transform:uppercase}

/* emergency band (one authentic jobsite photo, contained) */
.emergency{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);align-items:stretch;
  background:var(--ink);color:var(--white)}
.emergency img{width:100%;height:100%;min-height:420px;object-fit:cover;filter:grayscale(.35) contrast(1.05)}
.emergency-copy{display:grid;align-content:center;gap:22px;padding:clamp(36px,6vw,84px)}
.emergency-copy h2{color:var(--white)}
.emergency-copy .lead{color:rgba(255,255,255,.74)}
.phone-line{display:inline-flex;width:fit-content;padding:14px 18px;color:var(--ink);background:var(--accent);
  font-size:clamp(22px,4vw,40px);font-weight:900}

/* projects sectors */
.sector{margin-top:38px}
.sector h3{color:var(--ink);font-size:25px;border-bottom:3px solid var(--accent);padding-bottom:8px;margin-bottom:14px}
.sector ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:6px 24px}
.sector li{color:var(--muted);font-size:14px;padding:8px 0;border-bottom:1px solid var(--line)}
.sector li b{display:block;color:var(--ink);font-weight:800;font-size:16px}

/* home featured project cards (no photo — charcoal tiles) */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.feat{min-height:200px;display:grid;align-content:end;gap:6px;padding:22px;color:var(--white);
  background:linear-gradient(180deg,#23262a,#16181a);border-bottom:4px solid var(--accent)}
.feat span{color:var(--accent);font-size:11px;font-weight:900;letter-spacing:.16em;text-transform:uppercase}
.feat h3{font-size:24px;line-height:1.05;color:var(--white)}

/* badges */
.badge-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.badge{padding:10px 13px;border:1px solid var(--line);color:var(--ink);font-size:12px;font-weight:900;
  letter-spacing:.08em;text-transform:uppercase;background:var(--white)}

/* testimonials */
.quote-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
blockquote{margin:0;padding:34px;background:var(--white);border-left:5px solid var(--accent);box-shadow:0 16px 54px rgba(23,25,27,.07)}
blockquote p{margin:0;color:rgba(23,25,27,.84);font-size:20px;line-height:1.55}
blockquote cite{display:block;margin-top:20px;color:var(--steel);font-style:normal;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}

/* contact */
.contact{color:var(--white);background:var(--ink)}
.contact-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.8fr);gap:clamp(28px,5vw,72px);align-items:start}
.contact h2{color:var(--white)}
.contact .lead{color:rgba(255,255,255,.74)}
.contact-card{display:grid;gap:18px;padding:28px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16)}
.contact-card a,.contact-card strong{color:var(--accent)}

/* footer */
.footer{display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px;padding:48px clamp(20px,5vw,76px) 28px;
  color:rgba(255,255,255,.7);background:#0f1113;font-size:14px;line-height:1.7}
.footer h4{color:var(--white);font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin:0 0 10px}
.footer a{color:rgba(255,255,255,.7)}
.footer a:hover{color:var(--accent)}
.footnote{padding:14px clamp(20px,5vw,76px);background:#0a0c0d;color:rgba(255,255,255,.5);font-size:12px;text-align:center}

@media(max-width:1060px){
  nav a.navlink{display:none}
  .proof{grid-template-columns:repeat(2,1fr)}
  .grid4,.feat-grid{grid-template-columns:repeat(2,1fr)}
  .grid3{grid-template-columns:1fr}
  .emergency,.contact-grid,.section-head,.sms{grid-template-columns:1fr}
  .sector ul{grid-template-columns:repeat(2,1fr)}
  .footer{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .brand img{height:42px}
  .proof,.grid4,.feat-grid{grid-template-columns:1fr}
  .sector ul{grid-template-columns:1fr}
  .footer{grid-template-columns:1fr}
}
