/* =================================================================
   AC Asphalt LLC — "Fresh Pour" design system
   Palette pulled from the trade: jet-black asphalt, safety yellow
   (equipment + caution tape), concrete grays, NH-green photography.
   ================================================================= */

:root{
  /* asphalt */
  --asphalt:    #15171c;
  --asphalt-2:  #1f232b;
  --asphalt-3:  #2c313b;
  /* ink / text */
  --ink:        #181a1f;
  --sub:        #565d6a;
  --sub-d:      #9aa1ad;   /* sub text on dark */
  /* surfaces */
  --paper:      #ffffff;
  --concrete:   #f2f3f1;   /* alt section / cool concrete */
  --concrete-2: #e8eae6;
  --line:       #e3e4e0;
  --line-2:     #d2d4ce;
  --line-d:     #353a44;   /* hairline on dark */
  /* accent — safety yellow */
  --safety:     #ffb81c;
  --safety-d:   #e69e00;
  --safety-soft:#fff4d6;
  /* effects */
  --r:    6px;
  --r-sm: 4px;
  --r-lg: 12px;
  --shadow:    0 1px 2px rgba(20,22,28,.06), 0 8px 24px -12px rgba(20,22,28,.18);
  --shadow-lg: 0 24px 60px -24px rgba(20,22,28,.40);
  --ring: 0 0 0 3px var(--safety-soft), 0 0 0 5px var(--safety);
  /* type */
  --display:'Saira Condensed', 'Arial Narrow', system-ui, sans-serif;
  --body:'Hanken Grotesk', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --mono:'Spline Sans Mono', ui-monospace, 'Courier New', monospace;
  /* layout */
  --maxw: 1200px;
  --gut: clamp(1.1rem, 4vw, 2.4rem);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%; scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:1.0625rem;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,picture,svg{display:block; max-width:100%}
a{color:inherit; text-decoration:none}
button{font:inherit; color:inherit; cursor:pointer; background:none; border:none}
input,textarea,select{font:inherit}
ul{list-style:none; padding:0}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display); font-weight:700; line-height:1.02; letter-spacing:.01em}
h1{font-size:clamp(2.55rem,3vw + 1.6rem,5rem); font-weight:800; text-transform:uppercase; letter-spacing:.012em}
h2{font-size:clamp(2rem,2.2vw + 1.2rem,3.35rem)}
h3{font-size:clamp(1.3rem,.8vw + 1rem,1.7rem); font-weight:600; letter-spacing:.015em}
h4{font-size:1.05rem; font-weight:600; letter-spacing:.02em}
p{color:var(--ink)}
.lead{font-size:clamp(1.08rem,.5vw + 1rem,1.3rem); color:var(--sub); line-height:1.55}

/* lane-line eyebrow — road center-line dash + label */
.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--mono); font-weight:600; font-size:.78rem;
  text-transform:uppercase; letter-spacing:.18em; color:var(--safety-d);
}
.eyebrow::before{
  content:""; width:38px; height:4px; flex:none; border-radius:2px;
  background:repeating-linear-gradient(90deg,var(--safety) 0 13px,transparent 13px 21px);
}
.on-dark .eyebrow, .edge-dark .eyebrow{color:var(--safety)}

/* ---------- layout ---------- */
.container{width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut)}
.section{padding-block:clamp(3.4rem,7vw,6rem)}
.section--tight{padding-block:clamp(2.6rem,5vw,4rem)}
.center{text-align:center}
.measure{max-width:62ch}
.center .measure{margin-inline:auto}
.stack > * + *{margin-top:1rem}
.head{max-width:64ch; margin-bottom:clamp(2rem,4vw,3rem)}
.head.center{margin-inline:auto}
.head h2{margin-top:.7rem}
.head p{margin-top:.9rem}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--safety); --fg:var(--asphalt); --bd:var(--safety);
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.92rem 1.5rem; border-radius:var(--r-sm);
  font-family:var(--display); font-weight:600; font-size:1.02rem;
  letter-spacing:.04em; text-transform:uppercase;
  background:var(--bg); color:var(--fg); border:2px solid var(--bd);
  transition:transform .12s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px); box-shadow:0 10px 22px -10px rgba(230,158,0,.65)}
.btn:active{transform:translateY(0)}
.btn--lg{padding:1.05rem 1.9rem; font-size:1.12rem}
.btn--ghost{--bg:transparent; --fg:var(--ink); --bd:var(--line-2)}
.btn--ghost:hover{--bd:var(--ink); box-shadow:none}
.on-dark .btn--ghost, .edge-dark .btn--ghost{--fg:#fff; --bd:#454b57}
.on-dark .btn--ghost:hover, .edge-dark .btn--ghost:hover{--bd:#fff; background:rgba(255,255,255,.06)}
.btn--block{width:100%}
.btn svg{width:1.1em; height:1.1em; fill:currentColor}

/* link with arrow */
.arrow-link{
  display:inline-flex; align-items:center; gap:.45rem; font-weight:600;
  color:var(--ink); border-bottom:2px solid var(--safety); padding-bottom:2px;
  transition:gap .15s ease;
}
.arrow-link:hover{gap:.75rem}
.on-dark .arrow-link{color:#fff}

/* =================================================================
   TOP BAR
   ================================================================= */
.topbar{position:sticky; top:0; z-index:60; background:var(--asphalt); color:#fff;
  border-bottom:1px solid var(--line-d)}
.topbar__inner{display:flex; align-items:center; gap:1.2rem; min-height:68px}
.brand{display:flex; align-items:center; gap:.7rem; font-family:var(--display);
  font-weight:800; text-transform:uppercase; letter-spacing:.02em; font-size:1.32rem; color:#fff}
.brand:focus-visible{outline:none; box-shadow:var(--ring); border-radius:4px}
.brand__mark{
  --s:38px; width:var(--s); height:var(--s); flex:none; border-radius:5px;
  background:var(--safety); color:var(--asphalt); display:grid; place-items:center;
  font-weight:800; font-size:1.04rem; letter-spacing:.01em;
  box-shadow:inset 0 0 0 2px rgba(0,0,0,.12);
}
.brand small{display:block; font-family:var(--mono); font-weight:500; font-size:.56rem;
  letter-spacing:.26em; color:var(--safety); margin-top:1px; text-transform:uppercase}
.brand__txt{line-height:1}

.nav{display:none; margin-left:auto; align-items:center; gap:.3rem}
.nav a{padding:.55rem .7rem; font-weight:600; font-size:.97rem; color:#e7e9ed; border-radius:4px;
  transition:color .15s ease, background .15s ease}
.nav a:hover{color:#fff; background:rgba(255,255,255,.07)}
.nav a[aria-current="page"]{color:var(--safety)}

.topbar__cta{display:none; align-items:center; gap:.7rem; margin-left:.4rem}
.topbar .phone{display:inline-flex; align-items:center; gap:.5rem; font-family:var(--display);
  font-weight:700; font-size:1.12rem; letter-spacing:.02em; color:#fff}
.topbar .phone svg{width:18px; height:18px; fill:var(--safety)}
.topbar .phone span small{display:block; font-family:var(--mono); font-weight:500; font-size:.56rem;
  letter-spacing:.2em; color:var(--sub-d); text-transform:uppercase}

/* mobile menu button */
.burger{display:inline-flex; flex-direction:column; gap:5px; margin-left:auto; padding:10px;
  border-radius:6px}
.burger:focus-visible{outline:none; box-shadow:var(--ring)}
.burger span{width:24px; height:2px; background:#fff; border-radius:2px; transition:.2s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.mobile-nav{display:none; background:var(--asphalt-2); border-bottom:1px solid var(--line-d)}
.mobile-nav.open{display:block}
.mobile-nav a{display:block; padding:.85rem var(--gut); color:#e7e9ed; font-weight:600;
  border-top:1px solid var(--line-d)}
.mobile-nav a:hover{background:rgba(255,255,255,.05); color:#fff}
.mobile-nav .m-cta{padding:1rem var(--gut); display:grid; gap:.6rem; border-top:1px solid var(--line-d)}

/* =================================================================
   HERO
   ================================================================= */
.hero{position:relative; color:#fff; isolation:isolate; background:var(--asphalt)}
.hero__media{position:absolute; inset:0; z-index:-2; overflow:hidden}
.hero__media img{width:100%; height:100%; object-fit:cover; object-position:center 60%}
.hero::after{ /* gradient for legibility */
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(82deg, rgba(15,17,22,.92) 0%, rgba(15,17,22,.72) 38%, rgba(15,17,22,.30) 70%, rgba(15,17,22,.12) 100%),
    linear-gradient(to top, rgba(15,17,22,.85), transparent 42%);
}
.hero__inner{padding-block:clamp(3.2rem,9vw,7rem); max-width:760px}
.hero h1{margin:.9rem 0 0}
.hero .lead{color:#dfe2e7; margin-top:1.1rem; max-width:52ch}
.hero__actions{display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.8rem}
.hero__badges{display:flex; flex-wrap:wrap; gap:.5rem 1.4rem; margin-top:1.9rem;
  font-family:var(--mono); font-size:.78rem; letter-spacing:.04em; color:#cfd3da}
.hero__badges li{display:flex; align-items:center; gap:.5rem}
.hero__badges svg{width:15px; height:15px; fill:var(--safety); flex:none}

/* trust strip under hero */
.trust{background:var(--asphalt-2); color:#cfd3da; border-top:1px solid var(--line-d)}
.trust__row{display:flex; flex-wrap:wrap; gap:.4rem 0; justify-content:center;
  font-family:var(--display); text-transform:uppercase; letter-spacing:.05em;
  font-weight:600; font-size:.96rem; padding-block:.9rem}
.trust__row span{padding:.2rem 1.3rem; position:relative; color:#eef0f3}
.trust__row span + span::before{content:""; position:absolute; left:0; top:50%;
  transform:translateY(-50%); width:6px; height:6px; background:var(--safety); border-radius:50%}

/* =================================================================
   PAVING-EDGE DARK SECTIONS + speckle (aggregate) texture
   ================================================================= */
.edge-dark{position:relative; background:var(--asphalt); color:#fff}
.edge-dark--cut{clip-path:polygon(0 26px,100% 0,100% 100%,0 100%); margin-top:-1px}
.edge-dark::before{ /* fine aggregate speckle */
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.6;
  background-image:radial-gradient(rgba(255,255,255,.045) 1px, transparent 1.3px);
  background-size:7px 7px;
}
.edge-dark > *{position:relative}
.edge-dark h2, .on-dark h2{color:#fff}
.edge-dark p, .on-dark p{color:var(--sub-d)}
.edge-dark .lead{color:#cfd3da}

/* lane-line full-width divider */
.lane{height:4px; background:repeating-linear-gradient(90deg,var(--safety) 0 26px,transparent 26px 44px)}

/* =================================================================
   SERVICES GRID
   ================================================================= */
.grid{display:grid; gap:1.4rem}
.grid--3{grid-template-columns:1fr}
.grid--2{grid-template-columns:1fr}
.grid--4{grid-template-columns:1fr 1fr}

.card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .18s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--line-2)}
.card__media{position:relative; aspect-ratio:3/2; overflow:hidden; background:var(--concrete-2)}
.card__media img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease}
.card:hover .card__media img{transform:scale(1.05)}
.card__tag{position:absolute; left:12px; top:12px; background:var(--safety); color:var(--asphalt);
  font-family:var(--mono); font-weight:600; font-size:.66rem; letter-spacing:.12em; text-transform:uppercase;
  padding:.3rem .55rem; border-radius:3px}
.card__body{padding:1.3rem 1.3rem 1.4rem; display:flex; flex-direction:column; flex:1}
.card__body h3{margin-bottom:.5rem}
.card__body p{color:var(--sub); font-size:.99rem; flex:1}
.card__spec{font-family:var(--mono); font-size:.74rem; color:var(--sub); letter-spacing:.02em;
  margin-top:1rem; padding-top:.9rem; border-top:1px dashed var(--line-2);
  display:flex; align-items:center; gap:.5rem}
.card__spec b{color:var(--ink); font-weight:600}
.card__link{margin-top:1.1rem}

/* feature tiles (why us) */
.tiles{display:grid; gap:1.2rem; grid-template-columns:1fr}
.tile{padding:1.5rem 1.4rem; border:1px solid var(--line); border-radius:var(--r-lg); background:var(--paper)}
.edge-dark .tile, .on-dark .tile{background:var(--asphalt-2); border-color:var(--line-d)}
.tile__ic{width:46px; height:46px; border-radius:9px; display:grid; place-items:center;
  background:var(--safety-soft); color:var(--safety-d); margin-bottom:1rem}
.edge-dark .tile__ic{background:rgba(255,184,28,.14); color:var(--safety)}
.tile__ic svg{width:24px; height:24px; fill:currentColor}
.tile h3{font-size:1.22rem; margin-bottom:.45rem}
.tile p{color:var(--sub); font-size:.97rem}
.edge-dark .tile p{color:var(--sub-d)}

/* =================================================================
   SPLIT (image + text)
   ================================================================= */
.split{display:grid; gap:clamp(1.6rem,4vw,3.2rem); align-items:center; grid-template-columns:1fr}
.split__media{position:relative}
.split__media img{width:100%; border-radius:var(--r-lg); aspect-ratio:4/5; object-fit:cover}
.split__media--wide img{aspect-ratio:4/3}
.split__badge{position:absolute; right:-6px; bottom:-14px; background:var(--safety); color:var(--asphalt);
  border-radius:10px; padding:.85rem 1.05rem; box-shadow:var(--shadow-lg); max-width:62%}
.split__badge b{font-family:var(--display); font-weight:800; font-size:1.7rem; display:block; line-height:1}
.split__badge span{font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase}
.split__body h2{margin-bottom:.4rem}
.split ul.checks{margin-top:1.3rem; display:grid; gap:.7rem}
.checks li{display:flex; gap:.7rem; align-items:flex-start; color:var(--sub)}
.checks li b{color:var(--ink)}
.checks svg{width:22px; height:22px; flex:none; fill:none; stroke:var(--safety-d); stroke-width:2.5; margin-top:2px}
.edge-dark .checks li, .on-dark .checks li{color:var(--sub-d)}
.edge-dark .checks li b{color:#fff}
.edge-dark .checks svg{stroke:var(--safety)}

/* =================================================================
   STATS
   ================================================================= */
.stats{display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden}
.edge-dark .stats, .on-dark .stats{background:var(--line-d); border-color:var(--line-d)}
.stat{background:var(--paper); padding:1.5rem 1.2rem; text-align:center}
.edge-dark .stat, .on-dark .stat{background:var(--asphalt)}
.stat b{font-family:var(--display); font-weight:800; font-size:clamp(2.1rem,5vw,3rem); line-height:1;
  color:var(--ink); display:block}
.edge-dark .stat b{color:#fff}
.stat b em{color:var(--safety-d); font-style:normal}
.edge-dark .stat b em{color:var(--safety)}
.stat span{font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em;
  color:var(--sub); margin-top:.5rem; display:block}

/* =================================================================
   PROCESS (numbered — a real sequence)
   ================================================================= */
.process{display:grid; gap:1.1rem; counter-reset:step}
.step{display:grid; grid-template-columns:auto 1fr; gap:1.1rem; align-items:start;
  padding:1.3rem 1.4rem; border:1px solid var(--line); border-radius:var(--r-lg); background:var(--paper);
  position:relative}
.step__n{counter-increment:step; width:46px; height:46px; flex:none; border-radius:8px;
  background:var(--asphalt); color:var(--safety); font-family:var(--display); font-weight:800;
  font-size:1.35rem; display:grid; place-items:center}
.step__n::before{content:counter(step,decimal-leading-zero)}
.step h3{font-size:1.18rem; margin-bottom:.3rem}
.step p{color:var(--sub); font-size:.97rem}

/* =================================================================
   GALLERY (masonry columns + lightbox)
   ================================================================= */
.gallery{columns:1; column-gap:14px}
.gallery figure{break-inside:avoid; margin:0 0 14px; border-radius:var(--r); overflow:hidden;
  position:relative; cursor:zoom-in; background:var(--concrete-2)}
.gallery img{width:100%; transition:transform .5s ease, filter .3s ease}
.gallery figure:hover img{transform:scale(1.04)}
.gallery figcaption{position:absolute; left:0; right:0; bottom:0; padding:1.4rem .9rem .7rem;
  font-family:var(--mono); font-size:.72rem; letter-spacing:.03em; color:#fff;
  background:linear-gradient(to top,rgba(15,17,22,.82),transparent); opacity:0; transition:opacity .25s ease}
.gallery figure:hover figcaption{opacity:1}

.lightbox{position:fixed; inset:0; z-index:120; background:rgba(12,13,16,.94);
  display:none; align-items:center; justify-content:center; padding:2.5rem 1.2rem}
.lightbox.open{display:flex}
.lightbox img{max-width:min(1100px,94vw); max-height:86vh; width:auto; border-radius:6px;
  box-shadow:var(--shadow-lg)}
.lightbox__cap{position:absolute; bottom:1.1rem; left:0; right:0; text-align:center;
  font-family:var(--mono); font-size:.78rem; color:#cfd3da}
.lb-btn{position:absolute; top:1rem; right:1rem; width:46px; height:46px; border-radius:8px;
  background:rgba(255,255,255,.1); color:#fff; display:grid; place-items:center; font-size:1.5rem}
.lb-btn:hover{background:rgba(255,255,255,.2)}
.lb-nav{position:absolute; top:50%; transform:translateY(-50%); width:52px; height:52px;
  border-radius:50%; background:rgba(255,255,255,.1); color:#fff; display:grid; place-items:center; font-size:1.6rem}
.lb-nav:hover{background:var(--safety); color:var(--asphalt)}
.lb-prev{left:1rem} .lb-next{right:1rem}
.lb-btn:focus-visible,.lb-nav:focus-visible{outline:none; box-shadow:var(--ring)}

/* =================================================================
   SERVICE AREAS
   ================================================================= */
.areas{display:grid; grid-template-columns:1fr 1fr; gap:.6rem}
.area-link{display:flex; align-items:center; gap:.55rem; padding:.7rem .9rem; border:1px solid var(--line);
  border-radius:var(--r); background:var(--paper); font-weight:600; font-size:.96rem;
  transition:.15s ease}
.area-link:hover{border-color:var(--safety); background:var(--safety-soft); transform:translateX(2px)}
.area-link svg{width:16px; height:16px; fill:var(--safety-d); flex:none}
.area-link span{margin-left:auto; font-family:var(--mono); font-size:.68rem; color:var(--sub)}
.area-more{margin-top:1.4rem; color:var(--sub); font-size:.95rem; line-height:1.9}
.area-more a{color:var(--ink); border-bottom:1px solid var(--line-2)}
.area-more a:hover{border-color:var(--safety-d)}

/* =================================================================
   FAQ accordion
   ================================================================= */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none; cursor:pointer; padding:1.2rem .2rem; display:flex; gap:1rem;
  align-items:center; font-family:var(--display); font-weight:600; font-size:1.18rem; letter-spacing:.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+"; margin-left:auto; font-size:1.6rem; color:var(--safety-d);
  font-family:var(--body); transition:transform .2s ease; line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq__a{padding:0 .2rem 1.3rem; color:var(--sub); max-width:72ch}
.faq__a p + p{margin-top:.8rem}

/* =================================================================
   CTA BAND + FORM
   ================================================================= */
.cta-band{background:var(--safety); color:var(--asphalt)}
.cta-band .container{display:grid; gap:1.4rem; align-items:center}
.cta-band h2{color:var(--asphalt)}
.cta-band p{color:#3a2f08; font-weight:500}
.cta-band .phone-xl{font-family:var(--display); font-weight:800; font-size:clamp(2rem,6vw,3rem);
  letter-spacing:.01em; display:inline-flex; align-items:center; gap:.6rem; color:var(--asphalt)}
.cta-band .phone-xl svg{width:.85em; height:.85em; fill:var(--asphalt)}
.cta-band .btn{--bg:var(--asphalt); --fg:#fff; --bd:var(--asphalt)}
.cta-band .btn:hover{box-shadow:0 12px 26px -12px rgba(0,0,0,.5)}

.formcard{background:var(--paper); border-radius:var(--r-lg); padding:clamp(1.4rem,3vw,2rem);
  box-shadow:var(--shadow-lg); border:1px solid var(--line)}
.field{display:grid; gap:.4rem; margin-bottom:1rem}
.field label{font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em;
  color:var(--sub); font-weight:600}
.field label .req{color:var(--safety-d)}
.field input,.field select,.field textarea{
  padding:.8rem .9rem; border:1.5px solid var(--line-2); border-radius:var(--r-sm);
  background:#fff; color:var(--ink); transition:border-color .15s ease, box-shadow .15s ease; width:100%}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none; border-color:var(--safety); box-shadow:0 0 0 3px var(--safety-soft)}
.field textarea{min-height:120px; resize:vertical}
.field--row{display:grid; gap:1rem; grid-template-columns:1fr}
.form-note{font-size:.82rem; color:var(--sub); margin-top:.4rem}
.form-ok{display:none; padding:1rem 1.2rem; border-radius:var(--r); background:var(--safety-soft);
  border:1px solid var(--safety); color:#5a4200; font-weight:600; margin-bottom:1rem}
.hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}

/* =================================================================
   PAGE HERO (inner pages)
   ================================================================= */
.page-hero{position:relative; color:#fff; background:var(--asphalt); isolation:isolate; overflow:hidden}
.page-hero__media{position:absolute; inset:0; z-index:-2}
.page-hero__media img{width:100%; height:100%; object-fit:cover; object-position:center 55%}
.page-hero::after{content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(85deg,rgba(15,17,22,.93),rgba(15,17,22,.62) 60%,rgba(15,17,22,.40))}
.page-hero__inner{padding-block:clamp(2.6rem,7vw,4.8rem); max-width:760px}
.page-hero h1{margin-top:.7rem; font-size:clamp(2.3rem,2.5vw + 1.5rem,4rem)}
.page-hero .lead{color:#dfe2e7; margin-top:.9rem; max-width:54ch}
.page-hero__actions{margin-top:1.4rem; display:flex; flex-wrap:wrap; gap:.7rem}

/* breadcrumb */
.crumb{font-family:var(--mono); font-size:.74rem; letter-spacing:.04em; color:var(--sub);
  padding-block:.9rem; display:flex; flex-wrap:wrap; gap:.4rem; align-items:center}
.crumb a{color:var(--sub)} .crumb a:hover{color:var(--ink)}
.crumb .sep{color:var(--line-2)}
.crumb [aria-current]{color:var(--ink)}
.page-hero .crumb{color:#b9bec7} .page-hero .crumb a{color:#b9bec7}
.page-hero .crumb a:hover{color:#fff} .page-hero .crumb [aria-current]{color:#fff}
.page-hero .crumb .sep{color:#5a616d}

/* rich text body (service/location prose) */
.prose{max-width:none}
.prose > * + *{margin-top:1.1rem}
.prose h2{margin-top:2.4rem}
.prose h3{margin-top:1.8rem; margin-bottom:-.2rem}
.prose p{color:var(--sub)}
.prose strong{color:var(--ink)}
.prose ul{display:grid; gap:.6rem; margin-left:0}
.prose ul li{display:flex; gap:.6rem; color:var(--sub)}
.prose ul li::before{content:""; width:8px; height:8px; margin-top:.55rem; flex:none; border-radius:2px;
  background:var(--safety)}
.callout{background:var(--concrete); border-left:4px solid var(--safety); border-radius:0 var(--r) var(--r) 0;
  padding:1.2rem 1.3rem; margin-top:1.4rem}
.callout p{color:var(--ink)}
.callout b{font-family:var(--display); font-weight:700; letter-spacing:.01em}

/* layout: content + sidebar */
.with-aside{display:grid; gap:clamp(1.8rem,4vw,3rem); grid-template-columns:1fr}
.aside{align-self:start}
.aside__card{background:var(--asphalt); color:#fff; border-radius:var(--r-lg); padding:1.6rem 1.5rem;
  position:relative; overflow:hidden}
.aside__card::before{content:""; position:absolute; inset:0; opacity:.5; pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1.3px); background-size:7px 7px}
.aside__card > *{position:relative}
.aside__card h3{color:#fff; margin-bottom:.3rem}
.aside__card p{color:var(--sub-d); font-size:.94rem; margin-bottom:1.1rem}
.aside__card .phone-xl{font-family:var(--display); font-weight:800; font-size:1.7rem; color:#fff;
  display:flex; align-items:center; gap:.5rem; margin-bottom:1rem}
.aside__card .phone-xl svg{width:22px;height:22px;fill:var(--safety)}
.aside__list{margin-top:1.4rem; display:grid; gap:.55rem}
.aside__list a{display:flex; gap:.5rem; align-items:center; color:#dfe2e7; font-size:.95rem; font-weight:500}
.aside__list a:hover{color:var(--safety)}
.aside__list a::before{content:"\2192"; color:var(--safety)}

/* =================================================================
   FOOTER
   ================================================================= */
.footer{background:var(--asphalt); color:var(--sub-d); padding-top:clamp(3rem,6vw,4.5rem)}
.footer__grid{display:grid; gap:2.2rem; grid-template-columns:1fr; padding-bottom:2.6rem;
  border-bottom:1px solid var(--line-d)}
.footer .brand{margin-bottom:1rem}
.footer__about p{font-size:.95rem; max-width:34ch}
.footer__nap{margin-top:1.2rem; display:grid; gap:.6rem; font-size:.95rem}
.footer__nap a{color:#dfe2e7; display:flex; gap:.6rem; align-items:flex-start}
.footer__nap a:hover{color:var(--safety)}
.footer__nap svg{width:17px; height:17px; fill:var(--safety); flex:none; margin-top:3px}
.footer h4{color:#fff; font-family:var(--mono); font-weight:600; font-size:.74rem; letter-spacing:.14em;
  text-transform:uppercase; margin-bottom:1.1rem}
.footer__col ul{display:grid; gap:.55rem}
.footer__col a{color:var(--sub-d); font-size:.95rem}
.footer__col a:hover{color:#fff}
.footer__bar{display:flex; flex-wrap:wrap; gap:.6rem 1.2rem; justify-content:space-between;
  align-items:center; padding-block:1.5rem; font-size:.82rem; font-family:var(--mono); letter-spacing:.02em}
.footer__bar p{color:var(--sub-d)}
.footer__bar .pill{display:inline-flex; align-items:center; gap:.45rem; color:#cfd3da}
.footer__bar .pill::before{content:""; width:7px; height:7px; border-radius:50%; background:#39d98a}

/* =================================================================
   MISC / a11y
   ================================================================= */
:focus-visible{outline:none; box-shadow:var(--ring); border-radius:4px}
.skip{position:absolute; left:-9999px; top:0; background:var(--safety); color:var(--asphalt);
  padding:.7rem 1.1rem; font-weight:700; z-index:200; border-radius:0 0 6px 0}
.skip:focus{left:0}
.tag-row{display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.3rem}
.tag{font-family:var(--mono); font-size:.72rem; padding:.35rem .7rem; border:1px solid var(--line);
  border-radius:100px; color:var(--sub); background:var(--paper)}
.edge-dark .tag, .on-dark .tag{border-color:var(--line-d); color:var(--sub-d); background:transparent}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (min-width:560px){
  .grid--4{grid-template-columns:1fr 1fr}
  .field--row{grid-template-columns:1fr 1fr}
  .tiles{grid-template-columns:1fr 1fr}
  .gallery{columns:2}
}
@media (min-width:760px){
  .grid--2{grid-template-columns:1fr 1fr}
  .grid--3{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(4,1fr)}
  .split{grid-template-columns:1fr 1fr}
  .split--flip .split__media{order:2}
  .cta-band .container{grid-template-columns:1.1fr .9fr}
  .areas{grid-template-columns:repeat(3,1fr)}
  .process{grid-template-columns:1fr 1fr}
}
@media (min-width:960px){
  .nav{display:flex}
  .topbar__cta{display:flex}
  .burger{display:none}
  .grid--3{grid-template-columns:repeat(3,1fr)}
  .grid--4{grid-template-columns:repeat(4,1fr)}
  .tiles{grid-template-columns:repeat(3,1fr)}
  .gallery{columns:3}
  .footer__grid{grid-template-columns:1.6fr 1fr 1fr 1fr}
  .with-aside{grid-template-columns:1fr 340px}
  .with-aside--wide{grid-template-columns:1fr 360px}
  .areas{grid-template-columns:repeat(4,1fr)}
}
@media (min-width:1100px){
  .gallery{columns:3}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important; transition-duration:.001ms !important;
    scroll-behavior:auto !important}
}

/* print */
@media print{
  .topbar,.mobile-nav,.cta-band,.lightbox,.hero__actions{display:none}
  body{font-size:11pt}
}
