/* ============================================================
   LAPEER CUSTOMS — Industrial upfitting site
   ============================================================ */

:root{
  /* Surfaces */
  --ink:        #0d0e10;   /* deepest background */
  --steel-950:  #111316;
  --steel-900:  #16181c;
  --steel-850:  #1b1e23;
  --steel-800:  #21252b;
  --steel-700:  #2c3138;

  /* Lines / borders */
  --line:       rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.16);

  /* Text */
  --fg:         #f3f4f5;
  --fg-soft:    #c3c8cd;
  --muted:      #8b9097;
  --muted-dim:  #62676d;

  /* Accent — safety orange */
  --accent:     oklch(0.70 0.175 52);     /* ~#f2691f */
  --accent-hi:  oklch(0.76 0.165 58);
  --accent-dim: oklch(0.55 0.13 52);
  --accent-ink: #1a0d04;

  --maxw: 1320px;
  --gut: 40px;

  --f-disp: "Saira Condensed", "Arial Narrow", sans-serif;
  --f-body: "Barlow", system-ui, sans-serif;
  --f-mono: "Space Mono", ui-monospace, monospace;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--f-body);
  background:var(--ink);
  color:var(--fg);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }

.container{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gut);
}

/* ---------- Reusable bits ---------- */

.mono{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-family:var(--f-mono);
  font-size:12.5px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--accent-hi);
}
.eyebrow::before{
  content:"";
  width:30px; height:2px;
  background:var(--accent);
}

.hazard{
  height:10px;
  background:repeating-linear-gradient(-45deg,
    var(--accent) 0 16px, #121316 16px 32px);
}
.hazard--thin{ height:6px; }

.accent{ color:var(--accent-hi); }

/* Buttons */
.btn{
  --bg:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--f-disp);
  font-weight:700;
  font-size:16px;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:15px 26px;
  border:1px solid transparent;
  cursor:pointer;
  transition:.18s ease;
  white-space:nowrap;
}
.btn svg{ width:16px; height:16px; }
.btn-primary{
  background:var(--accent);
  color:var(--accent-ink);
}
.btn-primary:hover{ background:var(--accent-hi); transform:translateY(-2px); }
.btn-ghost{
  background:transparent;
  color:var(--fg);
  border-color:var(--line-strong);
}
.btn-ghost:hover{ border-color:var(--accent); color:var(--accent-hi); }
.btn-block{ width:100%; justify-content:center; }

/* Section scaffolding */
.section{ position:relative; padding:120px 0; }
.section--tight{ padding:90px 0; }
.section--alt{ background:var(--steel-900); }

.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:40px;
  margin-bottom:60px;
}
.section-head__l{ max-width:760px; }
.section-num{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.2em;
  color:var(--accent-hi);
  display:block;
  margin-bottom:18px;
}
.section-title{
  font-family:var(--f-disp);
  font-weight:700;
  font-size:clamp(38px, 5.2vw, 70px);
  line-height:.96;
  letter-spacing:.005em;
  text-transform:uppercase;
}
.section-intro{
  margin-top:22px;
  font-size:18px;
  color:var(--fg-soft);
  max-width:620px;
  text-wrap:pretty;
}

/* Image tile (real photo with caption scrim) */
.ph{
  position:relative;
  margin:0;
  background-color:var(--steel-850);
  background-image:repeating-linear-gradient(135deg,
    rgba(255,255,255,.035) 0 2px, transparent 2px 11px);
  border:1px solid var(--line);
  display:flex;
  align-items:flex-end;
  overflow:hidden;
}
.ph img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
.ph:hover img{ transform:scale(1.045); }
.ph::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(8,9,11,.86) 0%, rgba(8,9,11,.18) 38%, transparent 64%);
  pointer-events:none;
}
.ph-cap{
  position:relative;
  z-index:1;
  font-family:var(--f-mono);
  font-size:11.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--fg-soft);
  padding:14px 15px;
  display:flex;
  align-items:center;
  gap:8px;
}
.ph-cap::before{
  content:"";
  width:7px;height:7px;
  background:var(--accent);
  flex:none;
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;
  top:0; left:0; right:0;
  z-index:100;
  border-bottom:1px solid transparent;
  transition:.25s ease;
}
.site-header.scrolled{
  background:rgba(13,14,16,.86);
  backdrop-filter:blur(12px);
  border-bottom-color:var(--line);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:78px;
  transition:height .25s ease;
}
.site-header.scrolled .nav{ height:66px; }

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-family:var(--f-disp);
  font-weight:800;
  font-size:24px;
  letter-spacing:.02em;
  text-transform:uppercase;
}
.brand__mark{
  width:42px; height:42px;
  flex:none;
  object-fit:contain;
  border-radius:50%;
}
.site-header.scrolled .brand__mark{ width:38px; height:38px; }
.brand span{ color:var(--accent-hi); }

.nav-links{
  display:flex;
  align-items:center;
  gap:20px;
  list-style:none;
}
.nav-links a{
  font-family:var(--f-mono);
  font-size:11.5px;
  letter-spacing:.11em;
  text-transform:uppercase;
  color:var(--fg-soft);
  transition:.15s;
  position:relative;
  padding:6px 0;
}
.nav-links a:hover{ color:var(--accent-hi); }

.nav-right{ display:flex; align-items:center; gap:14px; }
.nav-cta-mobile{ display:none; }
/* mobile drawer backdrop */
.nav-backdrop{
  position:fixed; inset:0; z-index:90;
  background:rgba(8,9,11,.6);
  -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px);
  opacity:0; visibility:hidden; transition:opacity .3s ease, visibility .3s ease;
  cursor:pointer; /* iOS Safari: required for click events on plain divs */
}
.nav-backdrop.show{ opacity:1; visibility:visible; }
.nav-phone{
  font-family:var(--f-disp);
  font-weight:700;
  font-size:17px;
  letter-spacing:.03em;
  white-space:nowrap;
  display:flex; align-items:center; gap:7px;
}
.nav-phone svg{ width:15px;height:15px;color:var(--accent-hi); }

.menu-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none; border:none; cursor:pointer;
  padding:8px;
  position:relative;
  z-index:120; /* must sit above the open drawer (fixed) so the X stays tappable */
}
.menu-toggle span{ width:24px;height:2px;background:var(--fg);transition:.2s; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding-top:78px;
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background-color:#0a0b0d;
  background-image:
    repeating-linear-gradient(135deg, rgba(255,255,255,.03) 0 2px, transparent 2px 13px);
}
.hero-bg::after{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(13,14,16,.55) 0%, rgba(13,14,16,.2) 35%, rgba(13,14,16,.92) 100%),
    radial-gradient(80% 60% at 75% 25%, rgba(242,105,31,.10), transparent 60%);
}
/* Darkened photographic backdrop behind the hero content */
.hero-photo{
  position:absolute; inset:0;
  z-index:1;
  background:url("assets/photos/truck-desert.jpg") center 30% / cover no-repeat;
  opacity:.32;
  filter:grayscale(.2) contrast(1.02);
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, #000 22%, #000 70%, transparent 100%);
          mask-image:linear-gradient(180deg, transparent 0%, #000 22%, #000 70%, transparent 100%);
  pointer-events:none;
}
.hero-photo::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(13,14,16,.92) 0%, rgba(13,14,16,.55) 42%, rgba(13,14,16,.25) 100%);
}
.hero-inner{
  position:relative;
  z-index:3;
  flex:1;
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(0,0.92fr);
  align-items:center;
  gap:48px;
  padding-top:36px;
  padding-bottom:48px;
}
.hero-copy{ position:relative; z-index:3; }
.hero-emblem-wrap{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-emblem{
  width:100%;
  max-width:560px;
  height:auto;
  opacity:1;
  pointer-events:none;
  filter:drop-shadow(0 26px 54px rgba(0,0,0,.55));
}
.hero-eyebrow{ margin-bottom:26px; align-items:flex-start; }
.hero-eyebrow::before{ margin-top:7px; }
.eyebrow-stack{ display:flex; flex-direction:column; gap:6px; }
.eyebrow-loc{ color:var(--muted); }
.hero-title{
  font-family:var(--f-disp);
  font-weight:800;
  font-size:clamp(52px, 6.8vw, 108px);
  line-height:.9;
  letter-spacing:.004em;
  text-transform:uppercase;
}
.hero-title em{ color:var(--accent-hi); font-style:normal; }
.hero-sub{
  margin-top:28px;
  font-size:clamp(17px,1.5vw,21px);
  color:var(--fg-soft);
  max-width:60ch;
  text-wrap:pretty;
}
.hero-actions{
  margin-top:38px;
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}

/* Hero stats strip */
.hero-stats{
  position:relative;
  z-index:3;
  border-top:1px solid var(--line);
  display:grid;
  grid-template-columns:repeat(4,1fr);
}
.hero-stats .hs{
  padding:26px var(--gut);
  border-right:1px solid var(--line);
}
.hero-stats .hs:last-child{ border-right:none; }
.hs-num{
  font-family:var(--f-disp);
  font-weight:700;
  font-size:40px;
  line-height:1;
  letter-spacing:.02em;
}
.hs-num .accent{ color:var(--accent-hi); }
.hs-label{
  margin-top:8px;
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
}

/* ============================================================
   SERVICES
   ============================================================ */
.service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border:1px solid var(--line);
  border-bottom:none;
}
.service-card{
  position:relative;
  padding:38px 34px 42px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  transition:.2s ease;
  overflow:hidden;
}
.service-card:nth-child(3n){ border-right:none; }
.service-card::before{
  content:"";
  position:absolute; left:0; top:0; bottom:0;
  width:3px; background:var(--accent);
  transform:scaleY(0); transform-origin:top;
  transition:transform .25s ease;
}
.service-card:hover{ background:var(--steel-900); }
.service-card:hover::before{ transform:scaleY(1); }
.service-num{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.2em;
  color:var(--muted-dim);
}
.service-icon{
  margin-top:14px;
  width:42px;height:42px;
  color:var(--accent-hi);
}
.service-icon svg{ width:100%;height:100%; }
.service-title{
  font-family:var(--f-disp);
  font-weight:700;
  font-size:30px;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-top:20px;
  line-height:1;
}
.service-desc{
  margin-top:14px;
  color:var(--muted);
  font-size:15.5px;
  text-wrap:pretty;
}
.service-tags{
  margin-top:20px;
  display:flex; flex-wrap:wrap; gap:8px;
}
.tag{
  font-family:var(--f-mono);
  font-size:10.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--fg-soft);
  border:1px solid var(--line-strong);
  padding:5px 9px;
}

/* ============================================================
   CAPABILITIES (Aesthetic / Functional / Structural)
   ============================================================ */
.cap-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.cap-col{
  background:var(--ink);
  padding:42px 34px;
}
.section--alt .cap-col{ background:var(--steel-900); }
.cap-tier{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent-hi);
  display:flex; align-items:center; gap:10px;
}
.cap-tier b{ color:var(--muted-dim); font-weight:400; }
.cap-name{
  font-family:var(--f-disp);
  font-weight:700;
  font-size:34px;
  text-transform:uppercase;
  margin:16px 0 6px;
  line-height:1;
}
.cap-blurb{ color:var(--muted); font-size:15px; margin-bottom:24px; text-wrap:pretty; }
.cap-list{ list-style:none; display:flex; flex-direction:column; }
.cap-list li{
  display:flex; align-items:center; gap:12px;
  padding:13px 0;
  border-top:1px solid var(--line);
  font-size:15.5px;
  color:var(--fg-soft);
}
.cap-list li::before{
  content:"";
  width:6px;height:6px;
  background:var(--accent);
  transform:rotate(45deg);
  flex:none;
}

/* ============================================================
   PROCESS
   ============================================================ */
.step-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
}
.step{
  padding:34px 28px 30px;
  border-left:1px solid var(--line);
  position:relative;
}
.step:first-child{ padding-left:0; border-left:none; }
.step-num{
  font-family:var(--f-disp);
  font-weight:800;
  font-size:64px;
  line-height:.8;
  color:transparent;
  -webkit-text-stroke:1.4px var(--accent-dim);
}
.step-title{
  font-family:var(--f-disp);
  font-weight:700;
  font-size:25px;
  text-transform:uppercase;
  margin:22px 0 10px;
}
.step-desc{ color:var(--muted); font-size:15px; text-wrap:pretty; }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:200px;
  grid-auto-flow:dense;
  gap:14px;
}
.gallery-grid .ph{ height:100%; cursor:pointer; }
.g-tall{ grid-row:span 2; }
.g-wide{ grid-column:span 2; }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed; inset:0; z-index:200;
  background:rgba(8,9,11,.93);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  padding:24px;
  opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s ease;
}
.lightbox.open{ opacity:1; visibility:visible; }
.lb-stage{
  position:relative;
  max-width:min(1100px, 92vw);
  display:flex; flex-direction:column;
}
.lb-img{
  max-width:100%; max-height:78vh; object-fit:contain;
  border:1px solid var(--line-strong);
  background:var(--steel-900);
}
.lb-bar{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:14px 2px 0;
}
.lb-cap{
  font-family:var(--f-mono); font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--fg-soft);
}
.lb-count{ font-family:var(--f-mono); font-size:12px; color:var(--muted); flex:none; }
.lb-close,.lb-prev,.lb-next{
  background:rgba(255,255,255,.06); border:1px solid var(--line-strong); color:var(--fg);
  cursor:pointer; line-height:1; display:grid; place-items:center; transition:.15s ease;
}
.lb-prev,.lb-next{
  position:absolute; top:50%; transform:translateY(-50%); z-index:2;
  width:54px; height:54px; font-size:30px; font-family:var(--f-disp);
}
.lb-prev{ left:18px; }
.lb-next{ right:18px; }
.lb-close{
  position:absolute; top:18px; right:18px; z-index:3;
  width:46px; height:46px; font-size:26px;
}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{
  background:var(--accent); color:var(--accent-ink); border-color:var(--accent);
}

/* ============================================================
   STATS BAND
   ============================================================ */
.stats-band{
  background:var(--accent);
  color:var(--accent-ink);
}
.stats-inner{
  display:grid;
  grid-template-columns:repeat(4,1fr);
}
.sb{
  padding:54px var(--gut);
  border-right:1px solid rgba(26,13,4,.18);
}
.sb:last-child{ border-right:none; }
.sb-num{
  font-family:var(--f-disp);
  font-weight:800;
  font-size:clamp(46px,5vw,68px);
  line-height:.9;
  letter-spacing:.01em;
}
.sb-label{
  margin-top:10px;
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(26,13,4,.72);
}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:64px;
  align-items:center;
}
.about-media{ position:relative; max-width:540px; }
.about-media .ph{ aspect-ratio:16/10; }
.feature-list{ list-style:none; margin-top:34px; display:flex; flex-direction:column; gap:1px; }
.feature{
  display:flex; gap:18px; align-items:flex-start;
  padding:22px 0;
  border-top:1px solid var(--line);
}
.feature:last-child{ border-bottom:1px solid var(--line); }
.feature__ic{
  width:34px;height:34px;flex:none;color:var(--accent-hi);
  border:1px solid var(--line-strong);
  display:grid;place-items:center;
}
.feature__ic svg{ width:18px;height:18px; }
.feature h4{
  font-family:var(--f-disp);
  font-weight:700;
  font-size:21px;
  text-transform:uppercase;
  letter-spacing:.02em;
}
.feature p{ color:var(--muted); font-size:15px; margin-top:4px; text-wrap:pretty; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ background:var(--steel-900); }
.contact-grid{
  max-width:720px;
  margin:0 auto;
  border:1px solid var(--line);
}
.form-wrap{ padding:48px 46px; }
.info-wrap{
  padding:48px 42px;
  background:var(--steel-950);
  border-left:1px solid var(--line);
}

.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-row--3{ grid-template-columns:1fr 1fr 1fr; }
.field{ margin-bottom:18px; }
.field label{
  display:block;
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:9px;
}
.field label .req{ color:var(--accent-hi); }
.field input,
.field select,
.field textarea{
  width:100%;
  background:var(--ink);
  border:1px solid var(--line-strong);
  color:var(--fg);
  font-family:var(--f-body);
  font-size:15px;
  padding:13px 14px;
  transition:.15s;
}
.field textarea{ resize:vertical; min-height:120px; }
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--accent);
  background:var(--steel-900);
}
.field input::placeholder,
.field textarea::placeholder{ color:var(--muted-dim); }
.field select{ appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23f2691f' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:38px;
}
.field.invalid input,
.field.invalid select,
.field.invalid textarea{ border-color:#e0533a; }
.field .err{ display:none; color:#e8806c; font-size:12px; font-family:var(--f-mono); margin-top:6px; }
.field.invalid .err{ display:block; }

.form-note{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.05em;
  color:var(--muted-dim);
  margin-top:16px;
  line-height:1.6;
}
.form-success{
  display:none;
  border:1px solid var(--accent);
  background:rgba(242,105,31,.08);
  padding:38px 34px;
  text-align:left;
}
.form-success.show{ display:block; }
.form-success h3{
  font-family:var(--f-disp); font-weight:700; font-size:30px;
  text-transform:uppercase; color:var(--accent-hi);
}
.form-success p{ color:var(--fg-soft); margin-top:10px; }

/* API error message shown on fetch failure */
.form-api-error{
  font-size:13px; color:#e8806c; font-family:var(--f-mono);
  background:rgba(232,128,108,.08); border:1px solid rgba(232,128,108,.3);
  padding:12px 14px; margin-bottom:14px;
}
.form-submit-row{ margin-top:4px; }

/* Info column */
.info-block + .info-block{ margin-top:30px; padding-top:30px; border-top:1px solid var(--line); }
.info-k{
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--accent-hi); margin-bottom:12px;
}
.info-v{ font-size:17px; color:var(--fg); line-height:1.7; }
.info-v a:hover{ color:var(--accent-hi); }
.hours-row{ display:flex; justify-content:space-between; gap:16px; padding:6px 0; font-size:15px; }
.hours-row span:last-child{ color:var(--muted); font-family:var(--f-mono); font-size:13px; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--ink); border-top:1px solid var(--line); }
.footer-top{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:40px;
  padding:64px 0 54px;
}
.footer-brand p{ color:var(--muted); margin-top:18px; max-width:34ch; font-size:15px; }
.footer-col h5{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted-dim); margin-bottom:18px;
}
.footer-col ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
.footer-col a{ color:var(--fg-soft); font-size:15px; transition:.15s; }
.footer-col a:hover{ color:var(--accent-hi); }
.footer-bottom{
  border-top:1px solid var(--line);
  padding:24px 0;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--muted-dim);
}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
  .reveal.in{ opacity:1; transform:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  :root{ --gut:28px; }
  .about-grid{ gap:44px; }
}
@media (max-width:960px){
  .service-grid{ grid-template-columns:repeat(2,1fr); }
  .service-card:nth-child(3n){ border-right:1px solid var(--line); }
  .service-card:nth-child(2n){ border-right:none; }
  .cap-grid{ grid-template-columns:1fr; }
  .step-grid{ grid-template-columns:repeat(2,1fr); }
  .step{ border-left:none; border-top:1px solid var(--line); padding:30px 0; }
  .step:nth-child(2n){ padding-left:28px; border-left:1px solid var(--line); }
  .about-grid{ grid-template-columns:1fr; }
  .about-media{ max-width:460px; }
  .contact-grid{ grid-template-columns:1fr; }
  .hero-stats{ grid-template-columns:repeat(2,1fr); }
  .hero-stats .hs:nth-child(2){ border-right:none; }
  .hero-stats .hs:nth-child(1),.hero-stats .hs:nth-child(2){ border-bottom:1px solid var(--line); }
  .stats-inner{ grid-template-columns:repeat(2,1fr); }
  .sb:nth-child(2){ border-right:none; }
  .sb:nth-child(1),.sb:nth-child(2){ border-bottom:1px solid rgba(26,13,4,.18); }
  .footer-top{ grid-template-columns:1fr 1fr; gap:32px; }
}
/* Collapse the desktop nav to a hamburger before the full link row + phone +
   CTA would run out of room in the container. */
@media (max-width:1160px){
  .menu-toggle{ display:flex; }
  .nav-links{
    position:fixed; inset:0 0 0 auto;
    width:min(78vw,340px);
    background:var(--steel-950);
    border-left:1px solid var(--line);
    flex-direction:column; align-items:flex-start;
    padding:100px 36px 40px; gap:8px;
    transform:translateX(100%); transition:transform .3s ease;
  }
  .nav-links.open{ transform:none; }
  .nav-links li{ width:100%; }
  .nav-links a{ display:block; padding:14px 0; font-size:14px; border-bottom:1px solid var(--line); width:100%; }
  .menu-toggle.active span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .menu-toggle.active span:nth-child(2){ opacity:0; }
  .menu-toggle.active span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  /* Mobile/hamburger: drop the whole right cluster (phone + CTA) so only the
     hamburger sits opposite the logo — no overlap. The CTA lives in the drawer. */
  .nav-right{ display:none; }
  .nav-cta-mobile{ display:block; margin-top:14px; border-bottom:none !important; }
  .nav-cta-mobile a{ border-bottom:none !important; padding:15px 26px !important; font-size:16px !important; }
}
@media (max-width:480px){
  :root{ --gut:18px; }
  .brand{ font-size:20px; }
  .brand__mark{ width:34px; height:34px; }
}
@media (max-width:360px){
  .brand{ font-size:18px; }
}
@media (max-width:900px){
  .hero-inner{
    grid-template-columns:1fr;
    gap:0;
    padding-top:0;
  }
  .hero-emblem-wrap{
    position:absolute;
    inset:0;
    z-index:0;
    pointer-events:none;
  }
  .hero-emblem{
    max-width:min(540px, 82vw);
    opacity:.16;
    filter:none;
  }
  .hero-copy{ padding:40px 0; }
}
@media (max-width:760px){
  .section{ padding:84px 0; }
  .section-head{ flex-direction:column; align-items:flex-start; gap:8px; margin-bottom:42px; }
  .form-wrap{ padding:34px 26px; }
}
@media (max-width:560px){
  .service-grid{ grid-template-columns:1fr; }
  .service-card{ border-right:none !important; }
  .step-grid{ grid-template-columns:1fr; }
  .step:nth-child(2n){ padding-left:0; border-left:none; }
  /* Compact, scannable thumbnail grid — tap any tile to expand */
  .gallery-grid{
    grid-template-columns:repeat(3,1fr);
    grid-auto-rows:auto;
    grid-auto-flow:row;
    gap:8px;
  }
  .gallery-grid .ph{ aspect-ratio:1; height:auto; }
  .g-wide{ grid-column:span 1; }
  .g-tall{ grid-row:span 1; }
  .gallery-grid .ph-cap{ display:none; }
  .gallery-grid .ph::after{ background:linear-gradient(to top, rgba(8,9,11,.5), transparent 55%); }
  .lb-prev,.lb-next{ width:44px; height:44px; font-size:24px; }
  .lb-prev{ left:6px; }
  .lb-next{ right:6px; }
  .lb-close{ top:10px; right:10px; }
  .lb-cap{ font-size:11px; }
  .hero-stats{ grid-template-columns:1fr; }
  .hero-stats .hs{ border-right:none; border-bottom:1px solid var(--line); }
  .stats-inner{ grid-template-columns:1fr; }
  .sb{ border-right:none; border-bottom:1px solid rgba(26,13,4,.18); }
  .form-row,.form-row--3{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; }
}
