*{box-sizing:border-box;margin:0;padding:0}
:root{--orange:#ef861d;--orange-dark:#ca6c13;--black:#050505;--muted:#bdbdbd;--border:rgba(255,255,255,.13)}
html{scroll-behavior:smooth}
body{font-family:Arial,Helvetica,sans-serif;background:#050505;color:#fff;line-height:1.55}
.hero-header{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:30px clamp(28px,5vw,72px)}
.brand-logo img{width:210px;height:auto;display:block;filter:drop-shadow(0 8px 24px rgba(0,0,0,.85))}
.top-call{background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff;text-decoration:none;font-weight:900;font-size:22px;padding:15px 30px;border-radius:999px;box-shadow:0 16px 42px rgba(239,134,29,.25)}
.hero{min-height:100vh;position:relative;display:flex;align-items:flex-end;justify-content:center;text-align:center;padding:175px 24px 78px;background:url('assets/hero.jpg') center top/cover no-repeat;overflow:hidden}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.18) 0%,rgba(0,0,0,.30) 30%,rgba(0,0,0,.75) 64%,rgba(0,0,0,.97) 100%),radial-gradient(circle at 80% 24%,rgba(239,134,29,.18),transparent 25%)}
.hero-copy{position:relative;width:100%;max-width:1120px;padding-bottom:10px}
.eyebrow{color:var(--orange);font-weight:900;text-transform:uppercase;letter-spacing:.18em;font-size:15px;margin-bottom:18px}
.hero h1{font-size:clamp(66px,8.6vw,118px);line-height:.92;text-transform:uppercase;letter-spacing:-.065em;text-shadow:0 10px 34px rgba(0,0,0,.75);margin-bottom:30px}
.services-line{font-size:clamp(26px,3.1vw,42px);line-height:1.25;font-weight:900;margin:0 auto 36px}
.services-line span{color:var(--orange);padding:0 12px}
.hero-buttons{display:flex;justify-content:center;align-items:center;gap:24px;flex-wrap:wrap;margin-bottom:32px}
.button{min-width:250px;border-radius:999px;padding:18px 32px;text-decoration:none;font-size:22px;font-weight:900}
.primary{background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff}
.outline{border:1px solid rgba(255,255,255,.72);color:#fff;background:rgba(0,0,0,.22)}
.service-area{color:#e7e7e7;font-weight:800;font-size:20px}
.services,.featured-work,.quote{padding:90px 24px}
.services{background:linear-gradient(#050505,#111)}
.section-head{max-width:850px;margin:0 auto 44px;text-align:center}
.section-head h2{font-size:clamp(38px,5vw,64px);line-height:1;letter-spacing:-.045em;margin-bottom:18px}
.section-head p:not(.eyebrow){color:var(--muted);font-size:19px}
.service-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.service-grid article{background:#151515;border:1px solid var(--border);border-radius:16px;padding:28px}
.service-grid h3{font-size:24px;margin-bottom:10px}
.service-grid p{color:var(--muted)}
.featured-work{background:#0b0b0b}
.photo-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:22px}
figure{background:#141414;border:1px solid var(--border);border-radius:18px;overflow:hidden}
figure img{width:100%;height:560px;object-fit:cover;display:block}
figcaption{padding:18px 20px;font-weight:900;color:#e7e7e7}
.quote{background:linear-gradient(rgba(0,0,0,.74),rgba(0,0,0,.9)),url('assets/hardscape-2.jpg') center/cover no-repeat}
.quote-box{max-width:720px;margin:0 auto;background:rgba(8,8,8,.9);border:1px solid var(--border);border-radius:20px;padding:42px}
.quote-box h2{font-size:clamp(34px,5vw,54px);line-height:1;margin-bottom:24px}
form{display:grid;gap:14px}
input,textarea{width:100%;border:1px solid rgba(255,255,255,.15);background:#1a1a1a;color:#fff;border-radius:10px;padding:16px;font-size:16px}
textarea{min-height:135px}
button{background:var(--orange);color:#fff;border:0;border-radius:10px;padding:17px;font-size:16px;font-weight:900}
.hidden{display:none}
.mobile-call{display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:30;background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff;text-align:center;text-decoration:none;border-radius:999px;padding:15px;font-weight:900;box-shadow:0 14px 38px rgba(0,0,0,.55)}
footer{text-align:center;background:#000;padding:54px 20px 92px}
footer img{width:190px;margin-bottom:14px}
footer p{color:var(--muted)}
footer a{color:var(--orange);font-weight:900;text-decoration:none}
@media(max-width:980px){.service-grid{grid-template-columns:1fr 1fr}.photo-grid{grid-template-columns:1fr}figure img{height:520px}}
@media(max-width:640px){
.hero-header{padding:24px 22px;align-items:flex-start}
.brand-logo img{width:150px}
.top-call{font-size:17px;padding:12px 21px;margin-top:10px}
.hero{min-height:100vh;padding:150px 22px 88px;background-position:center top}
.hero-copy{padding-bottom:40px}
.eyebrow{font-size:12px;margin-bottom:18px}
.hero h1{font-size:50px;margin-bottom:28px}
.services-line{font-size:26px;max-width:370px;margin-bottom:34px}
.services-line span{padding:0 7px}
.hero-buttons{gap:14px;margin-bottom:26px}
.button{width:100%;max-width:310px;min-width:0;font-size:19px;padding:17px 26px}
.service-area{font-size:17px;max-width:340px;margin:0 auto}
.services,.featured-work,.quote{padding:72px 22px}
.service-grid{grid-template-columns:1fr}
figure img{height:430px}
.quote-box{padding:30px 22px}
.mobile-call{display:block}
}
