:root{
  --green:#1b1d20; --green-d:#0f0f0f; --green-l:#2a2d33;
  --orange:#c1121f; --orange-d:#9d0e18;
  --gold:#f4b400; --earth:#6b5536; --ink:#1c1d20; --muted:#5b6068; --line:#e3e3df;
  --cream:#f4f4f2; --paper:#fff; --dark:#0f0f0f;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased}
.container{width:min(1180px,92%);margin:0 auto}
.container.narrow{max-width:820px}
img{max-width:100%;display:block}
a{color:var(--green)}
h1,h2,h3,h4{font-family:'Oswald',sans-serif;line-height:1.1;text-transform:uppercase;letter-spacing:.5px;color:var(--green-d)}
.pop{color:var(--orange)}

.topbar{background:var(--dark);color:#d4dacf;font-size:.85rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 0;flex-wrap:wrap}
.topbar a{color:var(--orange);font-weight:700;text-decoration:none}

header.site{position:sticky;top:0;z-index:50;background:#fff;border-bottom:3px solid var(--orange);box-shadow:0 2px 12px rgba(36,58,33,.1)}
header.site .container{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:8px 0}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand .logo{height:46px;width:46px}
.brand-txt{display:flex;flex-direction:column;line-height:1.05}
.brand-txt .b1{font-family:'Oswald',sans-serif;font-weight:700;font-size:1.2rem;color:var(--green-d);text-transform:uppercase}
.brand-txt .b2{font-size:.68rem;color:var(--orange-d);font-weight:700;letter-spacing:1px;text-transform:uppercase}
header nav{display:flex;align-items:center;gap:20px}
header nav a{color:var(--ink);text-decoration:none;font-family:'Oswald',sans-serif;font-weight:500;text-transform:uppercase;font-size:.95rem;letter-spacing:.5px}
header nav a:not(.btn):hover{color:var(--orange-d)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:3px;background:var(--green-d);border-radius:2px}

.btn{display:inline-block;background:var(--orange);color:#fff;font-family:'Oswald',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.7px;text-decoration:none;padding:12px 26px;border-radius:6px;border:0;cursor:pointer;font-size:1.02rem;transition:background .12s,transform .08s}
.btn:hover{background:var(--orange-d);transform:translateY(-1px)}
.btn-lg{padding:15px 32px;font-size:1.12rem}
.btn-ghost{background:transparent;border:2px solid #fff;color:#fff}
.btn-ghost:hover{background:#fff;color:var(--green-d)}

.badge-open{display:inline-block;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.4);color:#fff;border-radius:30px;padding:7px 18px;font-size:.92rem;font-weight:600;margin-bottom:16px}
.open-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#6cc77d;margin-right:6px;vertical-align:middle}
.open-dot.closed{background:#e6a14e}

.hero{position:relative;color:#fff;isolation:isolate;background:var(--green-d)}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center;z-index:-2;opacity:.42}
.hero-overlay{position:absolute;inset:0;z-index:-1;background:linear-gradient(105deg,rgba(10,10,10,.93) 0%,rgba(22,22,22,.8) 48%,rgba(193,18,31,.4) 100%)}
.hero-inner{padding:84px 0 78px;max-width:720px}
.eyebrow{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:2.5px;font-size:.9rem;font-weight:600;color:var(--orange)}
.hero h1{font-size:clamp(2.5rem,6vw,4.4rem);margin:10px 0 12px;color:#fff}
.hero .lede{font-size:1.18rem;max-width:600px;color:#e9ede7}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.hero-note{margin-top:22px;font-weight:600;color:#cdd6ca}

.trust{background:var(--orange)}
.trust .container{display:flex;flex-wrap:wrap;justify-content:space-around;gap:12px;padding:15px 0;text-align:center}
.trust .item{color:#fff;font-family:'Oswald',sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.5px;font-size:1.02rem}
.trust b{font-size:1.2rem}

section{padding:62px 0}
.section-alt{background:var(--cream)}
.section-head{text-align:center;max-width:720px;margin:0 auto 42px}
.section-head h2{font-size:clamp(2rem,4.6vw,3rem)}
.section-head .eyebrow{display:block;margin-bottom:6px;color:var(--orange-d)}
.section-head p{color:var(--muted)}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{display:block;background:#fff;border:1px solid var(--line);border-top:4px solid var(--green);border-radius:10px;padding:24px 20px;box-shadow:0 6px 18px rgba(36,58,33,.05);transition:transform .1s,border-color .12s;text-decoration:none;color:inherit}
.svc:hover{transform:translateY(-4px);border-top-color:var(--orange)}
.svc .ic{font-size:2.1rem;margin-bottom:8px}
.svc h3{font-size:1.15rem;color:var(--green-d)}
.svc p{color:var(--muted);font-size:.92rem;margin-top:6px;text-transform:none;font-family:'Inter',sans-serif;letter-spacing:0}
.svc .more{display:inline-block;margin-top:10px;color:var(--orange-d);font-weight:700;font-size:.86rem}

.split{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.split img{border-radius:12px;box-shadow:0 16px 34px rgba(36,58,33,.18);width:100%;max-height:420px;object-fit:cover}
.split h2{font-size:clamp(1.9rem,4vw,2.6rem);margin-bottom:14px}
.split p{color:#3c463a}
.checks{list-style:none;margin:14px 0}
.checks li{padding-left:28px;position:relative;margin-bottom:9px;color:#3c463a}
.checks li::before{content:"✓";position:absolute;left:0;color:var(--orange-d);font-weight:800}

.area-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.area{background:#fff;border:1px solid var(--line);border-radius:30px;padding:11px 22px;text-decoration:none;color:var(--green-d);font-family:'Oswald',sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.5px;transition:background .12s,color .12s}
.area:hover{background:var(--green);color:#fff}

.faqs{display:flex;flex-direction:column;gap:12px}
.faqs details{background:#fff;border:1px solid var(--line);border-radius:10px;padding:4px 20px}
.faqs summary{font-family:'Oswald',sans-serif;font-weight:600;font-size:1.08rem;color:var(--green-d);cursor:pointer;padding:14px 0;list-style:none}
.faqs summary::-webkit-details-marker{display:none}
.faqs summary::before{content:"+";color:var(--orange-d);font-weight:800;margin-right:10px}
.faqs details[open] summary::before{content:"–"}
.faqs p{color:#3c463a;padding:0 0 16px}

.page-hero{background:var(--green-d);color:#fff;padding:54px 0 48px;position:relative}
.page-hero h1{color:#fff;font-size:clamp(2rem,5vw,3.2rem)}
.page-hero .lede{color:#e3e9e1;font-size:1.15rem;max-width:680px;margin-top:8px}
.page-hero .btn{margin-top:18px}
.crumbs{font-size:.85rem;color:#bcc8b9;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.crumbs a{color:var(--orange);text-decoration:none}

.body-copy{font-size:1.06rem;color:#3c463a;margin:16px 0}
.narrow h2{margin-top:32px;font-size:clamp(1.6rem,3.4vw,2.1rem)}
.mini-svc{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.mini-svc a{background:var(--cream);border:1px solid var(--line);border-radius:8px;padding:9px 16px;text-decoration:none;color:var(--green-d);font-weight:600;font-size:.92rem}
.mini-svc a:hover{background:var(--green);color:#fff}
.link-list{list-style:none;margin:10px 0 6px;display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.link-list a{color:var(--green);text-decoration:none}.link-list a:hover{color:var(--orange-d)}

.quote{background:var(--cream)}
.quote-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:26px;max-width:980px;margin:0 auto;align-items:start}
.qbox{background:var(--green-d);color:#fff;border-radius:12px;padding:30px;text-align:center}
.qbox h3{color:#fff;font-size:1.3rem}
.qbox .bigphone{display:block;font-family:'Oswald',sans-serif;font-size:1.9rem;color:#fff;text-decoration:none;margin:10px 0 2px}
.qbox p{color:#cfe0c8;margin-bottom:6px}
.lead-form{display:flex;flex-direction:column;gap:13px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:28px;box-shadow:0 8px 22px rgba(36,58,33,.07)}
.lead-form .hp{position:absolute;left:-9999px}
.lf-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.lead-form label{display:flex;flex-direction:column;gap:5px;font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.lead-form input,.lead-form select,.lead-form textarea{font:inherit;padding:11px 13px;border:1px solid var(--line);border-radius:7px;background:#fff;color:var(--ink)}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(51,80,47,.14)}
.lead-form .btn{align-self:flex-start;margin-top:4px;background:var(--green)}.lead-form .btn:hover{background:var(--green-d)}

.cta-band{background:var(--orange);color:#fff;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(1.9rem,4.4vw,2.8rem)}
.cta-band p{max-width:640px;margin:12px auto 0;color:#fff5ee;font-size:1.1rem}
.cta-btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:24px}
.cta-band .btn{background:#fff;color:var(--orange-d)}.cta-band .btn:hover{background:var(--green-d);color:#fff}
.cta-band .btn-ghost{background:transparent;color:#fff;border-color:#fff}.cta-band .btn-ghost:hover{background:#fff;color:var(--orange-d)}

.site-foot{background:var(--dark);color:#aebaa9;padding:48px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.site-foot .fb1{font-family:'Oswald',sans-serif;font-size:1.3rem;color:#fff;text-transform:uppercase}
.site-foot p{margin-top:8px;font-size:.94rem}
.site-foot .foot-phone a{color:var(--orange);font-weight:700;text-decoration:none;font-size:1.1rem}
.site-foot h4{color:#fff;text-transform:uppercase;font-size:1rem;margin-bottom:10px}
.site-foot .foot-grid a{display:block;color:#aebaa9;text-decoration:none;padding:3px 0;font-size:.93rem}
.site-foot .foot-grid a:hover{color:var(--orange)}
.site-foot .fine{margin-top:28px;border-top:1px solid #333a32;padding-top:16px;font-size:.84rem;color:#8a9588;text-align:center}
.site-foot .fine a{color:#aebaa9;text-decoration:none}

@media(max-width:980px){.svc-grid{grid-template-columns:repeat(2,1fr)}.quote-wrap,.split,.foot-grid{grid-template-columns:1fr}.split img{max-height:300px}}
@media(max-width:760px){
  header nav{position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;gap:0;border-bottom:3px solid var(--orange);display:none;padding:8px 0}
  header nav.open{display:flex}
  header nav a{padding:12px 22px;border-top:1px solid var(--line)}
  .nav-toggle{display:flex}
}
@media(max-width:600px){.svc-grid{grid-template-columns:1fr}.lf-row{grid-template-columns:1fr}.link-list{grid-template-columns:1fr}.trust .item{flex:1 1 44%}}

/* build-prep section */
.build-prep{background:var(--cream)}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{background:#fff;border:1px solid var(--line);border-radius:12px;padding:26px 20px 22px;position:relative;text-align:center;box-shadow:0 6px 18px rgba(36,58,33,.05)}
.step-num{position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:30px;height:30px;border-radius:50%;background:var(--orange);color:#fff;font-family:'Oswald',sans-serif;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:1rem}
.step-ic{font-size:2.2rem;margin:8px 0 6px}
.step h3{font-size:1.08rem;color:var(--green-d)}
.step p{color:var(--muted);font-size:.92rem;margin-top:6px}
.build-cta{text-align:center;margin-top:30px;font-size:1.05rem;color:#3c463a}
.build-cta a{color:var(--orange-d);font-weight:700;text-decoration:none}
@media(max-width:880px){.steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.steps-grid{grid-template-columns:1fr}}

/* ── Roach brand overrides ─────────────────────────────────────────────── */
.accent-stripe{height:5px;background:linear-gradient(90deg,var(--orange) 0 60%,var(--gold) 60% 100%)}
.topbar strong{color:var(--gold)}
.pop{color:var(--gold)}
/* dark header + ROACH wordmark */
header.site{background:var(--dark);border-bottom:3px solid var(--orange)}
header.site nav a{color:#e8e8e4}
header.site nav a:not(.btn):hover{color:var(--gold)}
.brand{display:flex;flex-direction:column;line-height:.92;text-decoration:none}
.brand .brand-r{font-family:'Oswald',sans-serif;font-weight:700;font-size:1.7rem;letter-spacing:2px;color:var(--orange);text-transform:uppercase}
.brand .brand-sub{font-family:'Oswald',sans-serif;font-weight:500;font-size:.66rem;letter-spacing:2px;color:#cfcfca;text-transform:uppercase}
.nav-toggle span{background:#e8e8e4}
/* trust bar in red, cta in red already via --orange */
.trust{background:var(--orange)}
.svc{border-top-color:var(--orange)}
.svc:hover{border-top-color:var(--gold)}
.area:hover{background:var(--orange)}
/* gallery (Recent Jobs) */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery figure{margin:0;border-radius:10px;overflow:hidden;border:1px solid var(--line);box-shadow:0 8px 20px rgba(0,0,0,.12)}
.gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .25s}
.gallery figure:hover img{transform:scale(1.05)}
/* quote box gold badge */
.qbox .qbadge{color:var(--gold);font-weight:700;margin:6px 0 10px;font-size:.92rem}
.btn-dark{background:var(--dark);color:#fff}.btn-dark:hover{background:#000}
@media(max-width:860px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.gallery{grid-template-columns:1fr}}
