@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/inter-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/inter-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/inter-latin-700-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/fonts/inter-latin-800-normal.woff2') format('woff2')}
@font-face{font-family:'Barlow Condensed';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/barlow-condensed-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Barlow Condensed';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/barlow-condensed-latin-700-normal.woff2') format('woff2')}

/* ============================================================
   Pure Blast Solutions — Industrial light theme
   Palette: white / steel gray surfaces, charcoal ink,
   brand green (from logo) as the working accent.
   Type: Barlow Condensed (display) + Inter (body).
   ============================================================ */

:root{
  /* Surfaces */
  --bg:#ffffff;
  --bg2:#f4f6f2;            /* steel-tinted section alt */
  --bg3:#eef1ec;
  --panel:#ffffff;
  --line:#dfe5dc;
  --line2:#cdd6c9;

  /* Ink */
  --ink:#161d18;
  --ink2:#2b342d;
  --muted:#5a665c;
  --muted2:#7d877e;

  /* Brand */
  --green:#7ac142;          /* logo green — fills, buttons */
  --green-bright:#8fd052;
  --green-dk:#3f7d1e;       /* accessible green for text on white */
  --green-ink:#0e2405;      /* text on green fills */
  --green-tint:#eef7e4;     /* soft green wash */

  /* Dark band (header accents, hero, footer) */
  --coal:#171c18;
  --coal2:#20271f;
  --coal-line:#323b31;
  --coal-text:#e8ede6;
  --coal-muted:#a8b3a6;

  --gold:#f5a623;
  --danger:#c62828;

  --radius:8px; --radius-lg:12px;
  --maxw:1240px;
  --shadow:0 1px 2px rgba(22,29,24,.05),0 8px 24px rgba(22,29,24,.07);
  --shadow-lg:0 2px 4px rgba(22,29,24,.06),0 18px 44px rgba(22,29,24,.12);

  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --font-display:'Barlow Condensed','Inter',-apple-system,'Segoe UI',sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;font-size:17px}
[id]{scroll-margin-top:140px}
section[id]{scroll-margin-top:56px}
html,body{overflow-x:clip}
body{margin:0;font-family:var(--font-body);background:var(--bg);color:var(--ink);
  line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
svg{display:block}
h1,h2,h3,h4,.hero h1{font-family:var(--font-display)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.icon{width:24px;height:24px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* Accessibility */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--green);color:var(--green-ink);
  padding:12px 20px;font-weight:700;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,summary:focus-visible{
  outline:3px solid var(--green-dk);outline-offset:2px}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* ---------- Header ---------- */
header.site{position:sticky;top:0;z-index:1100;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.topbar{background:var(--coal);color:var(--coal-text);font-size:13.5px}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:38px;flex-wrap:wrap}
.topbar a{font-weight:600;display:inline-flex;align-items:center;gap:7px;color:var(--coal-text)}
.topbar a:hover{color:var(--green-bright)}
.topbar .icon{width:15px;height:15px}
.topbar .tb-right{display:flex;gap:22px;align-items:center}
.topbar .tb-note{color:var(--coal-muted);display:inline-flex;align-items:center;gap:7px}
@media(max-width:720px){.topbar .tb-note{display:none}}

.nav{display:flex;align-items:center;gap:24px;height:84px}
.brand{display:flex;align-items:center;flex:0 1 auto;min-width:0;overflow:visible;position:relative;z-index:5}
.brand .logo-img{height:104px;width:auto;max-width:none;display:block;margin:10px 0 -34px;filter:drop-shadow(0 6px 14px rgba(22,29,24,.3))}
.nav .links{margin-left:auto;display:flex;gap:22px;align-items:center}
.nav .links a:not(.cta){color:var(--ink2);font-size:15px;font-weight:600;letter-spacing:.2px;
  position:relative;padding:6px 0;transition:color .15s}
.nav .links a:not(.cta):hover{color:var(--ink)}
.nav .links a.active{color:var(--ink)}
.nav .links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:3px;background:var(--green);border-radius:2px}
.nav .cta{background:var(--green);color:var(--green-ink);padding:13px 24px;border-radius:var(--radius);
  font-weight:800;font-size:15px;display:inline-flex;align-items:center;gap:9px;
  box-shadow:0 4px 14px rgba(122,193,66,.32);transition:background .15s,transform .15s}
.nav .cta:hover{background:var(--green-bright);transform:translateY(-1px)}
.nav .nav-phone{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:15px;color:var(--ink)}
.nav .nav-phone .icon{width:18px;height:18px;color:var(--green-dk)}
.nav .nav-phone:hover{color:var(--green-dk)}

/* Desktop hover dropdowns (Services / Locations) */
.nav .links .nav-drop{position:relative;display:flex;align-items:center}
.nav .links .nav-drop > a{display:inline-flex;align-items:center;gap:5px}
.nav .links .nav-drop .caret{width:13px;height:13px;fill:none;stroke:currentColor;
  stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;opacity:.55;transition:transform .2s,opacity .2s}
.nav .links .nav-drop:hover .caret,.nav .links .nav-drop:focus-within .caret{transform:rotate(180deg);opacity:.9}
.nav-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);
  min-width:248px;background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:0 20px 46px rgba(22,29,24,.18);padding:9px;
  display:flex;flex-direction:column;gap:2px;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:1200}
.nav-menu::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px}
.nav-drop:hover .nav-menu,.nav-drop:focus-within .nav-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(3px)}
.nav-menu a{padding:10px 14px;border-radius:9px;font-size:14.5px;font-weight:600;
  color:var(--ink2);white-space:nowrap;transition:background .12s,color .12s}
.nav-menu a:not(.cta):hover{background:var(--bg3);color:var(--green-dk)}
.nav-menu a.active::after{display:none}
.nav-menu--grid{min-width:360px;display:grid;grid-template-columns:1fr 1fr;gap:2px 6px}

/* Hamburger + mobile panel */
.menu-btn{display:none;background:none;border:1.5px solid var(--line2);border-radius:var(--radius);
  width:46px;height:46px;cursor:pointer;color:var(--ink);align-items:center;justify-content:center;padding:0}
.menu-btn .icon{width:24px;height:24px}
.mobile-nav{display:none;border-top:1px solid var(--line);background:#fff;padding:30px 24px 22px}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:14px 4px;font-weight:600;font-size:17px;color:var(--ink2);border-bottom:1px solid var(--bg3)}
.mobile-nav a.active{color:var(--green-dk)}
.mobile-nav .m-cta{margin-top:16px;background:var(--green);color:var(--green-ink);text-align:center;
  border-radius:var(--radius);padding:15px;font-weight:800;border-bottom:none}
.mobile-nav .m-phone{display:flex;align-items:center;gap:10px;justify-content:center;margin-top:12px;
  border:1.5px solid var(--line2);border-radius:var(--radius);padding:13px;font-weight:700}
.mobile-nav .m-phone .icon{width:18px;height:18px;color:var(--green-dk)}
@media(max-width:1180px){
  .nav{height:74px;gap:16px}
  .brand .logo-img{height:86px;margin-bottom:-26px}
  .nav .links,.nav .nav-phone{display:none}
  .menu-btn{display:inline-flex;margin-left:auto}
  header.site .lp-links{display:flex}
}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:800;padding:16px 28px;
  border-radius:var(--radius);font-size:16px;border:none;cursor:pointer;transition:.16s;font-family:var(--font-body)}
.btn .icon{width:20px;height:20px;stroke-width:2.2}
.btn.primary{background:var(--green);color:var(--green-ink);box-shadow:0 6px 18px rgba(122,193,66,.32)}
.btn.primary:hover{background:var(--green-bright);transform:translateY(-2px)}
.btn.dark{background:var(--coal);color:#fff}
.btn.dark:hover{background:var(--coal2);transform:translateY(-2px)}
.btn.ghost{border:1.5px solid var(--line2);color:var(--ink);background:#fff}
.btn.ghost:hover{border-color:var(--green-dk);color:var(--green-dk)}
.btn.light{background:#fff;color:var(--coal)}
.btn.light:hover{transform:translateY(-2px)}
/* ghost on dark surfaces */
.on-dark .btn.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.on-dark .btn.ghost:hover{border-color:var(--green);color:var(--green-bright)}

/* ---------- Hero (dark photo band on a light site) ---------- */
.hero{position:relative;padding:104px 0 88px;overflow:hidden;color:#fff;
  background:linear-gradient(100deg,rgba(15,20,16,.92) 0%,rgba(15,20,16,.72) 55%,rgba(15,20,16,.5) 100%),
  url('/assets/hero/pure-blast-steel-truss-sandblasting-02.webp') center/cover;
  border-bottom:4px solid var(--green)}
.hero.short{padding:72px 0 60px}
.eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--green-dk);font-weight:800;
  letter-spacing:2.5px;text-transform:uppercase;font-size:12.5px;font-family:var(--font-body)}
.eyebrow::before{content:"";width:28px;height:3px;background:var(--green)}
.hero .eyebrow,.on-dark .eyebrow{color:var(--green-bright)}
.hero h1{font-size:clamp(36px,6.5vw,68px);line-height:1.04;margin:18px 0 20px;max-width:820px;
  font-weight:700;letter-spacing:.2px;text-transform:uppercase;overflow-wrap:break-word}
.hero p.lead{font-size:19px;color:#dde5da;max-width:640px;margin:0 0 32px;line-height:1.65}
.hero .btns{display:flex;gap:14px;flex-wrap:wrap}
.t-mob{display:none}
.badges{display:flex;gap:14px;flex-wrap:wrap;margin-top:48px}
.badge-card{display:flex;align-items:center;gap:13px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:13px 17px;backdrop-filter:blur(4px)}
.badge-card .ic{width:40px;height:40px;border-radius:var(--radius);background:rgba(122,193,66,.2);
  display:flex;align-items:center;justify-content:center;color:var(--green-bright);flex:none}
.badge-card b{display:block;font-size:14.5px}
.badge-card span{font-size:12.5px;color:#b9c3b6}
@media(max-width:680px){
  .hero{padding:56px 0 48px}.hero p.lead{font-size:17px}html{font-size:16px}
  .t-desk{display:none}
  .t-mob{display:inline}
  .hero .btns{flex-wrap:nowrap;gap:10px}
  .hero .btns .btn{flex:1;justify-content:center;padding:17px 12px;font-size:15.5px;white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis}
  .hero .btns .on-dark{flex:1;display:flex}
  .hero .btns .on-dark .btn{width:100%}
  .badges{margin-top:24px;gap:8px;flex-wrap:nowrap}
  .badge-card.b-google{display:none}
  .badge-card{flex:1 1 0;min-width:0;padding:9px 12px;gap:9px}
  .badge-card .ic{width:28px;height:28px}
  .badge-card .ic .icon{width:17px;height:17px}
  .badge-card b{font-size:12.5px;line-height:1.25}
  .badge-card span{display:none}
}

/* ---------- Sections ---------- */
section{padding:88px 0}
.alt{background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-head{max-width:700px;margin-bottom:48px}
.section-head.center{margin:0 auto 52px;text-align:center}
.section-head.center .eyebrow{justify-content:center}
.section-head h2{font-size:clamp(32px,4vw,44px);margin:12px 0 12px;font-weight:700;
  letter-spacing:.3px;line-height:1.06;text-transform:uppercase;color:var(--ink)}
.section-head p{color:var(--muted);margin:0;font-size:17.5px}
@media(max-width:680px){section{padding:64px 0}}

/* ---------- Service cards ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.grid{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;
  transition:.2s;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.card::after{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:var(--green);transition:.25s}
.card:hover{transform:translateY(-4px);border-color:var(--line2);box-shadow:var(--shadow-lg)}
.card:hover::after{width:100%}
.card .ic-wrap{color:var(--green-dk);display:flex;align-items:center;margin-bottom:16px}
.card .ic-wrap .icon{width:36px;height:36px;stroke-width:1.7}
.card h3{margin:0 0 9px;font-size:23px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.card p{color:var(--muted);font-size:15.5px;margin:0;line-height:1.6}
.card .more{margin-top:16px;color:var(--green-dk);font-weight:700;font-size:14.5px;display:inline-flex;align-items:center;gap:6px}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:900px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:28px 24px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.step .num{font-size:15px;font-weight:800;color:var(--green-ink);background:var(--green);width:34px;height:34px;
  border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-family:var(--font-display)}
.step .ic-wrap{color:var(--green-dk);margin-bottom:12px}
.step .ic-wrap .icon{width:28px;height:28px}
.step h4{margin:0 0 7px;font-size:20px;text-transform:uppercase;letter-spacing:.3px}
.step p{color:var(--muted);font-size:14.5px;margin:0;line-height:1.55}

/* ---------- Stats band ---------- */
.stats-band{background:var(--coal);border-top:4px solid var(--green);border-bottom:4px solid var(--green)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
@media(max-width:680px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat .n{font-size:52px;font-weight:700;color:var(--green-bright);letter-spacing:.5px;line-height:1;font-family:var(--font-display)}
.stat .l{color:var(--coal-muted);font-size:14.5px;margin-top:8px;text-transform:uppercase;letter-spacing:1.2px;font-weight:600}

/* ---------- Features ---------- */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:860px){.features{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.features{grid-template-columns:1fr}}
.feat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px;box-shadow:var(--shadow)}
.feat .ic-wrap{width:50px;height:50px;border-radius:var(--radius);background:var(--green-tint);color:var(--green-dk);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feat h4{margin:0 0 8px;font-size:19px;text-transform:uppercase;letter-spacing:.3px}
.feat p{color:var(--muted);font-size:15px;margin:0;line-height:1.55}

/* ---------- Industries ---------- */
.industries{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}
@media(max-width:900px){.industries{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.industries{grid-template-columns:1fr}}
.ind{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--line);
  border-left:4px solid var(--green);border-radius:var(--radius);padding:16px 18px;font-weight:600;font-size:15px}
.ind .icon{width:22px;height:22px;color:var(--green-dk);flex:none}

/* ---------- Gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:860px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.gallery-grid{grid-template-columns:1fr}}
.gitem{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  transition:.2s;box-shadow:var(--shadow)}
.gitem:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.gitem .ph{aspect-ratio:4/3;background:linear-gradient(135deg,#dfe5dc,#eef1ec);position:relative}
.gitem .ph img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.gitem .meta{padding:15px 17px}
.gitem .meta .svc{font-size:11.5px;color:var(--green-dk);font-weight:800;text-transform:uppercase;letter-spacing:.8px}
.gitem .meta .cap{font-size:16px;font-weight:700;margin-top:3px}
.gitem .meta .dt{font-size:12.5px;color:var(--muted);margin-top:4px}
.gnew{position:absolute;top:10px;left:10px;background:var(--green);color:var(--green-ink);font-size:11px;
  font-weight:800;padding:4px 10px;border-radius:5px;z-index:2;letter-spacing:.5px}

/* ---------- Reviews ---------- */
.rev-summary{display:flex;align-items:center;justify-content:center;gap:30px;background:var(--panel);
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 32px;flex-wrap:wrap;
  margin:0 auto 30px;max-width:760px;text-align:left;box-shadow:var(--shadow)}
@media(max-width:560px){.rev-summary{flex-direction:column;text-align:center}}
.rev-summary .big{font-size:58px;font-weight:700;line-height:1;font-family:var(--font-display)}
.rev-summary .gstars{color:var(--gold);font-size:25px;letter-spacing:3px}
.rev-summary .based{color:var(--muted);font-size:14.5px;margin-top:6px;display:flex;align-items:center;gap:8px}
.rev-summary .glogo{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--ink)}
.rev-summary .gmark{font-weight:900;font-size:20px;font-family:Arial,sans-serif}
.gmark .b1{color:#4285f4}.gmark .b2{color:#ea4335}.gmark .b3{color:#fbbc05}.gmark .b4{color:#34a853}
.review-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}
.review-card .top{display:flex;align-items:center;gap:13px;margin-bottom:12px}
.review-card .ava{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-dk));
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px;flex:none}
.review-card .who{flex:1;min-width:0}
.review-card .who .nm{font-weight:700;font-size:16px}
.review-card .who .when{font-size:12.5px;color:var(--muted)}
.review-card .gicon{width:22px;height:22px;flex:none}
.review-card .stars{color:var(--gold);font-size:16px;letter-spacing:2px;margin-bottom:8px}
.review-card .body{color:var(--ink2);font-size:15px;line-height:1.6}
.review-card .verified{margin-top:14px;display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.review-card .verified .icon{width:15px;height:15px;color:var(--green-dk)}
/* Equal-height testimonials: clamp long reviews so cards match */
.carousel-slide .review-card .body,[data-reviews-grid] .review-card .body{
  display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}
[data-reviews-grid]{align-items:stretch}
[data-reviews-grid] .review-card{display:flex;flex-direction:column}
[data-reviews-grid] .review-card .verified{margin-top:auto;padding-top:14px}
/* Carousel */
.carousel{position:relative;max-width:780px;margin:0 auto}
.carousel-vp{overflow:hidden;padding:4px}
.carousel-track{display:flex;align-items:stretch;transition:transform .45s cubic-bezier(.4,0,.2,1)}
.carousel-slide{flex:0 0 100%;min-width:0;display:flex}
.carousel-slide .review-card{margin:0;padding:30px;width:100%;display:flex;flex-direction:column}
.carousel-slide .review-card .verified{margin-top:auto;padding-top:14px}
.carousel-slide .review-card .body{font-size:16px}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;
  background:#fff;border:1px solid var(--line2);color:var(--ink);display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:3;transition:.15s;box-shadow:var(--shadow)}
.carousel-btn:hover{border-color:var(--green-dk);color:var(--green-dk)}
.carousel-btn.prev{left:-23px}.carousel-btn.next{right:-23px}
@media(max-width:880px){.carousel-btn.prev{left:6px}.carousel-btn.next{right:6px}}
@media(max-width:680px){.carousel-btn{display:none}.rev-summary{gap:18px;padding:24px 20px}}
.carousel-dots{display:flex;gap:9px;justify-content:center;margin-top:22px}
.carousel-dots button{width:9px;height:9px;border-radius:50%;border:none;background:var(--line2);cursor:pointer;padding:0;transition:.2s}
.carousel-dots button.on{background:var(--green-dk);width:26px;border-radius:5px}

/* ---------- FAQ ---------- */
.faq{max-width:840px;margin:0 auto}
.faq details{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--panel);
  margin-bottom:12px;overflow:hidden;box-shadow:var(--shadow)}
.faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-weight:700;font-size:17px;
  display:flex;align-items:center;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{width:24px;height:24px;color:var(--green-dk);flex:none;transition:.2s}
.faq details[open] summary .pm{transform:rotate(45deg)}
.faq .ans{padding:0 24px 20px;color:var(--muted);font-size:15.5px;line-height:1.65}

/* ---------- Areas ---------- */
.areas{display:flex;gap:12px;flex-wrap:wrap}
.area{display:inline-flex;align-items:center;gap:9px;background:var(--panel);border:1px solid var(--line2);
  border-radius:6px;padding:10px 18px;font-weight:700;font-size:15px}
.area .icon{width:18px;height:18px;color:var(--green-dk)}

/* ---------- Service detail rows ---------- */
.svc-row{display:grid;grid-template-columns:260px 1fr;gap:30px;align-items:center;background:var(--panel);
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px;margin-bottom:20px;box-shadow:var(--shadow)}
.svc-row img{border-radius:var(--radius);width:100%;height:100%;object-fit:cover;max-height:240px}
.svc-row h3{font-size:30px;margin:0 0 10px;text-transform:uppercase;letter-spacing:.3px}
.svc-row p{color:var(--muted);font-size:16px;line-height:1.65;margin:0 0 18px}
@media(max-width:720px){.svc-row{grid-template-columns:1fr}}

/* ---------- Contact / Form ---------- */
.contact-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:start}
@media(max-width:820px){.contact-wrap{grid-template-columns:1fr}.contact-wrap .form-card{order:-1}}
.info-row{display:flex;gap:16px;align-items:flex-start;margin-bottom:22px}
.info-row .ic-wrap{width:48px;height:48px;border-radius:var(--radius);background:var(--green-tint);
  color:var(--green-dk);display:flex;align-items:center;justify-content:center;flex:none}
.info-row b{display:block;font-size:16px;margin-bottom:3px}
.info-row a,.info-row .v{color:var(--muted);font-size:15.5px;display:block}
.info-row a:hover{color:var(--green-dk)}
.form-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:34px;box-shadow:var(--shadow-lg)}
.form-card h3{margin:0 0 6px;font-size:28px;text-transform:uppercase;letter-spacing:.3px}
.form-card .sub{color:var(--muted);font-size:15px;margin:0 0 20px}
.form .frow{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
@media(max-width:520px){.form .frow{grid-template-columns:1fr}}
.form label{display:block;font-size:14px;color:var(--ink2);margin:15px 0 6px;font-weight:600}
.form input,.form textarea{width:100%;background:#fff;border:1.5px solid var(--line2);border-radius:var(--radius);
  padding:14px 16px;color:var(--ink);font-size:16px;font-family:inherit;transition:.15s}
.form input::placeholder,.form textarea::placeholder{color:var(--muted2)}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--green-dk);
  box-shadow:0 0 0 4px rgba(122,193,66,.22)}
.form textarea{min-height:120px;resize:vertical}
.form .btn{margin-top:20px;width:100%;justify-content:center}

/* ---------- CTA band ---------- */
.band{background:linear-gradient(110deg,var(--coal) 0%,#243024 100%);border-radius:var(--radius-lg);
  padding:56px;text-align:center;position:relative;overflow:hidden;border-left:6px solid var(--green)}
.band h2{margin:0 0 12px;font-size:clamp(28px,4vw,40px);color:#fff;font-weight:700;
  text-transform:uppercase;letter-spacing:.4px}
.band p{color:var(--coal-muted);margin:0 0 26px;font-size:17.5px}
@media(max-width:680px){.band{padding:40px 26px}}

/* ---------- Footer ---------- */
footer.site{background:var(--coal);border-top:4px solid var(--green);padding:60px 0 32px;
  color:var(--coal-muted);font-size:15px}
.foot{display:grid;grid-template-columns:1.4fr .95fr .8fr 1fr 1.15fr;gap:30px}
@media(max-width:1020px){.foot{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot{grid-template-columns:1fr}}
.foot .logo-img{height:72px;margin-bottom:14px}
.foot p{line-height:1.6;margin:0}
.foot a{display:block;margin:9px 0;transition:.15s}
.foot a:hover{color:var(--green-bright)}
.foot h5{color:#fff;margin:0 0 14px;font-size:14px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}
.foot .social{display:flex;gap:12px;margin-top:14px}
.foot .social a{width:40px;height:40px;border:1px solid var(--coal-line);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;margin:0;color:var(--coal-text)}
.foot .social a:hover{border-color:var(--green);color:var(--green-bright)}
.foot-bottom{border-top:1px solid var(--coal-line);margin-top:42px;padding-top:22px;font-size:13.5px;
  color:#7e897c;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.note{color:var(--muted);font-size:14px;background:var(--bg2);border:1px dashed var(--line2);border-radius:var(--radius);padding:14px 16px}
.prose{max-width:820px}
.prose p{color:var(--ink2);font-size:17px;line-height:1.75;margin:0 0 18px}
.prose h2{font-size:32px;margin:36px 0 14px;text-transform:uppercase;letter-spacing:.3px}

/* ---------- Split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.split.rev .media{order:2}
@media(max-width:820px){.split{grid-template-columns:1fr}.split.rev .media{order:0}}
.split .media{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);
  aspect-ratio:4/3;background:var(--bg3);box-shadow:var(--shadow-lg)}
.split .media img{width:100%;height:100%;object-fit:cover}
.check-list{list-style:none;padding:0;margin:20px 0 0;display:grid;gap:13px}
.check-list li{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:var(--ink2)}
.check-list li .icon{width:24px;height:24px;color:var(--green-dk);flex:none;margin-top:1px}
.on-dark .check-list li{color:#dde5da}
.on-dark .check-list li .icon{color:var(--green-bright)}

/* ---------- Blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.blog-grid{grid-template-columns:1fr}}
.blog-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;transition:.2s;display:block;box-shadow:var(--shadow)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.blog-card .img{aspect-ratio:16/9;background:var(--bg3);position:relative}
.blog-card .img img{width:100%;height:100%;object-fit:cover}
.blog-card .tag{position:absolute;top:12px;left:12px;background:var(--coal);color:var(--green-bright);
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;padding:5px 11px;border-radius:5px}
.blog-card .bc{padding:22px 24px}
.blog-card .date{color:var(--muted2);font-size:12.5px;margin-bottom:8px}
.blog-card h3{margin:0 0 8px;font-size:22px;line-height:1.2;text-transform:uppercase;letter-spacing:.2px}
.blog-card p{color:var(--muted);font-size:14.5px;margin:0 0 14px;line-height:1.55}
.blog-card .read{color:var(--green-dk);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:6px}

/* ---------- Lead block ---------- */
.lead-block{background:var(--coal);color:#fff;border-radius:var(--radius-lg);padding:48px;
  display:grid;grid-template-columns:1.05fr 1fr;gap:46px;align-items:center;border-left:6px solid var(--green)}
@media(max-width:820px){.lead-block{grid-template-columns:1fr;padding:30px 24px}}
.lead-block h2{font-size:clamp(30px,4vw,42px);margin:12px 0;line-height:1.05;text-transform:uppercase;letter-spacing:.4px}
.lead-block p{color:var(--coal-muted);font-size:17px;margin:0 0 8px}
.mini-form{display:grid;gap:11px}
.mini-form input,.mini-form textarea{width:100%;background:#fff;border:1.5px solid var(--line2);
  border-radius:var(--radius);padding:14px 15px;color:var(--ink);font-size:15.5px;font-family:inherit}
.mini-form input::placeholder,.mini-form textarea::placeholder{color:var(--muted2)}
.mini-form input:focus,.mini-form textarea:focus{outline:none;border-color:var(--green);
  box-shadow:0 0 0 4px rgba(122,193,66,.3)}
.mini-form textarea{min-height:100px;resize:vertical}
.mini-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
@media(max-width:480px){.mini-form .row2{grid-template-columns:1fr}}

/* ---------- Trust strip ---------- */
.trust-strip{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.trust-pill{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  border-radius:6px;padding:12px 22px;font-weight:700;font-size:15px;box-shadow:var(--shadow)}
.trust-pill .icon{width:21px;height:21px;color:var(--green-dk);flex:none}

/* ---------- Video block ---------- */
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:860px){.video-grid{grid-template-columns:1fr}}
.vitem{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.vitem video{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:#0f1410}
.vitem .meta{padding:15px 17px}
.vitem .meta .svc{font-size:11.5px;color:var(--green-dk);font-weight:800;text-transform:uppercase;letter-spacing:.8px}
.vitem .meta .cap{font-size:16px;font-weight:700;margin-top:3px}
.vitem .meta .cap:empty{display:none}

/* ---------- 4-up grid (even rows for 4 cards) ---------- */
.grid.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.grid.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.grid.g4{grid-template-columns:1fr}}
.grid.g5{grid-template-columns:repeat(5,1fr)}
@media(max-width:1200px){.grid.g5{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.grid.g5{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.grid.g5{grid-template-columns:1fr}}
/* ---------- 4-up gallery (76 photos = 19 even rows) ---------- */
.gallery-grid.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.gallery-grid.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.gallery-grid.g4{grid-template-columns:1fr}}
/* ---------- Floating text-us bubble ---------- */
.sms-fab{position:fixed;right:22px;bottom:22px;z-index:1300;border-radius:999px;padding:10px 16px 10px 13px;
  background:var(--green);color:var(--green-ink);display:flex;align-items:center;gap:9px;
  box-shadow:0 6px 22px rgba(22,29,24,.32);transition:transform .15s,background .15s}
.sms-fab:hover{background:var(--green-bright);transform:translateY(-3px)}
.sms-fab .icon{width:22px;height:22px;stroke-width:2;flex:none}
.sms-fab .fab-txt{display:flex;flex-direction:column;line-height:1.15;text-align:left}
.sms-fab .fab-txt b{font-size:13.5px;font-weight:800}
.sms-fab .fab-txt small{font-size:10.5px;font-weight:700;opacity:.8}
@media(max-width:680px){.sms-fab{right:14px;bottom:14px;padding:9px 14px 9px 12px}}

/* ---------- Area chips on dark bands ---------- */
.band .areas{justify-content:center;margin-top:14px}
.band .area{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.22);color:#fff}
.band .area .icon{color:var(--green-bright)}

/* ---------- Footer locations + bottom links ---------- */
.foot .loc-grid{display:grid;grid-template-columns:1fr 1fr;column-gap:14px}
.foot .loc-grid a{margin:7px 0}
.foot-bottom a{display:inline;margin:0;color:inherit}
.foot-bottom a:hover{color:var(--green-bright)}
@media(max-width:680px){.foot-bottom{justify-content:center;text-align:center}}

/* mobile: compact quote form so Send is visible on open */
@media(max-width:680px){
  .form-card{padding:26px 22px}
  .form-card h3{font-size:24px}
  .form textarea{min-height:96px}
}

/* ---------- Mobile: tidy, even 2-col location chips (all pages) ---------- */
@media(max-width:680px){
  .areas{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .area{justify-content:center;padding:9px 8px;font-size:13px;gap:7px;min-width:0}
  .area .icon{width:14px;height:14px;flex:none}
  .band .areas{margin-top:10px}
  .band{padding:36px 18px}
  .band p{font-size:15.5px}
}

/* mobile: trust pills equal width + centered */
@media(max-width:680px){
  .trust-strip{display:grid;grid-template-columns:1fr;gap:8px}
  .trust-pill{justify-content:center;padding:11px 14px;font-size:14.5px}
}

/* ---------- Scroll-in header CTA (mobile) ---------- */
.scroll-cta{display:none}
@media(max-width:1180px){
  .container.nav{position:relative}
  /* absolutely positioned: occupies no flex space, so it can only move vertically */
  .scroll-cta{display:flex;gap:8px;align-items:center;position:absolute;right:84px;top:50%;
    opacity:0;transform:translateY(-230%);pointer-events:none;
    transition:transform .3s ease-out,opacity .25s ease-out}
  header.site.scrolled .scroll-cta{opacity:1;transform:translateY(-50%);pointer-events:auto}
  .scroll-cta .sc-quote{background:var(--green);color:var(--green-ink);font-weight:800;font-size:14px;
    padding:11px 15px;border-radius:var(--radius);box-shadow:0 4px 14px rgba(122,193,66,.32);white-space:nowrap}
  .scroll-cta .sc-quote:active{background:var(--green-bright)}
  .scroll-cta .sc-call{width:42px;height:42px;border:none;border-radius:var(--radius);
    display:flex;align-items:center;justify-content:center;color:var(--green-ink);background:var(--green);flex:none;
    box-shadow:0 4px 14px rgba(122,193,66,.32)}
  .scroll-cta .sc-call .icon{width:19px;height:19px}
  .brand .logo-img{transition:height .3s ease,margin .3s ease}
  header.site.scrolled .brand .logo-img{height:56px;margin:4px 0 -8px}
}

/* mobile: collapse the top phone/text strip once scrolled */
@media(max-width:1180px){
  .topbar{max-height:60px;overflow:hidden;transition:max-height .3s ease,opacity .25s ease}
  header.site.scrolled .topbar{max-height:0;opacity:0}
}

/* suppress header animations during initial state sync (prevents reload flash) */
header.site.no-anim, header.site.no-anim *{transition:none!important}

/* ---------- Home gallery mosaic ---------- */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.mosaic .mitem{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:1/1;display:block;
  border:1px solid var(--line);box-shadow:var(--shadow);background:var(--bg3)}
.mosaic .mitem.big{grid-column:span 2;grid-row:span 2;aspect-ratio:auto;min-height:0}
.mosaic .mitem.big img{position:absolute;inset:0}
.mosaic .mitem img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.mosaic .mitem:hover img{transform:scale(1.04)}
.mcap{position:absolute;left:0;right:0;bottom:0;padding:30px 13px 11px;
  background:linear-gradient(transparent,rgba(15,20,16,.88));color:#fff;pointer-events:none}
.mcap .svc{font-size:10.5px;letter-spacing:.8px;text-transform:uppercase;font-weight:800;color:var(--green-bright)}
.mcap .cap{font-size:13px;font-weight:600;line-height:1.3}
@media(max-width:680px){
  .mosaic{grid-template-columns:1fr 1fr;gap:8px}
  .mosaic .mitem.big{grid-column:span 2;grid-row:span 1;aspect-ratio:16/10}
  .mosaic .mitem.big img{position:static}
  .mcap .cap{font-size:12px}
}
/* ---------- Gallery filters ---------- */
.gfilters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px}
.gfilters button{border:1.5px solid var(--line2);background:#fff;border-radius:999px;padding:9px 16px;
  font-weight:700;font-size:14px;cursor:pointer;font-family:inherit;color:var(--ink2);transition:.15s}
.gfilters button:hover{border-color:var(--green-dk);color:var(--green-dk)}
.gfilters button.on{background:var(--green);border-color:var(--green);color:var(--green-ink)}
@media(max-width:680px){.gfilters{gap:6px}.gfilters button{padding:8px 13px;font-size:13px}}
/* ---------- Photo grid ---------- */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media(max-width:1100px){.pgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.pgrid{grid-template-columns:1fr 1fr;gap:8px}}
.gph{position:relative;border:none;padding:0;background:var(--bg3);border-radius:var(--radius);overflow:hidden;
  aspect-ratio:1/1;cursor:pointer;display:block;width:100%}
.gph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s}
.gph:hover img{transform:scale(1.05)}
.gmore{display:flex;justify-content:center;margin-top:30px}
/* ---------- Lightbox ---------- */
.lb{position:fixed;inset:0;z-index:2000;background:rgba(10,14,11,.94);display:none;
  align-items:center;justify-content:center;flex-direction:column;padding:20px}
.lb.open{display:flex}
.lb img{max-width:min(1100px,92vw);max-height:70vh;border-radius:8px;object-fit:contain}
.lb .lb-meta{color:#fff;text-align:center;margin-top:14px;max-width:680px}
.lb .lb-meta .svc{color:var(--green-bright);text-transform:uppercase;font-size:11.5px;font-weight:800;letter-spacing:.8px}
.lb .lb-meta .cap{font-size:16px;font-weight:600;margin-top:3px}
.lb .lb-count{color:#a8b3a6;font-size:12.5px;margin-top:6px}
.lb .lb-btn{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);color:#fff;
  width:46px;height:46px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}
.lb .lb-btn:hover{background:rgba(255,255,255,.2)}
.lb .lb-btn .icon{width:22px;height:22px}
.lb .lb-close{top:18px;right:18px}
.lb .lb-prev{left:16px;top:50%;transform:translateY(-50%)}
.lb .lb-next{right:16px;top:50%;transform:translateY(-50%)}
@media(max-width:680px){
  .lb{padding:14px}
  .lb .lb-prev{top:auto;bottom:20px;left:calc(50% - 64px);transform:none}
  .lb .lb-next{top:auto;bottom:20px;right:calc(50% - 64px);transform:none}
  .lb img{max-height:60vh}
}

/* desktop: nudge contact info column down to align with the form card */
@media(min-width:821px){.contact-wrap>div:first-child{padding-top:36px}}

/* mobile: lighter hero background */
@media(max-width:680px){
  .hero{background:linear-gradient(100deg,rgba(15,20,16,.92) 0%,rgba(15,20,16,.72) 55%,rgba(15,20,16,.5) 100%),
    url('/assets/hero-m/pure-blast-steel-truss-sandblasting-02.webp') center/cover;border-bottom:4px solid var(--green)}
}
/* click-to-play video facade */
.vplay{display:block;width:100%;border:none;padding:0;cursor:pointer;position:relative;background:#0f1410}
.vplay img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;display:block}
.vbtn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:58px;height:58px;border-radius:50%;
  background:var(--green);color:var(--green-ink);display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(0,0,0,.4);transition:transform .15s}
.vbtn svg{width:26px;height:26px;margin-left:3px}
.vplay:hover .vbtn{transform:translate(-50%,-50%) scale(1.08)}

/* Optional "Add a photo" control on quote forms (compact, single line) */
.photo-attach{margin:-4px 0 2px;line-height:1.3}
.photo-attach .photo-trigger{display:inline-flex;align-items:center;gap:6px;background:none;border:none;padding:2px 0;margin:0;font:inherit;font-size:13px;font-weight:700;color:inherit;opacity:.82;cursor:pointer}
.photo-attach .photo-trigger:hover{opacity:1;text-decoration:underline}
.photo-attach .photo-trigger .po{font-weight:500;opacity:.78}
.photo-attach .photo-chosen{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:inherit;opacity:.92}
.photo-attach .photo-chosen .photo-remove{background:none;border:none;color:inherit;cursor:pointer;font-weight:800;padding:0 2px;font-size:16px;line-height:1}
.photo-attach .photo-chosen .photo-remove:hover{opacity:.7}
