
:root{
  --char:#1c1b18; --char-2:#262420; --steel:#3c4347; --steel-2:#566066;
  --rust:#b4451f; --rust-dk:#94360f; --clay:#c9683a;
  --sand:#efe7d8; --sand-2:#e2d6c0; --paper:#f6f1e7; --line:#d8ccb6;
  --ink:#23211d; --ink-soft:#4f4a40; --white:#fbf8f2;
  --amber:#e8a317;
  --shadow:0 14px 34px rgba(28,27,24,.16);
  --shadow-sm:0 6px 16px rgba(28,27,24,.10);
  --maxw:1160px;
  --font-d:"Oswald",Impact,"Arial Narrow Bold",sans-serif;
  --font-b:"Source Sans 3","Segoe UI",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-b);color:var(--ink);background:var(--paper);
  font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-d);font-weight:600;line-height:1.08;
  letter-spacing:.01em;color:var(--char);margin:0 0 .5em;text-wrap:balance}
h1{font-size:clamp(2.1rem,5.2vw,3.5rem);text-transform:uppercase;letter-spacing:.02em}
h2{font-size:clamp(1.6rem,3.4vw,2.4rem);text-transform:uppercase}
h3{font-size:1.3rem;text-transform:uppercase;letter-spacing:.03em}
h4{font-size:1.06rem;text-transform:uppercase;letter-spacing:.04em;color:var(--steel)}
p{margin:0 0 1.1em}
a{color:var(--rust-dk);text-underline-offset:3px}
a:hover{color:var(--rust)}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.sec{padding:74px 0}
.sec-tight{padding:52px 0}
.lede{font-size:1.18rem;color:var(--ink-soft);max-width:62ch}
.eyebrow{font-family:var(--font-d);text-transform:uppercase;letter-spacing:.18em;
  font-size:.82rem;color:var(--rust);font-weight:600;margin:0 0 .7em}
.center{text-align:center}.center .lede{margin-left:auto;margin-right:auto}

/* top utility bar */
.topbar{background:var(--char);color:#cdc6b8;font-size:.86rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:14px;
  min-height:40px;flex-wrap:wrap}
.topbar a{color:#efe7d8}
.topbar .badge{color:var(--amber);font-family:var(--font-d);letter-spacing:.06em;
  text-transform:uppercase;font-size:.8rem}

/* header */
.site-head{position:sticky;top:0;z-index:50;background:var(--char-2);
  border-bottom:3px solid var(--rust);box-shadow:0 2px 14px rgba(0,0,0,.28)}
.site-head .wrap{display:flex;align-items:center;gap:18px;min-height:74px}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none;margin-right:auto}
.brand .mark{width:46px;height:46px;flex:0 0 46px;background:var(--rust);
  border-radius:7px;display:grid;place-items:center;font-family:var(--font-d);
  color:#fff;font-size:1.5rem;font-weight:700;box-shadow:inset 0 -4px 0 rgba(0,0,0,.22)}
.brand b{font-family:var(--font-d);text-transform:uppercase;color:var(--white);
  font-size:1.34rem;letter-spacing:.03em;line-height:1;font-weight:600}
.brand span{display:block;color:#b3aa98;font-size:.72rem;letter-spacing:.13em;
  text-transform:uppercase;margin-top:3px;font-family:var(--font-b)}
.mainnav{display:flex;gap:4px;align-items:center}
.mainnav a{font-family:var(--font-d);text-transform:uppercase;letter-spacing:.04em;
  font-size:.96rem;color:#e7e0d2;text-decoration:none;padding:9px 12px;border-radius:6px}
.mainnav a:hover,.mainnav a[aria-current="page"]{background:rgba(255,255,255,.08);color:#fff}
.head-cta{font-family:var(--font-d);text-transform:uppercase;letter-spacing:.04em;
  background:var(--rust);color:#fff;text-decoration:none;padding:11px 17px;border-radius:7px;
  font-size:.96rem;white-space:nowrap;box-shadow:inset 0 -3px 0 rgba(0,0,0,.22)}
.head-cta:hover{background:var(--rust-dk);color:#fff}
.navtoggle{display:none;background:var(--rust);border:0;color:#fff;width:46px;height:42px;
  border-radius:7px;font-size:1.4rem;cursor:pointer}
/* dropdown menus */
.has-dropdown{position:relative;display:flex;align-items:center}
.caret{font-size:.62em;margin-left:5px;opacity:.75;display:inline-block;transition:transform .15s}
.has-dropdown:hover .caret,.has-dropdown:focus-within .caret{transform:rotate(180deg)}
.dropdown{position:absolute;top:100%;left:0;min-width:230px;background:var(--char-2);
  border:1px solid rgba(255,255,255,.12);border-top:3px solid var(--rust);
  border-radius:0 0 9px 9px;box-shadow:0 16px 34px rgba(0,0,0,.4);padding:8px;
  display:none;z-index:60}
.dropdown.wide{min-width:480px;display:none;grid-template-columns:1fr 1fr;gap:2px}
.has-dropdown:hover>.dropdown,.has-dropdown:focus-within>.dropdown{display:block}
.has-dropdown:hover>.dropdown.wide,.has-dropdown:focus-within>.dropdown.wide{display:grid}
.dropdown a{display:block;padding:9px 12px;border-radius:6px;font-family:var(--font-d);
  text-transform:uppercase;letter-spacing:.03em;font-size:.86rem;color:#e7e0d2;
  text-decoration:none;white-space:nowrap}
.dropdown a:hover{background:rgba(255,255,255,.09);color:#fff}

/* hero */
.hero{position:relative;background:var(--char);color:var(--white);overflow:hidden}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;
  filter:saturate(1.02)}
.hero .scrim{position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(20,19,16,.92) 0%,rgba(20,19,16,.78) 42%,rgba(20,19,16,.34) 100%)}
.hero .wrap{position:relative;padding:96px 22px 104px}
.hero h1{color:#fff;max-width:17ch}
.hero .sub{font-size:1.24rem;color:#e9e1d2;max-width:54ch;margin:0 0 1.5em}
.hero .badges{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 26px}
.chip{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);color:#fff;padding:7px 13px;border-radius:30px;
  font-size:.86rem;font-family:var(--font-d);letter-spacing:.05em;text-transform:uppercase}
.chip b{color:var(--amber)}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-d);
  text-transform:uppercase;letter-spacing:.04em;font-size:1.04rem;text-decoration:none;
  padding:15px 26px;border-radius:8px;border:0;cursor:pointer;transition:transform .06s ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--rust);color:#fff;box-shadow:inset 0 -4px 0 rgba(0,0,0,.24),var(--shadow-sm)}
.btn-primary:hover{background:var(--rust-dk);color:#fff}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.55)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}
.btn-dark{background:var(--char);color:#fff;box-shadow:inset 0 -4px 0 rgba(0,0,0,.3)}
.btn-dark:hover{background:#000;color:#fff}

/* promise band */
.promise{background:var(--sand-2);border-top:4px solid var(--rust);
  border-bottom:1px solid var(--line)}
.promise .wrap{padding:30px 22px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;
  justify-content:center;text-align:center}
.promise p{margin:0;font-size:1.25rem;font-family:var(--font-d);color:var(--char);
  text-transform:uppercase;letter-spacing:.02em;max-width:60ch}
.promise .ic{color:var(--rust)}

/* grids */
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

/* service cards */
.card{background:var(--white);border:1px solid var(--line);border-radius:12px;
  overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
  transition:transform .12s ease,box-shadow .12s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .body{padding:22px;display:flex;flex-direction:column;gap:8px;flex:1}
.card h3{margin:0}
.card p{margin:0;color:var(--ink-soft);font-size:.99rem}
.card .more{margin-top:auto;font-family:var(--font-d);text-transform:uppercase;
  letter-spacing:.05em;color:var(--rust-dk);font-size:.9rem;text-decoration:none;padding-top:10px}
.card a.cardlink{text-decoration:none;color:inherit;display:flex;flex-direction:column;flex:1}
.card .tag{font-family:var(--font-d);font-size:.74rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--rust)}

/* dark section */
.dark{background:var(--char);color:#e8e1d3}
.dark h1,.dark h2,.dark h3{color:#fff}
.dark .lede{color:#cdc5b6}
.dark a{color:var(--amber)}
/* light cards keep their own colors even inside dark sections */
.dark .card h3,.dark .card h4{color:var(--char)}
.dark .card p{color:var(--ink-soft)}
.dark .card .tag{color:var(--rust)}
.dark .card .more{color:var(--rust-dk)}
.dark .card a{color:inherit}

/* equipment / split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.split img{border-radius:12px;box-shadow:var(--shadow)}
.statline{display:flex;gap:26px;flex-wrap:wrap;margin:18px 0 6px}
.stat b{font-family:var(--font-d);font-size:2rem;color:var(--rust);display:block;line-height:1}
.stat span{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}

/* included list */
.ticks{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.ticks li{padding-left:34px;position:relative;color:var(--ink-soft)}
.ticks li::before{content:"";position:absolute;left:0;top:3px;width:21px;height:21px;
  border-radius:5px;background:var(--rust);
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="white" d="M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z"/></svg>') center/15px no-repeat;
  mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="white" d="M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z"/></svg>') center/15px no-repeat}

/* price factors */
.factors{display:grid;gap:14px}
.factor{background:var(--white);border:1px solid var(--line);border-left:5px solid var(--rust);
  border-radius:8px;padding:15px 18px}
.factor b{font-family:var(--font-d);text-transform:uppercase;letter-spacing:.03em;
  color:var(--char);font-size:1.02rem}
.factor span{display:block;color:var(--ink-soft);font-size:.98rem;margin-top:2px}

/* faq */
.faq{display:grid;gap:12px;max-width:860px}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:10px;
  box-shadow:var(--shadow-sm);overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:18px 22px;font-family:var(--font-d);
  text-transform:uppercase;letter-spacing:.02em;font-size:1.06rem;color:var(--char);
  display:flex;justify-content:space-between;gap:14px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--rust);font-size:1.6rem;line-height:1;font-family:var(--font-d)}
.faq details[open] summary::after{content:"\2013"}
.faq .ans{padding:0 22px 20px;color:var(--ink-soft)}
.faq .ans p{margin:0 0 .7em}

/* cta band */
.ctaband{background:linear-gradient(120deg,var(--rust) 0%,var(--rust-dk) 100%);color:#fff}
.ctaband .wrap{padding:58px 22px;text-align:center}
.ctaband h2{color:#fff}
.ctaband p{color:#ffe9df;max-width:56ch;margin:0 auto 24px;font-size:1.12rem}
.ctaband .btn-primary{background:var(--char)}
.ctaband .btn-primary:hover{background:#000}
.ctaband .btn-ghost{border-color:rgba(255,255,255,.7)}

/* breadcrumb */
.crumb{font-size:.86rem;color:var(--ink-soft);padding:16px 0 0}
.crumb a{color:var(--ink-soft);text-decoration:none}
.crumb a:hover{color:var(--rust)}

/* page header */
.phead{background:var(--char-2);color:#fff;border-bottom:3px solid var(--rust)}
.phead .wrap{padding:48px 22px 52px}
.phead h1{color:#fff;margin-bottom:.3em}
.phead .lede{color:#d6cdbd}
.phead .eyebrow{color:var(--amber)}

/* projects */
.proj{background:var(--white);border:1px solid var(--line);border-radius:12px;overflow:hidden;
  box-shadow:var(--shadow-sm)}
.proj img{aspect-ratio:4/3;object-fit:cover;width:100%}
.proj .body{padding:20px}
.proj .meta{display:flex;gap:16px;flex-wrap:wrap;font-size:.82rem;color:var(--ink-soft);
  text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-d);margin-top:10px;
  border-top:1px solid var(--line);padding-top:12px}
.proj .meta b{color:var(--rust)}

/* reviews */
.quote{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:26px;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}
.quote .stars{color:var(--amber);letter-spacing:3px;font-size:1.05rem}
.quote blockquote{margin:0;font-size:1.08rem;color:var(--ink)}
.quote .who{font-family:var(--font-d);text-transform:uppercase;letter-spacing:.04em;
  color:var(--steel);font-size:.92rem}
.quote .who b{color:var(--char)}

/* resources list */
.artlist{display:grid;gap:16px}
.artrow{background:var(--white);border:1px solid var(--line);border-radius:10px;padding:18px 22px;
  box-shadow:var(--shadow-sm)}
.artrow h3{margin:0 0 4px;font-size:1.12rem;text-transform:none;letter-spacing:0;
  font-family:var(--font-d)}
.artrow p{margin:0;color:var(--ink-soft);font-size:.96rem}
.artrow a{text-decoration:none}
.cluster-h{border-left:5px solid var(--rust);padding-left:14px;margin:34px 0 16px}

/* contact */
.cgrid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px}
.field{display:block;margin-bottom:16px}
.field label{font-family:var(--font-d);text-transform:uppercase;letter-spacing:.05em;
  font-size:.85rem;color:var(--char);display:block;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);
  border-radius:8px;font-family:inherit;font-size:1rem;background:var(--white);color:var(--ink)}
.field textarea{min-height:120px;resize:vertical}
.infobox{background:var(--sand-2);border:1px solid var(--line);border-radius:12px;padding:24px}
.infobox h3{margin-top:0}
.infobox .row{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.infobox .row .ic{color:var(--rust);flex:0 0 22px;margin-top:3px}
.infobox a{color:var(--rust-dk);font-weight:600;text-decoration:none}

/* area list */
.arealist{columns:2;gap:30px}
.arealist li{margin-bottom:8px}

/* footer */
.site-foot{background:var(--char);color:#b9b1a1;font-size:.95rem;
  border-top:4px solid var(--rust)}
.site-foot .wrap{padding:54px 22px 28px;display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:36px}
.site-foot h4{color:#fff;margin:0 0 14px}
.site-foot a{color:#cfc7b7;text-decoration:none;display:block;padding:3px 0}
.site-foot a:hover{color:var(--amber)}
.site-foot .brand b{color:#fff}
.foot-bot{border-top:1px solid rgba(255,255,255,.12);margin-top:18px}
.foot-bot .wrap{padding:18px 22px;display:flex;justify-content:space-between;gap:14px;
  flex-wrap:wrap;font-size:.84rem;color:#8f897b}
.foot-promise{color:#d8d0c0;max-width:40ch;line-height:1.6}

/* mobile call bar */
.callbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;
  background:var(--rust);box-shadow:0 -4px 16px rgba(0,0,0,.25)}
.callbar a{flex:1;text-align:center;color:#fff;text-decoration:none;padding:14px 8px;
  font-family:var(--font-d);text-transform:uppercase;letter-spacing:.04em;font-size:1rem}
.callbar a+a{border-left:1px solid rgba(255,255,255,.3)}
.callbar a.alt{background:var(--char)}

@media(max-width:980px){
  .split,.cgrid{grid-template-columns:1fr;gap:26px}
  .g4{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:repeat(2,1fr)}
  .site-foot .wrap{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  body{font-size:17px}
  .mainnav,.head-cta{display:none}
  .navtoggle{display:block}
  .site-head .wrap{min-height:64px}
  .mainnav.open{display:flex;position:absolute;top:64px;left:0;right:0;flex-direction:column;
    background:var(--char-2);padding:10px;gap:2px;border-bottom:3px solid var(--rust);
    max-height:80vh;overflow-y:auto}
  .mainnav.open a{padding:13px}
  .has-dropdown{display:block}
  .caret{display:none}
  .dropdown,.dropdown.wide{position:static;display:block;border:0;box-shadow:none;
    background:transparent;padding:0 0 6px 14px;min-width:0;grid-template-columns:1fr}
  .dropdown a{padding:10px 13px;font-size:.84rem;color:#cdc6b8}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .sec{padding:50px 0}
  .hero .wrap{padding:64px 22px 76px}
  .arealist{columns:1}
  .callbar{display:flex}
  body{padding-bottom:54px}
  .site-foot .wrap{grid-template-columns:1fr}
}
