/* =========================================================
   SACCUZZO ASPHALT — gritty industrial paving site
   Palette pulled from logo: orange, asphalt black, steel, road-stripe yellow
   ========================================================= */

:root{
  --orange:#ED6A1A;
  --orange-bright:#FF7A1F;
  --orange-deep:#C24E0E;
  --yellow:#F4C20D;
  --asphalt:#0E0E0F;
  --asphalt-2:#161618;
  --steel:#26262A;
  --steel-light:#3A3A40;
  --silver:#B9BCC2;
  --concrete:#E9E6DF;
  --concrete-dim:#C9C6BD;
  --white:#F6F4EF;

  --ff-display:'Anton', Impact, sans-serif;
  --ff-head:'Oswald', sans-serif;
  --ff-body:'Inter', system-ui, sans-serif;

  --ease:cubic-bezier(.16,1,.3,1);
  --pad:clamp(1.25rem, 5vw, 6rem);
}

*{margin:0;padding:0;box-sizing:border-box}
html{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}

body{
  font-family:var(--ff-body);
  background:var(--asphalt);
  color:var(--concrete);
  overflow-x:hidden;
  line-height:1.55;
  cursor:none;
}
@media (max-width:900px){ body{cursor:auto} }

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--orange);color:#000}

/* ---------- Texture overlays ---------- */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)} 20%{transform:translate(-4%,3%)} 40%{transform:translate(3%,-5%)}
  60%{transform:translate(-3%,4%)} 80%{transform:translate(4%,-2%)}
}
.vignette{position:fixed;inset:0;z-index:8999;pointer-events:none;
  box-shadow:inset 0 0 200px 40px rgba(0,0,0,.55);}

/* ---------- Scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:9500;background:rgba(255,255,255,.06)}
.scroll-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--orange),var(--yellow));box-shadow:0 0 12px var(--orange)}

/* ---------- Custom cursor ---------- */
.cursor{position:fixed;top:0;left:0;width:14px;height:14px;border-radius:50%;
  background:var(--orange);z-index:9600;pointer-events:none;transform:translate(-50%,-50%);
  transition:width .25s var(--ease),height .25s var(--ease),background .25s,opacity .3s;mix-blend-mode:difference}
.cursor.is-hover{width:64px;height:64px;background:var(--white)}
.cursor.is-view{width:84px;height:84px;background:var(--orange)}
.cursor.is-view::after{content:'VIEW';position:absolute;inset:0;display:grid;place-items:center;
  font:700 11px/1 var(--ff-head);letter-spacing:.15em;color:#000;mix-blend-mode:normal}
.cursor.is-logo{width:0;height:0;opacity:0}
@media (max-width:900px){.cursor{display:none}}

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader{position:fixed;inset:0;z-index:9990;background:var(--asphalt);
  display:grid;place-items:center;overflow:hidden}
.preloader::before{content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,#000 0 38px,var(--yellow) 38px 76px);opacity:.05}
.preloader__inner{text-align:center;position:relative;z-index:2}
.preloader__word{font-family:var(--ff-display);font-size:clamp(2.5rem,9vw,7rem);letter-spacing:.02em;
  color:var(--white);line-height:.9}
.preloader__line{height:4px;width:min(60vw,420px);background:rgba(255,255,255,.1);margin:1.2rem auto;overflow:hidden}
.preloader__line span{display:block;height:100%;width:0;background:var(--orange)}
.preloader__sub{font-family:var(--ff-head);letter-spacing:.4em;font-size:.8rem;color:var(--orange)}
.preloader__count{font-family:var(--ff-head);font-size:.85rem;color:var(--silver);margin-top:1rem;letter-spacing:.2em}
.preloader.done{transform:translateY(-100%);transition:transform 1s var(--ease)}

/* =========================================================
   NAV
   ========================================================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:8000;
  display:flex;align-items:center;gap:2rem;
  padding:1.1rem var(--pad);
  transition:padding .4s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease);
}
.nav.scrolled{background:rgba(14,14,15,.82);backdrop-filter:blur(14px);
  padding:.6rem var(--pad);box-shadow:0 1px 0 rgba(255,255,255,.06),0 14px 40px rgba(0,0,0,.5)}
.nav__brand img{height:46px;transition:height .4s var(--ease);filter:drop-shadow(0 4px 10px rgba(0,0,0,.5))}
.nav.scrolled .nav__brand img{height:38px}
.nav__links{margin-left:auto;display:flex;gap:2.2rem}
.nav__links a{font-family:var(--ff-head);font-weight:500;text-transform:uppercase;letter-spacing:.12em;
  font-size:.82rem;color:var(--concrete-dim);position:relative;padding:.3rem 0}
.nav__links a::after{content:'';position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--orange);transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--white)}
.nav__links a:hover::after{width:100%}
.nav__burger{display:none;background:none;border:0;width:34px;height:34px;flex-direction:column;justify-content:center;gap:7px;cursor:pointer;margin-left:auto}
.nav__burger span{display:block;height:2px;width:100%;background:var(--white);transition:.3s var(--ease)}
.nav.open .nav__burger span:nth-child(1){transform:translateY(4.5px) rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){transform:translateY(-4.5px) rotate(-45deg)}

/* ---------- Buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--ff-head);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;
  padding:1rem 1.8rem;border:2px solid transparent;overflow:hidden;isolation:isolate;
  transition:color .4s var(--ease),border-color .4s var(--ease)}
.btn span{position:relative;z-index:2}
.btn::before{content:'';position:absolute;inset:0;z-index:1;transform:translateY(101%);transition:transform .5s var(--ease)}
.btn:hover::before{transform:translateY(0)}
.btn--orange{background:var(--orange);color:#140a02}
.btn--orange::before{background:var(--white)}
.btn--orange:hover{color:#000}
.btn--ghost{border-color:rgba(255,255,255,.35);color:var(--white)}
.btn--ghost::before{background:var(--orange)}
.btn--ghost:hover{color:#140a02;border-color:var(--orange)}
.btn--block{width:100%;margin-top:.6rem}
.nav__cta{padding:.7rem 1.3rem}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--pad) clamp(2rem,5vh,4rem);overflow:hidden}
.hero__media{position:absolute;inset:-12% 0;z-index:0;will-change:transform}
.hero__media img{width:100%;height:100%;object-fit:cover;filter:contrast(1.08) saturate(.95) brightness(.78)}
.hero__media-overlay{position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(14,14,15,.55) 0%, rgba(14,14,15,.15) 35%, rgba(14,14,15,.5) 75%, var(--asphalt) 100%),
    radial-gradient(120% 80% at 80% 10%, transparent 40%, rgba(14,14,15,.7) 100%);}
.hero__stripes{position:absolute;left:0;top:0;bottom:0;width:14px;z-index:2;
  background:repeating-linear-gradient(180deg,var(--orange) 0 26px,#000 26px 52px);opacity:.85}

.hero__content{position:relative;z-index:3;max-width:1100px}
.hero__eyebrow{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.25em;font-size:.8rem;
  color:var(--silver);display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem}
.dash{display:inline-block;width:34px;height:3px;background:var(--orange)}
.hero__title{font-family:'Clash Display','Anton',sans-serif;font-weight:700;line-height:.84;letter-spacing:-.015em;
  font-size:clamp(3.4rem,13.5vw,12rem);color:var(--white);margin:.2rem 0 1.4rem}
.hero__title .line{display:block;width:max-content;max-width:calc(100vw - var(--pad) - .5rem);overflow:hidden;padding-bottom:.04em;padding-right:.12em}
.hero__title .line>span{display:block;transform:translateY(110%)}
/* solid line — lit-from-above metallic sheen */
.hero__title .line:not(.line--outline)>span{
  background:linear-gradient(180deg,#ffffff 0%,#f4f1ea 54%,#bfbbb1 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  text-shadow:0 2px 30px rgba(0,0,0,.35)}
/* outline line — refined orange with soft glow */
.hero__title .line--outline>span{
  color:transparent;-webkit-text-stroke:2.5px var(--orange);text-stroke:2.5px var(--orange);
  filter:drop-shadow(0 6px 34px rgba(237,106,26,.22))}
@media(max-width:600px){.hero__title .line--outline>span{-webkit-text-stroke-width:1.5px}}
.hero__lede{font-size:clamp(1rem,1.6vw,1.35rem);max-width:46ch;color:var(--concrete);line-height:1.5}
.hero__actions{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap}

.hero__meta{position:relative;z-index:3;display:flex;justify-content:space-between;align-items:flex-end;
  margin-top:clamp(2.5rem,6vh,4.5rem)}
.hero__phone{display:flex;flex-direction:column;gap:.2rem}
.hero__phone-label{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;color:var(--silver)}
.hero__phone-num{font-family:var(--ff-display);font-size:clamp(1.6rem,3vw,2.4rem);color:var(--white);line-height:1}
.hero__phone:hover .hero__phone-num{color:var(--orange)}
.hero__scroll{display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.25em;font-size:.68rem;color:var(--silver)}
.hero__scroll-line{width:2px;height:54px;background:rgba(255,255,255,.18);overflow:hidden;position:relative}
.hero__scroll-line i{position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--orange);animation:scrolldown 1.8s var(--ease) infinite}
@keyframes scrolldown{0%{top:-50%}100%{top:100%}}
@media(max-width:600px){.hero__scroll{display:none}}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{background:var(--orange);color:#140a02;padding:1rem 0;overflow:hidden;
  border-top:3px solid #000;border-bottom:3px solid #000;position:relative}
.marquee__track{display:flex;align-items:center;gap:1.5rem;white-space:nowrap;width:max-content;will-change:transform}
.marquee__track span{font-family:var(--ff-display);font-size:clamp(1.6rem,3.5vw,2.6rem);text-transform:uppercase;letter-spacing:.02em}
.marquee__track b{color:#140a02;font-size:1rem;opacity:.6}

/* =========================================================
   SECTION SHARED
   ========================================================= */
.eyebrow{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.25em;font-size:.78rem;
  color:var(--orange);display:flex;align-items:center;gap:.8rem}
.h-display{font-family:var(--ff-display);line-height:.9;letter-spacing:.01em;color:var(--white);
  font-size:clamp(2.4rem,6.5vw,6rem)}
.text-orange{color:var(--orange)}
.section-head{padding:clamp(4rem,9vh,8rem) var(--pad) 0;max-width:1100px}
.section-head--center{margin-inline:auto;text-align:center}
.section-head--center .eyebrow{justify-content:center}
.section-head__title{margin:1rem 0}
.section-head__sub{margin-top:1.2rem;max-width:52ch;color:var(--concrete-dim);font-size:1.05rem}
.section-head--center .section-head__sub{margin-inline:auto}

/* reveal base */
.reveal{opacity:0;transform:translateY(40px)}

/* =========================================================
   ABOUT
   ========================================================= */
.about{padding:clamp(4rem,10vh,9rem) var(--pad)}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;max-width:1300px;margin:0 auto}
.about__media{position:relative;aspect-ratio:4/5;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.about__media img{position:absolute;inset:-10% 0;width:100%;height:120%;object-fit:cover;filter:contrast(1.05) brightness(.9)}
.about__badge{position:absolute;right:-1px;bottom:-1px;background:var(--orange);color:#140a02;
  padding:1.2rem 1.6rem;display:flex;align-items:center;gap:.7rem;z-index:2}
.about__badge-big{font-family:var(--ff-display);font-size:3.4rem;line-height:.8}
.about__badge-big i{font-style:normal;font-size:1.6rem;vertical-align:top}
.about__badge-sm{font-family:var(--ff-head);text-transform:uppercase;font-size:.75rem;letter-spacing:.08em;line-height:1.2}
.about__copy{max-width:560px}
.about__text{margin-top:1.3rem;color:var(--concrete-dim);font-size:1.05rem}
.about__text strong{color:var(--white)}
.stats{display:flex;gap:clamp(1rem,4vw,3rem);margin-top:2.5rem;flex-wrap:wrap}
.stat{display:flex;flex-direction:column}
.stat__num{font-family:var(--ff-display);font-size:clamp(2.2rem,4vw,3.4rem);color:var(--orange);line-height:.9}
.stat__label{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--silver);margin-top:.4rem}
@media(max-width:860px){.about__grid{grid-template-columns:1fr}.about__media{aspect-ratio:4/3;max-height:60vh}}

/* =========================================================
   PROCESS — vertical timeline (clear, intuitive)
   ========================================================= */
.process{background:var(--asphalt-2);position:relative;padding-bottom:clamp(4rem,9vh,8rem)}
.steps{position:relative;max-width:1060px;margin:clamp(2.5rem,6vh,5rem) auto 0;padding:0 var(--pad)}
.steps__line{position:absolute;left:50%;top:30px;bottom:30px;width:3px;transform:translateX(-50%);
  background:rgba(255,255,255,.1)}
.steps__line span{position:absolute;left:0;top:0;width:100%;height:0;
  background:linear-gradient(var(--orange),var(--yellow));box-shadow:0 0 14px rgba(237,106,26,.6)}
.step{position:relative;display:grid;grid-template-columns:1fr 78px 1fr;align-items:center;
  gap:clamp(1.2rem,3vw,2.6rem);padding:clamp(1.4rem,3.5vh,2.6rem) 0}
.step__num{grid-column:2;width:70px;height:70px;border-radius:50%;display:grid;place-items:center;
  background:var(--asphalt-2);border:3px solid var(--orange);position:relative;z-index:2}
.step__num span{font-family:var(--ff-display);font-size:2rem;color:var(--orange);line-height:1}
.step__text{grid-column:1;text-align:right}
.step__text h3{font-family:var(--ff-display);font-size:clamp(1.5rem,3vw,2.4rem);color:var(--white);line-height:1.02}
.step__text p{color:var(--concrete-dim);margin-top:.7rem;font-size:1.02rem;max-width:42ch;margin-left:auto}
.step__media{grid-column:3;overflow:hidden;aspect-ratio:16/11;border:1px solid rgba(255,255,255,.1)}
.step__media img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) brightness(.92);
  transition:transform .8s var(--ease)}
.step:hover .step__media img{transform:scale(1.05)}
/* alternate sides */
.step:nth-child(even) .step__text{grid-column:3;text-align:left}
.step:nth-child(even) .step__text p{margin-left:0;margin-right:auto}
.step:nth-child(even) .step__media{grid-column:1}
/* optional add-on step */
.step__addon{display:inline-block;vertical-align:middle;margin-left:.6rem;
  font-family:var(--ff-head);font-weight:600;text-transform:uppercase;letter-spacing:.14em;
  font-size:.6rem;color:var(--orange);border:1px solid var(--orange);border-radius:999px;
  padding:.32em .7em;line-height:1;white-space:nowrap}
.step--optional .step__num{border-style:dashed}
.step--optional .step__media{position:relative}
.step--optional .step__media::after{content:'';position:absolute;inset:0;
  box-shadow:inset 0 0 0 2px rgba(237,106,26,.35);pointer-events:none}
@media(max-width:860px){
  .steps__line{left:26px;top:20px;bottom:20px}
  .step{grid-template-columns:52px 1fr;gap:1rem 1.3rem;align-items:start;
    padding:clamp(1.2rem,3vh,2rem) 0}
  .step__num{grid-column:1;grid-row:1;width:52px;height:52px}
  .step__num span{font-size:1.5rem}
  .step__text,.step:nth-child(even) .step__text{grid-column:2;grid-row:1;text-align:left}
  .step__text p,.step:nth-child(even) .step__text p{margin-left:0;margin-right:0}
  .step__media,.step:nth-child(even) .step__media{grid-column:2;grid-row:2;margin-top:.4rem}
}

/* =========================================================
   WORK / GALLERY
   ========================================================= */
.work{padding-bottom:clamp(4rem,9vh,8rem);overflow:hidden}
.work__head{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;
  padding:0 var(--pad);max-width:1400px;margin:0 auto;flex-wrap:wrap}
.work__nav{display:flex;gap:.7rem}
.work__arrow{width:54px;height:54px;border-radius:50%;border:1px solid rgba(255,255,255,.18);
  background:var(--asphalt-2);color:var(--white);display:flex;align-items:center;justify-content:center;
  cursor:none;transition:background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease),opacity .3s}
.work__arrow svg{width:22px;height:22px}
.work__arrow:hover{background:var(--orange);border-color:var(--orange);color:#140a02;transform:translateY(-2px)}
.work__arrow:disabled{opacity:.3;pointer-events:none}

.work__viewport{margin-top:clamp(2rem,5vh,3.5rem);overflow:hidden;cursor:grab}
.work__viewport.is-dragging{cursor:grabbing}
.work__track{display:flex;gap:clamp(1rem,2vw,1.8rem);padding:0 var(--pad);
  scroll-snap-type:x proximity;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;
  -webkit-overflow-scrolling:touch;padding-bottom:1.2rem}
.work__track::-webkit-scrollbar{display:none}

.workcard{position:relative;flex:0 0 auto;width:clamp(280px,42vw,560px);scroll-snap-align:center;
  border-radius:8px;overflow:hidden;background:#000;cursor:none}
.workcard__media{aspect-ratio:4/3;overflow:hidden}
.workcard__media img{width:100%;height:100%;object-fit:cover;pointer-events:auto;
  transition:transform .9s var(--ease),filter .6s var(--ease);filter:grayscale(.3) contrast(1.05) brightness(.92);
  -webkit-user-drag:none;user-select:none}
.workcard:hover .workcard__media img{transform:scale(1.06);filter:grayscale(0) contrast(1.08) brightness(1)}
.workcard::after{content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(14,14,15,.1) 0%,rgba(14,14,15,0) 35%,rgba(14,14,15,.9) 100%)}
.workcard__no{position:absolute;top:1rem;right:1.2rem;z-index:2;font-family:var(--ff-display);
  font-size:1.5rem;color:var(--white);opacity:.55;letter-spacing:.05em}
.workcard figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:1.6rem 1.4rem 1.3rem;display:flex;flex-direction:column;gap:.25rem}
.workcard figcaption strong{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.02em;
  font-size:clamp(1.2rem,2vw,1.6rem);color:var(--white);line-height:1;font-weight:400}
.workcard figcaption span{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.12em;
  font-size:.72rem;color:var(--orange)}

.work__progress{position:relative;height:3px;border-radius:3px;background:rgba(255,255,255,.1);
  margin:1.5rem var(--pad) 0;max-width:1400px;margin-inline:auto;overflow:hidden}
.work__progress-bar{position:absolute;left:0;top:0;bottom:0;width:25%;border-radius:3px;
  background:linear-gradient(90deg,var(--orange),var(--orange-bright));transition:left .15s linear,width .15s linear}

@media(max-width:700px){
  .work__head{align-items:flex-start;gap:1.4rem}
  .work__nav{display:none}
  .workcard{width:82vw}
}

/* =========================================================
   GUARANTEE BAND
   ========================================================= */
.band{position:relative;padding:clamp(4rem,11vh,9rem) var(--pad);overflow:hidden;
  background:linear-gradient(var(--orange),var(--orange-deep))}
.band__inner{position:relative;z-index:2;max-width:1000px;margin:0 auto;text-align:center;color:#140a02}
.band__quote{font-family:var(--ff-display);font-size:clamp(1.8rem,4.5vw,4rem);line-height:1.02}
.band__by{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.2em;margin-top:1.5rem;font-size:.85rem}
.band__hazard{position:absolute;inset:0;z-index:1;opacity:.12;
  background:repeating-linear-gradient(45deg,#000 0 40px,transparent 40px 80px)}

/* =========================================================
   CONTACT
   ========================================================= */
.contact{padding:clamp(4rem,10vh,9rem) var(--pad);background:var(--asphalt)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem);max-width:1300px;margin:0 auto;align-items:start}
.contact__intro h2{margin:1rem 0}
.contact__text{color:var(--concrete-dim);max-width:44ch;font-size:1.05rem}
.contact__details{list-style:none;margin-top:2.5rem;border-top:1px solid rgba(255,255,255,.1)}
.contact__details li{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.05rem 0;border-bottom:1px solid rgba(255,255,255,.1)}
.contact__k{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;color:var(--silver)}
.contact__v{font-family:var(--ff-head);font-size:1.15rem;color:var(--white)}
a.contact__v:hover{color:var(--orange)}
.contact__placeholder-note{margin-top:1rem;font-size:.78rem;color:var(--steel-light);font-style:italic}

/* form */
.form{background:var(--asphalt-2);border:1px solid rgba(255,255,255,.08);padding:clamp(1.5rem,3vw,2.6rem)}
.form__row{margin-bottom:1.1rem}
.form__row--2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{position:relative}
.field input,.field select,.field textarea{
  width:100%;background:transparent;border:0;border-bottom:2px solid var(--steel-light);
  color:var(--white);font-family:var(--ff-body);font-size:1rem;padding:1.4rem 0 .5rem;outline:none;
  transition:border-color .3s}
.field textarea{resize:vertical;min-height:90px}
.field select{cursor:pointer}
.field select option{background:var(--steel);color:var(--white)}
.field label{position:absolute;left:0;top:1.3rem;color:var(--silver);font-size:1rem;pointer-events:none;
  transition:.3s var(--ease);font-family:var(--ff-head);letter-spacing:.04em}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--orange)}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label,
.field .label--static{top:0;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange)}
.field .label--static{top:0}
.form__success{display:none;margin-top:1.2rem;padding:1rem;background:rgba(237,106,26,.12);
  border-left:3px solid var(--orange);color:var(--concrete);font-size:.9rem}
.form__success em{color:var(--silver)}
.form__success.show{display:block}
@media(max-width:860px){.contact__grid{grid-template-columns:1fr}}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:#0a0a0b;padding:clamp(3rem,6vh,5rem) var(--pad) 2rem;border-top:3px solid var(--orange)}
.footer__top{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.footer__logo img{height:64px}
.footer__nav{display:flex;gap:1.8rem;flex-wrap:wrap}
.footer__nav a{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;color:var(--concrete-dim)}
.footer__nav a:hover{color:var(--orange)}
.footer__phone{font-family:var(--ff-display);font-size:clamp(1.8rem,3vw,2.6rem);color:var(--white)}
.footer__phone:hover{color:var(--orange)}
.footer__line{height:1px;background:rgba(255,255,255,.1);margin:2.2rem 0 1.4rem}
.footer__bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-size:.8rem;color:var(--silver);font-family:var(--ff-head);letter-spacing:.08em}
.footer__credit a{color:var(--orange);font-family:var(--ff-display);letter-spacing:.04em;
  font-size:1rem;position:relative}
.footer__credit a::after{content:'';position:absolute;left:0;bottom:-3px;height:2px;width:0;
  background:var(--orange);transition:width .35s var(--ease)}
.footer__credit a:hover::after{width:100%}

/* =========================================================
   SERVICES — 3D tilt cards
   ========================================================= */
.services2{padding-bottom:clamp(3rem,8vh,7rem)}
.cards{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(1rem,2vw,1.8rem);
  padding:clamp(2.5rem,5vh,4rem) var(--pad) 0;max-width:1300px;margin-inline:auto}
.card3d{perspective:1100px;flex:0 1 calc(33.333% - 1.8rem);min-width:280px}
.card3d__inner{position:relative;height:100%;min-height:430px;border-radius:6px;overflow:hidden;
  border:1px solid rgba(255,255,255,.08);background:var(--asphalt-2);
  transform-style:preserve-3d;transition:transform .25s var(--ease),box-shadow .35s var(--ease);
  box-shadow:0 18px 40px -28px rgba(0,0,0,.9);will-change:transform}
.card3d:hover .card3d__inner{box-shadow:0 40px 80px -30px rgba(0,0,0,.95),0 0 0 1px rgba(237,106,26,.35)}
.card3d__media{position:absolute;inset:0;transform:translateZ(0)}
.card3d__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.25) contrast(1.05) brightness(.62);
  transition:transform .6s var(--ease),filter .5s var(--ease)}
.card3d:hover .card3d__media img{transform:scale(1.08);filter:grayscale(0) contrast(1.08) brightness(.72)}
.card3d__media::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,14,15,.25) 0%,rgba(14,14,15,.55) 45%,rgba(14,14,15,.94) 100%)}
.card3d__glare{position:absolute;inset:0;z-index:3;pointer-events:none;opacity:0;
  background:radial-gradient(420px circle at var(--gx,50%) var(--gy,0%),rgba(255,255,255,.22),transparent 60%);
  transition:opacity .4s var(--ease);mix-blend-mode:overlay}
.card3d:hover .card3d__glare{opacity:1}
.card3d__content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;
  justify-content:flex-end;gap:.55rem;padding:clamp(1.4rem,2.5vw,2rem);transform:translateZ(40px)}
.card3d__index{position:absolute;top:1.4rem;right:clamp(1.4rem,2.5vw,2rem);font-family:var(--ff-display);
  font-size:1.6rem;color:var(--orange);letter-spacing:.05em;opacity:.85}
.card3d__icon{width:46px;height:46px;color:var(--orange);margin-bottom:.2rem}
.card3d__icon svg{width:100%;height:100%}
.card3d__title{font-family:var(--ff-display);font-size:clamp(1.7rem,3vw,2.3rem);color:var(--white);
  line-height:.95;text-transform:uppercase}
.card3d__desc{color:var(--concrete-dim);font-size:.95rem;max-width:34ch}
.card3d__link{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;
  color:var(--orange);display:inline-flex;align-items:center;gap:.4rem;margin-top:.4rem}
.card3d__link i{font-style:normal;transition:transform .3s var(--ease)}
.card3d:hover .card3d__link i{transform:translate(3px,-3px)}
@media(max-width:900px){
  .cards{max-width:480px;flex-direction:column}
  .card3d{flex:1 1 auto}
  .card3d__inner{min-height:340px}
}

/* =========================================================
   TRUST STRIP
   ========================================================= */
.trust{padding:clamp(1.5rem,3vh,2.6rem) var(--pad);background:var(--asphalt-2);
  border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07)}
.trust__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1rem,3vw,2.5rem)}
.trust__item{display:flex;align-items:center;gap:1rem;justify-content:center}
.trust__icon{flex:none;width:42px;height:42px;color:var(--orange)}
.trust__icon svg{width:100%;height:100%}
.trust__text{display:flex;flex-direction:column;line-height:1.25}
.trust__text strong{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.06em;
  font-size:1rem;color:var(--white)}
.trust__text{font-size:.82rem;color:var(--silver)}
@media(max-width:820px){
  .trust__inner{grid-template-columns:1fr;gap:1.1rem;max-width:360px}
  .trust__item{justify-content:flex-start}
}

/* =========================================================
   BEFORE / AFTER SLIDER
   ========================================================= */
.ba{padding-bottom:clamp(4rem,9vh,8rem);background:var(--asphalt)}
.ba__stage{max-width:680px;margin:clamp(2.5rem,5vh,4rem) auto 0;padding:0 var(--pad)}
.ba__wrap{position:relative;aspect-ratio:3/4;overflow:hidden;border:1px solid rgba(255,255,255,.1);
  border-radius:6px;user-select:none;touch-action:pan-y;box-shadow:0 30px 70px -40px rgba(0,0,0,.95)}
.ba__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
/* both layers are full-size; the "before" layer is clipped from the right via clip-path (set in JS) */
.ba__before{position:absolute;inset:0;clip-path:inset(0 50% 0 0);will-change:clip-path}
.ba__divider{position:absolute;top:0;bottom:0;left:50%;width:3px;transform:translateX(-50%);
  background:var(--orange);box-shadow:0 0 18px rgba(237,106,26,.7);pointer-events:none;z-index:3}
.ba__handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:50px;height:50px;border-radius:50%;background:var(--orange);color:#140a02;
  display:flex;align-items:center;justify-content:center;gap:5px;
  box-shadow:0 6px 22px rgba(0,0,0,.5)}
.ba__handle i{width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent}
.ba__handle i:first-child{border-right:8px solid #140a02}
.ba__handle i:last-child{border-left:8px solid #140a02}
.ba__tag{position:absolute;top:1rem;z-index:3;font-family:var(--ff-head);text-transform:uppercase;
  letter-spacing:.16em;font-size:.72rem;padding:.4rem .8rem;border-radius:999px;
  background:rgba(10,10,11,.6);border:1px solid rgba(255,255,255,.14);color:var(--white)}
.ba__tag--before{left:1rem}
.ba__tag--after{right:1rem;color:var(--orange);border-color:rgba(237,106,26,.5)}
.ba__range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:4;
  pointer-events:none}
.ba__wrap{cursor:ew-resize}
@media(max-width:560px){.ba__stage{max-width:none}}

/* =========================================================
   LOCATIONS — 3D Maine map
   ========================================================= */
.locations{position:relative;padding:clamp(3rem,7vh,6rem) var(--pad) clamp(4rem,9vh,8rem);
  background:linear-gradient(180deg,var(--asphalt) 0%,var(--asphalt-2) 100%);overflow:hidden}
.locations::before{content:'';position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:radial-gradient(800px circle at 25% 30%,rgba(237,106,26,.10),transparent 60%)}
.locations__head{position:relative;max-width:1100px;margin:0 auto clamp(2rem,4vh,3.5rem)}
.locations__head .h-display{margin:.8rem 0}
.locations__stage{position:relative;display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(1.5rem,4vw,4rem);
  align-items:center;max-width:1300px;margin-inline:auto}
.locations__canvas{position:relative;width:100%;aspect-ratio:1/1;max-height:560px;
  border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden;
  background:radial-gradient(circle at 50% 40%,rgba(34,34,40,.6),rgba(10,10,11,.9));cursor:grab}
.locations__canvas:active{cursor:grabbing}
.locations__canvas canvas{display:block;width:100%!important;height:100%!important}
.locations__hint{position:absolute;left:1rem;bottom:1rem;z-index:4;font-family:var(--ff-head);
  text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;color:var(--silver);
  background:rgba(10,10,11,.55);padding:.4rem .7rem;border:1px solid rgba(255,255,255,.08);
  border-radius:99px;pointer-events:none;transition:opacity .5s var(--ease)}
.locations__canvas.is-touched .locations__hint{opacity:0}
.locations__active{position:absolute;top:1rem;left:1rem;z-index:4;font-family:var(--ff-display);
  font-size:clamp(1.4rem,2.4vw,2rem);color:var(--orange);text-transform:uppercase;letter-spacing:.03em;
  opacity:0;transform:translateY(-8px);transition:opacity .35s var(--ease),transform .35s var(--ease);
  pointer-events:none;text-shadow:0 0 24px rgba(237,106,26,.5)}
.locations__active.show{opacity:1;transform:translateY(0)}
.locations__list{list-style:none;display:flex;flex-direction:column;gap:.2rem}
.loc-city{display:flex;align-items:center;gap:.9rem;padding:.7rem .9rem;border-radius:5px;cursor:pointer;
  border:1px solid transparent;transition:background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease)}
.loc-city__dot{width:9px;height:9px;border-radius:50%;background:var(--steel-light);flex:none;
  transition:background .3s var(--ease),box-shadow .3s var(--ease),transform .3s var(--ease)}
.loc-city__name{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.1em;
  font-size:1.05rem;color:var(--concrete-dim);transition:color .3s var(--ease)}
.loc-city:hover,.loc-city.is-active{background:rgba(237,106,26,.08);border-color:rgba(237,106,26,.3);transform:translateX(6px)}
.loc-city:hover .loc-city__dot,.loc-city.is-active .loc-city__dot{background:var(--orange);
  box-shadow:0 0 12px 2px rgba(237,106,26,.7);transform:scale(1.25)}
.loc-city:hover .loc-city__name,.loc-city.is-active .loc-city__name{color:var(--white)}
@media(max-width:900px){
  .locations__stage{grid-template-columns:1fr}
  .locations__canvas{max-height:420px}
  .locations__list{display:grid;grid-template-columns:1fr 1fr;gap:.3rem}
}

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lightbox{position:fixed;inset:0;z-index:9700;background:rgba(8,8,9,.94);
  display:flex;align-items:center;justify-content:center;padding:5vw;
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:100%;max-height:90vh;object-fit:contain;border:1px solid rgba(255,255,255,.1);
  transform:scale(.92);transition:transform .5s var(--ease)}
.lightbox.open img{transform:scale(1)}
.lightbox__close{position:absolute;top:1.5rem;right:2rem;background:none;border:0;color:var(--white);
  font-size:2.6rem;cursor:pointer;line-height:1}
.lightbox__close:hover{color:var(--orange)}

/* =========================================================
   MOBILE NAV
   ========================================================= */
@media(max-width:860px){
  .nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__links{position:fixed;inset:0;margin:0;background:rgba(10,10,11,.97);backdrop-filter:blur(10px);
    flex-direction:column;align-items:center;justify-content:center;gap:2rem;
    transform:translateX(100%);transition:transform .5s var(--ease)}
  .nav.open .nav__links{transform:translateX(0)}
  .nav__links a{font-size:1.6rem;font-family:var(--ff-display);color:var(--white)}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
  .hero__title .line>span{transform:none}
}
