/* ============================================================
   Johnson Metal Works — shared stylesheet (multi-page site)
   Dark brushed-steel + electric arc-light theme.
   ============================================================ */

/* ============================== TOKENS ============================== */
:root{
  --ink:#0F1216;
  --panel:#161B21;
  --card:#1E242C;
  --edge:#2F3741;
  --edge-2:#3C4651;

  --steel-lo:#6B7280;
  --steel-mid:#9AA1AB;
  --steel-hi:#DCE0E5;

  --text:#C7CCD4;
  --text-dim:#8A92A0;

  --arc:#CBE0FF;
  --arc-edge:#6E8FE8;
  --arc-soft:#9FBEF5;

  --maxw:1180px;
  --gut:clamp(20px,5vw,56px);

  --f-display:"Saira Condensed",system-ui,sans-serif;
  --f-body:"Archivo",system-ui,-apple-system,sans-serif;

  --tint:linear-gradient(90deg,#3A6FD0 0%,#BFD6FF 18%,#FFFFFF 40%,#E6EEFF 56%,#9FBEF5 76%,#3A60C8 100%);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
section[id],#main,#top{scroll-margin-top:90px}
body{
  font-family:var(--f-body);
  background:var(--ink);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:rgba(150,185,255,.30);color:#fff}
:focus-visible{outline:2px solid var(--arc);outline-offset:3px;border-radius:2px}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;z-index:100;background:var(--arc);color:#11151A;
  padding:.7rem 1.1rem;font-weight:700;font-size:.86rem;border-radius:0 0 4px 0;text-transform:uppercase;letter-spacing:.04em}
.skip:focus{left:0}

.brushed{background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.014) 0 1px,rgba(0,0,0,.018) 1px 3px)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ============================== LAYOUT ============================== */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
.plate{padding:clamp(56px,8vw,108px) 0}
.plate-sm{padding:clamp(40px,5vw,64px) 0}
.eyebrow{
  font-family:var(--f-body);font-weight:700;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--arc);display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--arc);display:inline-block}

h1,h2,h3{font-family:var(--f-display);font-weight:700;line-height:1.02;letter-spacing:.005em}
.h2{font-size:clamp(2rem,4.6vw,3.4rem);text-transform:uppercase;color:var(--steel-hi);margin-bottom:.5em;max-width:20ch}
.lede{font-size:clamp(1.02rem,1.5vw,1.18rem);color:var(--text-dim);max-width:62ch}
.prose p{color:var(--text-dim);font-size:1.02rem;line-height:1.7;margin-bottom:1.1rem;max-width:68ch}
.prose h3{color:var(--steel-hi);text-transform:uppercase;font-size:1.5rem;letter-spacing:.02em;margin:2.2rem 0 .9rem}
.prose h2{color:var(--steel-hi);text-transform:uppercase;font-size:clamp(1.6rem,3vw,2.2rem);letter-spacing:.015em;margin:2.4rem 0 1rem}
.prose ul{list-style:none;margin:0 0 1.4rem;display:grid;gap:.7rem;max-width:64ch}
.prose ul li{position:relative;padding-left:1.7rem;color:var(--text);font-size:1.01rem}
.prose ul li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;
  background:var(--arc);box-shadow:0 0 8px 1px rgba(150,185,255,.5)}
.prose a:not(.btn){color:var(--arc-soft);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--edge-2)}
.prose a:not(.btn):hover{color:var(--arc)}

.metal{background:linear-gradient(176deg,#F2F4F6 4%,#C3C8CE 30%,#878E97 54%,#E4E7EA 72%,#A4ABB3 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 1px 0 rgba(0,0,0,.35)}

/* ============================== WELD SEAM ============================== */
.seam{position:relative;height:2px;width:100%;background:var(--tint);background-size:220% 100%;animation:heat-drift 26s linear infinite}
.seam::before{content:"";position:absolute;inset:-7px 0;background:var(--tint);background-size:220% 100%;filter:blur(11px);opacity:.42;animation:heat-drift 26s linear infinite}
@keyframes heat-drift{to{background-position:220% 0}}

/* ============================== BUTTONS ============================== */
.btn{display:inline-flex;align-items:center;gap:.55rem;justify-content:center;
  font-family:var(--f-body);font-weight:700;font-size:.92rem;letter-spacing:.02em;
  padding:.92rem 1.5rem;border-radius:3px;cursor:pointer;border:1px solid transparent;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease;text-transform:uppercase}
.btn svg{width:17px;height:17px}
.btn-arc{color:#11151A;border:none;background:linear-gradient(180deg,#F6F8FB,#D2DAE2 55%,#B7C0CB);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset,0 8px 24px -8px rgba(150,185,255,.5)}
.btn-arc:hover{transform:translateY(-2px);box-shadow:0 1px 0 rgba(255,255,255,.7) inset,0 14px 30px -8px rgba(150,185,255,.7)}
.btn-steel{color:var(--steel-hi);background:linear-gradient(180deg,#2A323B,#222931);border:1px solid var(--edge-2);
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset}
.btn-steel:hover{transform:translateY(-2px);border-color:var(--steel-lo);color:#fff}

/* ============================== NAV ============================== */
header.nav{position:sticky;top:0;z-index:60;background:rgba(15,18,22,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--edge)}
.nav-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.5rem;height:74px}
.brand{display:flex;align-items:center;gap:.72rem;flex-shrink:0;justify-self:start}
.brand .mark{width:34px;height:34px;flex-shrink:0}
.brand-txt{display:flex;flex-direction:column;line-height:1}
.brand-txt b{font-family:var(--f-display);font-weight:800;font-size:1.16rem;letter-spacing:.04em;text-transform:uppercase;color:var(--steel-hi)}
.brand-txt span{font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--text-dim);margin-top:3px;font-weight:600}
.nav-links{display:flex;align-items:center;gap:2.1rem;justify-self:center}
.nav-links a.link{font-weight:600;font-size:.86rem;letter-spacing:.04em;color:var(--text-dim);text-transform:uppercase;transition:color .15s ease;position:relative;padding:.3rem 0}
.nav-links a.link:hover{color:var(--steel-hi)}
.nav-links a.link[aria-current="page"]{color:var(--steel-hi)}
.nav-links a.link[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--arc)}
.nav-cta{display:flex;align-items:center;gap:1.15rem;justify-self:end}
.nav-phone{font-weight:700;color:var(--steel-hi);font-size:.9rem;display:flex;align-items:center;gap:.45rem;white-space:nowrap}
.nav-phone svg{width:15px;height:15px;color:var(--arc)}
.hamburger{display:none;background:none;border:1px solid var(--edge-2);border-radius:4px;width:44px;height:40px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.hamburger span{width:20px;height:2px;background:var(--steel-hi);transition:.25s}
.hamburger.on span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.on span:nth-child(2){opacity:0}
.hamburger.on span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================== PAGE HERO (home) ============================== */
.hero{position:relative;overflow:hidden;background:var(--ink)}
.hero::before{content:"";position:absolute;top:-22%;right:-12%;width:62vw;height:62vw;max-width:820px;max-height:820px;
  background:radial-gradient(circle,rgba(120,160,255,.16),rgba(110,140,235,.06) 38%,transparent 66%);pointer-events:none;z-index:0}
.hero::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;z-index:0;
  background:repeating-linear-gradient(125deg,rgba(255,255,255,.012) 0 2px,transparent 2px 9px)}
.hero-inner{position:relative;z-index:2;padding:clamp(52px,8vw,96px) 0 clamp(36px,5vw,56px)}
.hero h1{font-size:clamp(2.7rem,7.4vw,5.8rem);text-transform:uppercase;letter-spacing:.004em;margin:.2em 0 .42em;max-width:16ch}
.hero h1 .spark{position:relative;background:linear-gradient(180deg,#FFFFFF,#DCE8FF 55%,#A9C2F0);
  -webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 30px rgba(150,185,255,.45)}
.hero .lede{font-size:clamp(1.05rem,1.7vw,1.26rem);color:#AEB6C2;max-width:56ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:2rem}
.hero-bead{position:relative;height:2px;margin-top:clamp(36px,5vw,54px);overflow:visible}
.hero-bead .seam{transform:scaleX(0);transform-origin:left center;animation:lay-bead 1.5s .25s cubic-bezier(.45,0,.1,1) forwards}
.hero-bead .torch{position:absolute;top:50%;left:0;width:14px;height:14px;border-radius:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,#FFFFFF,#CFE0FF 38%,#8FB0F0 72%);
  box-shadow:0 0 16px 5px rgba(170,200,255,.9),0 0 40px 14px rgba(120,160,255,.45);
  animation:travel 1.5s .25s cubic-bezier(.45,0,.1,1) forwards;opacity:0}
@keyframes lay-bead{to{transform:scaleX(1)}}
@keyframes travel{0%{left:0;opacity:0}8%{opacity:1}90%{left:100%;opacity:1}100%{left:100%;opacity:0}}

/* ============================== INTERIOR PAGE HERO ============================== */
.page-hero{position:relative;overflow:hidden;background:var(--panel);border-bottom:1px solid var(--edge)}
.page-hero::before{content:"";position:absolute;top:-30%;right:-10%;width:50vw;height:50vw;max-width:640px;max-height:640px;
  background:radial-gradient(circle,rgba(120,160,255,.13),transparent 66%);pointer-events:none}
.page-hero-inner{position:relative;z-index:2;padding:clamp(40px,6vw,70px) 0 clamp(34px,5vw,52px)}
.page-hero h1{font-size:clamp(2.2rem,5.2vw,4rem);text-transform:uppercase;color:var(--steel-hi);max-width:20ch;margin-bottom:.5rem}
.page-hero .lede{margin-top:.4rem}

/* breadcrumb */
.crumbs{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;font-size:.78rem;letter-spacing:.04em;color:var(--text-dim);margin-bottom:1.1rem}
.crumbs a{color:var(--text-dim);text-transform:uppercase;font-weight:600}
.crumbs a:hover{color:var(--arc)}
.crumbs span.sep{color:var(--edge-2)}
.crumbs span[aria-current]{color:var(--steel-mid);text-transform:uppercase;font-weight:600}

/* ============================== TRUST STRIP ============================== */
.trust{border-top:1px solid var(--edge);border-bottom:1px solid var(--edge);background:var(--panel)}
.trust-row{display:flex;flex-wrap:wrap;align-items:center;gap:0;justify-content:space-between}
.trust-item{display:flex;align-items:center;gap:.6rem;padding:1.05rem 0;font-family:var(--f-body);font-weight:700;font-size:.78rem;letter-spacing:.13em;text-transform:uppercase;color:var(--steel-mid);flex:1 1 auto;justify-content:center}
.trust-item svg{width:18px;height:18px;color:var(--arc);flex-shrink:0}
.trust-item + .trust-item{border-left:1px solid var(--edge)}

/* ============================== SERVICE CARDS ============================== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:3rem}
.svc{position:relative;background:var(--card);border:1px solid var(--edge);border-radius:6px;padding:2rem 1.7rem 1.8rem;overflow:hidden;display:flex;flex-direction:column;
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.svc::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:linear-gradient(90deg,var(--arc),var(--arc-edge));transform:scaleX(0);transform-origin:left;transition:transform .28s ease}
.svc:hover{transform:translateY(-4px);border-color:var(--edge-2);box-shadow:0 18px 40px -22px rgba(0,0,0,.8)}
.svc:hover::before{transform:scaleX(1)}
.svc-ico{width:48px;height:48px;border-radius:5px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#252C35,#1B2129);border:1px solid var(--edge-2);margin-bottom:1.2rem}
.svc-ico svg{width:26px;height:26px;color:var(--arc-soft)}
.svc h3{font-size:1.35rem;text-transform:uppercase;color:var(--steel-hi);margin-bottom:.5rem;letter-spacing:.02em}
.svc p{font-size:.95rem;color:var(--text-dim);line-height:1.62}
.svc .svc-more{margin-top:1.1rem;font-family:var(--f-body);font-weight:700;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--arc);display:inline-flex;align-items:center;gap:.4rem}
.svc .svc-more svg{width:14px;height:14px;transition:transform .2s ease}
a.svc:hover .svc-more svg{transform:translateX(3px)}
.svc-foot{margin-top:2.6rem;text-align:center;font-size:.96rem;color:var(--text-dim)}
.svc-foot b{color:var(--steel-mid);font-weight:600}

/* ============================== SPLIT / FEATURE ============================== */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,84px);align-items:center}
.split.rev{grid-template-columns:.95fr 1.05fr}
.panel-bg{background:var(--panel)}
.deal{list-style:none;margin-top:1.9rem;display:grid;gap:1px;background:var(--edge);border:1px solid var(--edge);border-radius:6px;overflow:hidden}
.deal li{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 1.3rem;background:var(--card)}
.deal .chk{width:26px;height:26px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#EEF2F8,#AFBCCD)}
.deal .chk svg{width:14px;height:14px;color:#15191E}
.deal b{color:var(--steel-hi);font-family:var(--f-body);font-weight:700;font-size:.98rem}
.aside-card{position:relative;background:var(--card);border:1px solid var(--edge);border-radius:8px;padding:clamp(2rem,3.5vw,2.8rem);overflow:hidden}
.aside-card::after{content:"";position:absolute;bottom:-40%;left:-20%;width:90%;height:90%;background:radial-gradient(circle,rgba(120,160,255,.16),transparent 64%);pointer-events:none}
.signoff{font-family:var(--f-display);font-weight:700;text-transform:uppercase;color:var(--steel-hi);font-size:1.5rem;letter-spacing:.03em;position:relative;z-index:1;line-height:1.05}
.signoff small{display:block;font-family:var(--f-body);font-weight:600;font-size:.72rem;letter-spacing:.2em;color:var(--arc);margin-top:.6rem}
.stat-row{display:flex;gap:2.2rem;margin-top:1.8rem;position:relative;z-index:1;flex-wrap:wrap}
.stat .n{font-family:var(--f-display);font-weight:800;font-size:2.4rem;line-height:1;color:var(--steel-hi)}
.stat .l{font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;color:var(--text-dim);margin-top:.4rem;font-weight:600}

/* ============================== PROCESS STEPS ============================== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:3rem;border:1px solid var(--edge);border-radius:8px;overflow:hidden;background:var(--card)}
.step{padding:2.2rem 1.9rem;position:relative}
.step + .step{border-left:1px solid var(--edge)}
.step .num{font-family:var(--f-display);font-weight:800;font-size:1.05rem;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--arc);border:2px solid var(--edge-2);background:var(--ink);margin-bottom:1.2rem;letter-spacing:.04em;box-shadow:0 0 0 4px rgba(150,185,255,.08)}
.step h3{font-size:1.28rem;text-transform:uppercase;color:var(--steel-hi);margin-bottom:.5rem;letter-spacing:.02em}
.step p{font-size:.94rem;color:var(--text-dim)}

/* ============================== JOBS LIST ============================== */
.job-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;margin-top:2.6rem;background:var(--edge);border:1px solid var(--edge);border-radius:6px;overflow:hidden}
.job{display:flex;align-items:center;gap:1rem;padding:1.05rem 1.4rem;background:var(--panel)}
.job .tick{width:8px;height:8px;border-radius:50%;background:var(--arc);flex-shrink:0;box-shadow:0 0 9px 2px rgba(150,185,255,.55)}
.job span{font-weight:500;color:var(--text);font-size:.98rem}

/* ============================== CHIPS / SERVICE AREA ============================== */
.chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.9rem}
.chip{font-family:var(--f-body);font-weight:600;font-size:.86rem;letter-spacing:.03em;padding:.5rem 1rem;border-radius:3px;color:var(--steel-mid);background:var(--card);border:1px solid var(--edge);transition:border-color .15s ease,color .15s ease}
a.chip:hover{border-color:var(--steel-lo);color:var(--steel-hi)}
.chip.home{color:#11151A;background:linear-gradient(180deg,#EEF2F8,#C2CCDA);border:none;font-weight:700}
.chips-county{margin-top:.7rem}
.chips-county .chip{background:transparent;color:var(--text-dim);border-color:var(--edge-2);font-weight:600}
.area-map{position:relative;aspect-ratio:1/.82;border:1px solid var(--edge);border-radius:8px;overflow:hidden;background:radial-gradient(circle at 52% 46%,rgba(120,160,255,.13),transparent 58%),var(--card);display:flex;align-items:center;justify-content:center}
.area-map .ring{position:absolute;border:1px solid var(--edge-2);border-radius:50%}
.area-map .r1{width:38%;height:46%}
.area-map .r2{width:62%;height:74%;border-style:dashed;border-color:var(--edge)}
.area-map .r3{width:88%;height:104%;border-color:rgba(63,71,81,.5)}
.area-map .pin{position:relative;z-index:2;text-align:center}
.area-map .dot{width:16px;height:16px;border-radius:50%;margin:0 auto .6rem;background:radial-gradient(circle,#FFFFFF,#BFD6FF 60%);box-shadow:0 0 14px 4px rgba(150,185,255,.7)}
.area-map .pin b{font-family:var(--f-display);font-weight:700;text-transform:uppercase;color:var(--steel-hi);font-size:1.15rem;letter-spacing:.06em;display:block}
.area-map .pin span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);font-weight:600}
.area-map .map-cap{position:absolute;bottom:14px;left:0;right:0;text-align:center;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);font-weight:600;z-index:2}

/* link grid (towns / services index) */
.link-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:2rem}
.link-tile{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:1rem 1.2rem;background:var(--card);border:1px solid var(--edge);border-radius:6px;color:var(--steel-hi);font-weight:600;font-size:.98rem;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.link-tile:hover{transform:translateY(-3px);border-color:var(--edge-2);box-shadow:0 14px 30px -20px rgba(0,0,0,.8)}
.link-tile svg{width:16px;height:16px;color:var(--arc);flex-shrink:0;transition:transform .2s ease}
.link-tile:hover svg{transform:translateX(3px)}
.link-tile small{display:block;color:var(--text-dim);font-weight:500;font-size:.8rem;margin-top:.2rem}

/* ============================== CTA BAND ============================== */
.cta-band{position:relative;overflow:hidden;background:var(--panel);border-top:1px solid var(--edge);border-bottom:1px solid var(--edge)}
.cta-band::before{content:"";position:absolute;top:-40%;left:50%;transform:translateX(-50%);width:70vw;height:70vw;max-width:760px;max-height:760px;background:radial-gradient(circle,rgba(120,160,255,.14),transparent 64%);pointer-events:none}
.cta-inner{position:relative;z-index:1;text-align:center;padding:clamp(48px,7vw,84px) 0;display:flex;flex-direction:column;align-items:center}
.cta-inner h2{font-size:clamp(1.9rem,4vw,3rem);text-transform:uppercase;color:var(--steel-hi);max-width:22ch}
.cta-inner p{color:var(--text-dim);max-width:54ch;margin:.9rem auto 0;font-size:1.05rem}
.cta-inner .hero-cta{justify-content:center}

/* ============================== FAQ ============================== */
.faq-list{margin-top:2.6rem;display:grid;gap:14px;max-width:880px}
.faq-item{background:var(--card);border:1px solid var(--edge);border-radius:6px;overflow:hidden;transition:border-color .2s ease}
.faq-item[open]{border-color:var(--edge-2)}
.faq-item summary{list-style:none;cursor:pointer;padding:1.15rem 1.4rem;display:flex;align-items:center;justify-content:space-between;gap:1.2rem;font-family:var(--f-body);font-weight:700;font-size:1.02rem;color:var(--steel-hi);transition:color .15s ease}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:#fff}
.faq-item summary::after{content:"";width:11px;height:11px;flex-shrink:0;border-right:2px solid var(--arc);border-bottom:2px solid var(--arc);transform:rotate(45deg) translateY(-2px);transition:transform .2s ease}
.faq-item[open] summary::after{transform:rotate(-135deg) translateY(0)}
.faq-a{padding:0 1.4rem 1.3rem}
.faq-a p{color:var(--text-dim);font-size:.97rem;line-height:1.64;max-width:66ch}

/* ============================== CONTACT ============================== */
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(40px,6vw,80px);position:relative;z-index:1}
.contact-info .lede{margin-bottom:2rem}
.contact-line{display:flex;align-items:center;gap:1rem;padding:1.1rem 0;border-top:1px solid var(--edge)}
.contact-line:last-of-type{border-bottom:1px solid var(--edge)}
.contact-line .ci{width:42px;height:42px;border-radius:5px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#252C35,#1B2129);border:1px solid var(--edge-2)}
.contact-line .ci svg{width:19px;height:19px;color:var(--arc)}
.contact-line .ct b{display:block;font-family:var(--f-body);font-weight:700;color:var(--steel-hi);font-size:1rem}
.contact-line .ct span{font-size:.85rem;color:var(--text-dim)}
.form-card{background:var(--card);border:1px solid var(--edge);border-radius:8px;padding:clamp(1.6rem,3vw,2.4rem)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:700;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--steel-mid);margin-bottom:.5rem}
.field input,.field textarea,.field select{width:100%;font-family:var(--f-body);font-size:1rem;color:var(--steel-hi);background:var(--ink);border:1px solid var(--edge-2);border-radius:4px;padding:.85rem .95rem;transition:border-color .18s ease,box-shadow .18s ease}
.field input::placeholder,.field textarea::placeholder{color:#8A92A0}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--arc);box-shadow:0 0 0 3px rgba(150,185,255,.16)}
.field textarea{resize:vertical;min-height:118px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-note{font-size:.82rem;color:var(--text-dim);margin-top:1rem;text-align:center}
.form-msg{display:none;padding:1.1rem 1.2rem;border-radius:5px;margin-bottom:1.2rem;font-size:.94rem;font-weight:500}
.form-msg.ok{display:block;background:rgba(74,222,128,.1);border:1px solid rgba(74,222,128,.35);color:#86efac}
.form-msg.err{display:block;background:rgba(255,79,44,.1);border:1px solid rgba(255,79,44,.4);color:#ffae9a}

/* ============================== FOOTER ============================== */
footer.ft{background:var(--panel);padding:clamp(48px,6vw,72px) 0 2.4rem;border-top:1px solid var(--edge)}
.ft-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:2.2rem;border-bottom:1px solid var(--edge)}
.ft-brand{max-width:320px}
.ft-brand .brand{margin-bottom:1rem}
.ft-brand p{color:var(--text-dim);font-size:.92rem}
.ft-col h2{font-family:var(--f-body);font-weight:700;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--steel-mid);margin-bottom:1rem}
.ft-col a,.ft-col p{display:block;color:var(--text-dim);font-size:.9rem;margin-bottom:.55rem;transition:color .15s}
.ft-col a:hover{color:var(--arc)}
.ft-bot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding-top:1.8rem;font-size:.82rem;color:var(--text-dim)}
.ft-bot .made{letter-spacing:.04em}

/* ============================== RESPONSIVE ============================== */
@media(max-width:1180px){.nav-links{gap:1.45rem}.nav-cta .nav-phone{display:none}}
@media(max-width:1024px){
  .nav-inner{display:flex;justify-content:space-between}
  .nav-links{position:fixed;top:74px;left:0;right:0;width:100%;flex-direction:column;align-items:stretch;gap:0;background:rgba(15,18,22,.98);backdrop-filter:blur(14px);border-bottom:1px solid var(--edge);padding:.5rem var(--gut) 1.4rem;transform:translateY(-135%);transition:transform .3s ease;z-index:55}
  .nav-links.open{transform:translateY(0)}
  .nav-links a.link{padding:1rem 0;border-bottom:1px solid var(--edge);font-size:1rem}
  .nav-links a.link[aria-current="page"]::after{display:none}
  .hamburger{display:flex}
}
@media(max-width:960px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .split,.split.rev,.contact-grid,.area-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .step + .step{border-left:none;border-top:1px solid var(--edge)}
  .area-map{max-width:460px;margin:0 auto;width:100%}
  .link-grid{grid-template-columns:repeat(2,1fr)}
  .ft-top{grid-template-columns:1fr 1fr}
  .ft-brand{grid-column:1 / -1;max-width:none}
}
@media(max-width:760px){
  .trust-item{flex:1 1 50%;border-left:none!important;padding:.85rem .5rem}
  .trust-item:nth-child(odd){border-right:1px solid var(--edge)}
  .trust-item:nth-child(-n+2){border-bottom:1px solid var(--edge)}
}
@media(max-width:560px){
  .svc-grid,.job-grid,.row2,.link-grid{grid-template-columns:1fr}
  .hero-cta .btn,.cta-inner .btn{width:100%}
  .nav-cta .btn-arc{display:none}
  .ft-top{grid-template-columns:1fr}
  .chips-county .chip{font-size:.8rem}
}

/* ============================== MOTION OFF ============================== */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .hero-bead .seam{transform:scaleX(1)}
  .hero-bead .torch{display:none}
  .reveal{opacity:1!important;transform:none!important}
}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
