:root{--black:#070707;--charcoal:#151515;--gray:#242424;--text:#f5f5f5;--muted:#b8b8b8;--orange:#ff6a00;--white:#fff}*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#fff;color:#151515;line-height:1.6}a{color:inherit}.container{width:min(1180px,92%);margin:0 auto}.site-header{position:sticky;top:0;z-index:50;background:rgba(7,7,7,.94);color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}.nav-wrap{display:flex;align-items:center;justify-content:space-between;min-height:76px;gap:24px}.brand{font-weight:900;text-decoration:none;font-size:1.25rem;letter-spacing:.04em;display:flex;align-items:center}.custom-logo{max-height:58px;width:auto}.main-nav ul{display:flex;gap:22px;list-style:none;margin:0;padding:0}.main-nav a{text-decoration:none;color:#eee;font-weight:700;font-size:.95rem}.header-phone{background:var(--orange);color:#000;font-weight:900;text-decoration:none;padding:10px 16px;border-radius:999px}.hero{position:relative;min-height:82vh;display:flex;align-items:center;background:#111 center/cover no-repeat;color:#fff}.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.82),rgba(0,0,0,.42),rgba(0,0,0,.22))}.hero-content{position:relative;max-width:780px;margin-left:4vw}.eyebrow{text-transform:uppercase;color:var(--orange);font-weight:900;letter-spacing:.13em;font-size:.86rem}.hero h1{font-size:clamp(2.5rem,7vw,6rem);line-height:.95;margin:10px 0 20px;text-transform:uppercase;letter-spacing:-.04em}.hero p{font-size:1.25rem;color:#e9e9e9;max-width:680px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.btn{display:inline-block;text-decoration:none;font-weight:900;padding:14px 22px;border-radius:6px}.btn-primary{background:var(--orange);color:#000}.btn-secondary{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.35)}.section{padding:78px 0}.section h2{font-size:clamp(2rem,4vw,3.2rem);line-height:1.05;margin:0 0 26px}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.card{background:#fff;border:1px solid #e8e8e8;padding:28px;border-radius:14px;box-shadow:0 12px 30px rgba(0,0,0,.06)}.card h3{margin-top:0;font-size:1.35rem}.dark{background:var(--black);color:#fff}.dark p{color:#d6d6d6}.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:32px}.proof-grid div{background:#151515;border:1px solid #303030;padding:26px;border-radius:14px}.proof-grid strong{display:block;font-size:2.4rem;color:var(--orange);line-height:1}.proof-grid span{color:#fff;font-weight:700}.area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.area{padding:18px;background:#151515;color:#fff;text-decoration:none;border-left:5px solid var(--orange);font-weight:900}.cta{background:linear-gradient(135deg,#111,#2a2a2a);color:#fff;padding:70px 0;text-align:center}.cta h2{font-size:clamp(2rem,4vw,3.2rem);margin:0 0 12px}.page-hero{background:#111;color:#fff;padding:90px 0}.page-hero h1{font-size:clamp(2.2rem,5vw,4rem);margin:0;text-transform:uppercase}.content-area{max-width:900px}.content-area img{max-width:100%;height:auto;border-radius:14px}.site-footer{background:#050505;color:#fff;padding:50px 0 20px}.footer-grid{display:grid;grid-template-columns:2fr 1fr 2fr;gap:40px}.site-footer a{color:#fff}.copyright{text-align:center;color:#aaa;border-top:1px solid #222;margin-top:35px;padding-top:18px}@media(max-width:800px){.main-nav{display:none}.nav-wrap{min-height:66px}.header-phone{font-size:.9rem;padding:9px 12px}.hero{min-height:72vh;background-position:center}.hero-content{margin-left:0}.hero h1{font-size:2.55rem}.cards,.split,.proof-grid,.area-grid,.footer-grid{grid-template-columns:1fr}.section{padding:54px 0}}
.header-actions{display:flex;align-items:center;gap:14px}.header-socials{display:flex;align-items:center;gap:8px}.header-socials a,.social-links a{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-weight:900}.header-socials a{width:34px;height:34px;border-radius:50%;background:#222;color:#fff;border:1px solid rgba(255,255,255,.18);font-size:.78rem}.header-socials a:hover,.social-links a:hover{background:var(--orange);color:#000}.social-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.social-links a{padding:9px 12px;border-radius:999px;background:#151515;border:1px solid #333;color:#fff;font-size:.9rem}@media(max-width:800px){.header-socials{display:none}.header-actions{gap:8px}}

/* v1.2 hero image map: show full uploaded hero image, no cropping, no duplicate text overlay */
.hero-image-map{position:relative;background:#050505;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.08)}
.hero-main-image{display:block;width:100%;height:auto;margin:0 auto;max-width:1920px}
.hero-fallback{min-height:72vh;display:flex;align-items:center;background:linear-gradient(135deg,#080808,#1c1c1c);color:#fff}
.hero-hotspot{position:absolute;display:block;z-index:5;border-radius:8px;text-indent:-9999px;overflow:hidden}
.hero-hotspot:focus{outline:3px solid var(--orange);outline-offset:2px;background:rgba(255,106,0,.15)}
/* Percent positions are based on the current hero graphic layout */
.hotspot-estimate{left:20.5%;top:72.5%;width:22%;height:6.5%}
.hotspot-commercial{left:38%;top:62%;width:10%;height:12%}
.hotspot-driveways{left:48%;top:62%;width:10%;height:12%}
.hotspot-sidewalks{left:58%;top:62%;width:10%;height:12%}
.hotspot-patios{left:68%;top:62%;width:10%;height:12%}
.hotspot-parking{left:78%;top:62%;width:10%;height:12%}
.hotspot-slabs{left:88%;top:62%;width:10%;height:12%}
.page-block-content{padding:60px 0;background:#fff;color:#151515}
.service-card{text-decoration:none;color:#151515;transition:transform .18s ease, border-color .18s ease}
.service-card:hover{transform:translateY(-4px);border-color:var(--orange)}
.service-card span{color:var(--orange);font-weight:900}
@media(max-width:800px){
  .hero-image-map{overflow-x:auto}
  .hero-main-image{width:1200px;max-width:none}
}


/* v1.4 navigation hover polish */
.main-nav a{transition:color .18s ease, border-color .18s ease;}
.main-nav a:hover,
.main-nav a:focus,
.main-nav .current-menu-item > a,
.main-nav .current_page_item > a{color:var(--orange);}
.main-nav a:focus{outline:2px solid var(--orange);outline-offset:4px;border-radius:4px;}
.header-phone{transition:transform .18s ease, box-shadow .18s ease, background .18s ease;}
.header-phone:hover,.header-phone:focus{background:#ff7a1a;transform:translateY(-1px);box-shadow:0 0 18px rgba(255,106,0,.35);}

/* v1.5 clickable service/estimate hotspot polish */
.hero-hotspot{cursor:pointer;}
.hero-hotspot:hover{background:rgba(255,106,0,.10);}


/* v1.6 clean hero hover: remove red boxes over service icons and estimate button */
.hero-hotspot:hover,
.hero-hotspot:focus{
  background:transparent !important;
}
.hero-hotspot:focus{
  outline:2px solid var(--orange);
  outline-offset:3px;
}
/* keep cursor pointer but no visible block overlay */
.hero-hotspot{
  cursor:pointer;
}

/* v1.7 clean hotspot behavior: no boxes, no outline, no background overlay */
.hero-hotspot,
.hero-hotspot:hover,
.hero-hotspot:focus,
.hero-hotspot:active{
  background: transparent !important;
  outline: none !important;
  box-shadow: none !important;
  border: 0 !important;
}
.hero-hotspot:hover{ cursor:pointer; }


/* v1.8 final night polish: tighter invisible clickable zones, no fake hover boxes */
.hero-hotspot,
.hero-hotspot:hover,
.hero-hotspot:focus,
.hero-hotspot:active{
  background: transparent !important;
  outline: none !important;
  box-shadow: none !important;
  border: 0 !important;
}

/* Tighten estimate hotspot so the hand cursor only appears on the orange button itself */
.hotspot-estimate{
  left: 6.4% !important;
  top: 68.2% !important;
  width: 31.8% !important;
  height: 6.1% !important;
  border-radius: 8px !important;
}

/* Service hotspots: clickable, but invisible and cleaner */
.hotspot-commercial,
.hotspot-driveways,
.hotspot-sidewalks,
.hotspot-patios,
.hotspot-parking,
.hotspot-slabs{
  top: 63.4% !important;
  height: 9.6% !important;
  border-radius: 0 !important;
}

.hotspot-commercial{left:39.8% !important;width:8.8% !important;}
.hotspot-driveways{left:49.4% !important;width:8.8% !important;}
.hotspot-sidewalks{left:59.0% !important;width:8.8% !important;}
.hotspot-patios{left:68.5% !important;width:8.8% !important;}
.hotspot-parking{left:78.1% !important;width:8.8% !important;}
.hotspot-slabs{left:87.5% !important;width:9.8% !important;}

/* v1.9: hide default theme page title banner on inner pages */
.page-hero{display:none!important;}
.page-content-section{padding-top:40px;}
