/* ===========================================================
   TRINITY XPRESS — cinematic oilfield transport site
   =========================================================== */

:root{
  --bg:        #0A0A0A;
  --bg-2:      #0E0E0E;
  --ink:       #F4F2EE;
  --ink-dim:   #9A968D;
  --ink-faint: #2A2A2A;
  --red:       #CC0000;
  --red-deep:  #8B0000;
  --red-glow:  rgba(204, 0, 0, 0.35);
  --line:      rgba(244, 242, 238, 0.08);
  --line-2:    rgba(244, 242, 238, 0.14);

  --f-display: "Bebas Neue", "Barlow Condensed", sans-serif;
  --f-body:    "Barlow Condensed", system-ui, sans-serif;

  --ease: cubic-bezier(.77,0,.175,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

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

html, body{
  background: var(--bg);
  color: var(--ink);
  font-family: var(--f-body);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  cursor: none;
}

html{ scroll-behavior: auto; }

img, svg{ display: block; max-width: 100%; }
a{ color: inherit; text-decoration: none; }
button{ font: inherit; color: inherit; background: none; border: 0; cursor: none; }
ul{ list-style: none; }
em{ font-style: normal; color: var(--red); }

::selection{ background: var(--red); color: #fff; }

/* Grain + film vignette baked in globally */
body::before{
  content:"";
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: .55;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 2000;
}

/* ============ Cursor ============ */
.cursor-dot,
.cursor-ring{
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 9999;
  transform: translate3d(-50%,-50%,0);
  mix-blend-mode: difference;
}
.cursor-dot{
  width: 6px; height: 6px;
  background: var(--red);
  border-radius: 50%;
  box-shadow: 0 0 12px var(--red-glow), 0 0 2px var(--red);
}
.cursor-ring{
  width: 42px; height: 42px;
  border: 1px solid rgba(204, 0, 0, 0.8);
  border-radius: 50%;
  transition: width .35s var(--ease-out),
              height .35s var(--ease-out),
              border-color .35s var(--ease-out),
              background .35s var(--ease-out);
}
.cursor-ring.is-link{
  width: 70px; height: 70px;
  background: rgba(204, 0, 0, 0.08);
  border-color: var(--red);
}

@media (pointer: coarse){
  html, body, button{ cursor: auto; }
  .cursor-dot, .cursor-ring{ display: none; }
}

/* ============ Preloader ============ */
.preloader{
  position: fixed; inset: 0;
  background: var(--bg);
  z-index: 9000;
  display: flex; align-items: center; justify-content: center;
}
.preloader__inner{ width: min(420px, 80vw); text-align: left; }
.preloader__logo{
  font-family: var(--f-display);
  font-size: clamp(64px, 10vw, 140px);
  letter-spacing: .02em;
  line-height: .9;
  color: var(--ink);
  position: relative;
}
.preloader__logo::after{
  content:""; position: absolute; right: -14px; top: 18%;
  width: 10px; height: 10px; background: var(--red);
  box-shadow: 0 0 20px var(--red-glow);
}
.preloader__bar{
  margin-top: 28px;
  height: 1px; background: var(--line);
  position: relative; overflow: hidden;
}
.preloader__bar span{
  position: absolute; left:0; top:0; bottom:0;
  width: 0;
  background: var(--red);
  box-shadow: 0 0 18px var(--red-glow);
}
.preloader__pct{
  margin-top: 14px;
  font-family: var(--f-display);
  font-size: 14px; letter-spacing: .3em;
  color: var(--ink-dim);
}

/* ============ Nav ============ */
.nav{
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 20px 28px;
  mix-blend-mode: difference;
  transition: padding .4s var(--ease);
}
.nav.is-scrolled{ padding: 14px 28px; }
.nav__inner{
  display: flex; align-items: center; justify-content: space-between;
  gap: 40px;
  max-width: 1800px; margin: 0 auto;
}
.nav__logo{
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--f-display);
  letter-spacing: .05em;
  color: #fff;
}
.nav__logo-mark{
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border: 1px solid rgba(255,255,255,.3);
  font-size: 20px;
  letter-spacing: 0;
  position: relative;
}
.nav__logo-mark em{ color: var(--red); font-style: normal; }
.nav__logo-mark::after{
  content:""; position: absolute; inset: -1px;
  border: 1px solid var(--red);
  opacity: 0; transition: opacity .4s var(--ease);
}
.nav__logo:hover .nav__logo-mark::after{ opacity: 1; }
.nav__logo-text{ font-size: 18px; letter-spacing: .18em; }

.nav__links{
  display: flex; gap: 36px;
  font-family: var(--f-display);
  letter-spacing: .18em;
  font-size: 14px;
}
.nav__links a{
  position: relative;
  padding: 6px 0;
  color: #fff;
}
.nav__links a::after{
  content:""; position: absolute; left:0; right: 100%; bottom: 0;
  height: 1px; background: var(--red);
  transition: right .5s var(--ease-out);
}
.nav__links a:hover::after{ right: 0; }

.nav__cta{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 20px;
  border: 1px solid rgba(255,255,255,.25);
  font-family: var(--f-display); font-size: 13px; letter-spacing: .22em;
  color: #fff;
  position: relative;
  overflow: hidden;
  transition: border-color .4s var(--ease), color .4s var(--ease);
}
.nav__cta .dot{
  width: 6px; height: 6px; background: var(--red); border-radius: 50%;
  box-shadow: 0 0 10px var(--red-glow);
  animation: pulse 1.8s infinite var(--ease);
}
.nav__cta::before{
  content:""; position: absolute; inset:0;
  background: var(--red);
  transform: translateY(101%);
  transition: transform .5s var(--ease-out);
  z-index: -1;
}
.nav__cta:hover{ border-color: var(--red); color: #fff; }
.nav__cta:hover::before{ transform: translateY(0); }

@keyframes pulse{
  0%,100%{ opacity: 1; transform: scale(1); }
  50%{ opacity: .45; transform: scale(1.4); }
}

@media (max-width: 900px){
  .nav__links{ display: none; }
}

/* ============ Hero ============ */
.hero{
  position: relative;
  min-height: 100svh;
  padding: 120px 28px 80px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.hero__particles{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  z-index: 0;
}
.hero__vignette{
  position: absolute; inset:0; z-index: 1;
  background:
    radial-gradient(80% 60% at 50% 40%, transparent 0%, rgba(0,0,0,.55) 60%, #000 100%),
    radial-gradient(60% 50% at 80% 30%, rgba(204,0,0,.10) 0%, transparent 60%);
  pointer-events: none;
}
.hero__sweep{
  position: absolute; top:0; bottom:0; left: -30%;
  width: 60%;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(204,0,0,0) 30%,
    rgba(204,0,0,.25) 48%,
    rgba(255,255,255,.9) 50%,
    rgba(204,0,0,.25) 52%,
    transparent 70%);
  transform: skewX(-14deg);
  opacity: 0;
  z-index: 2;
  pointer-events: none;
  mix-blend-mode: screen;
}

.hero__meta{
  position: relative; z-index: 3;
  display: flex; justify-content: space-between;
  gap: 24px;
  font-family: var(--f-display);
  letter-spacing: .28em; font-size: 12px;
  color: var(--ink-dim);
  padding: 0 4px;
}
.hero__meta-item{ display: inline-flex; align-items: center; gap: 10px; }
.hero__meta-item .dot{
  width: 6px; height: 6px; background: var(--red); border-radius: 50%;
  box-shadow: 0 0 8px var(--red-glow);
}

.hero__content{
  position: relative; z-index: 3;
  max-width: 1800px; margin: 0 auto; width: 100%;
  padding-top: min(6vh, 60px);
}
.hero__eyebrow{
  display: flex; align-items: center; gap: 20px;
  font-family: var(--f-display);
  letter-spacing: .3em;
  font-size: 13px;
  color: var(--ink);
  margin-bottom: 28px;
}
.hero__eyebrow .line{
  width: 60px; height: 1px;
  background: var(--red);
  box-shadow: 0 0 8px var(--red-glow);
}

.hero__title{
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(72px, 18vw, 280px);
  line-height: .82;
  letter-spacing: -.01em;
  color: #fff;
  text-transform: uppercase;
  display: flex; flex-direction: column;
  gap: .02em;
}
.hero__title .word{
  display: block;
  overflow: hidden;
  position: relative;
}
.hero__title .word span.char{
  display: inline-block;
  will-change: transform;
}
.hero__title .word[data-word="XPRESS"]{ color: #fff; }
.hero__title .word[data-word="XPRESS"] .char:first-child{ color: var(--red); }

.hero__sub{
  margin-top: 34px;
  max-width: 560px;
  font-size: clamp(16px, 1.4vw, 20px);
  line-height: 1.5;
  color: var(--ink);
  font-weight: 400;
  letter-spacing: .02em;
}
.hero__sub em{ color: var(--red); font-style: normal; font-weight: 500; }

.hero__ctas{
  margin-top: 40px;
  display: flex; gap: 14px; flex-wrap: wrap;
}

.btn{
  display: inline-flex; align-items: center; gap: 12px;
  padding: 18px 26px;
  font-family: var(--f-display);
  letter-spacing: .24em; font-size: 14px;
  position: relative;
  overflow: hidden;
  transition: color .4s var(--ease);
}
.btn svg{ transition: transform .4s var(--ease); }
.btn:hover svg{ transform: translateX(6px); }
.btn--primary{
  background: var(--red);
  color: #fff;
  box-shadow: 0 0 40px rgba(204,0,0,.35);
}
.btn--primary::before{
  content:""; position: absolute; inset:0;
  background: #fff;
  transform: translateY(101%);
  transition: transform .55s var(--ease-out);
}
.btn--primary:hover{ color: var(--red); }
.btn--primary:hover::before{ transform: translateY(0); }
.btn--primary > *{ position: relative; z-index: 1; }
.btn--ghost{
  border: 1px solid var(--line-2);
  color: #fff;
}
.btn--ghost::after{
  content:""; position: absolute; left:0; bottom:0;
  width: 0; height: 1px; background: var(--red);
  transition: width .5s var(--ease-out);
}
.btn--ghost:hover::after{ width: 100%; }

.hero__scroll{
  position: absolute;
  right: 40px; bottom: 110px;
  z-index: 3;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
  font-family: var(--f-display); letter-spacing: .3em; font-size: 11px;
  color: var(--ink-dim);
}
.hero__scroll-line{
  width: 1px; height: 80px;
  background: var(--line-2);
  position: relative; overflow: hidden;
}
.hero__scroll-line span{
  position: absolute; left:0; right:0; top:0; height: 30%;
  background: var(--red);
  animation: scrollDown 2s infinite var(--ease);
}
@keyframes scrollDown{
  0%{ transform: translateY(-100%); }
  100%{ transform: translateY(400%); }
}

.hero__side{
  position: absolute;
  top: 140px;
  right: 40px;
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-family: var(--f-display);
  color: var(--ink-dim);
  letter-spacing: .22em;
  font-size: 12px;
  min-width: 180px;
}
.hero__side-row{
  display: flex; justify-content: space-between;
  padding: 4px 0;
  border-bottom: 1px solid var(--line);
}
.hero__side-row .k{ color: var(--red); }
.hero__side-row .v{ color: var(--ink); }
.hero__side-sep{ height: 10px; }
.hero__side-block{
  display: flex;
  align-items: flex-end;
  gap: 14px;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.hero__side-num{
  font-family: var(--f-display);
  font-size: 72px;
  line-height: .85;
  color: #fff;
  letter-spacing: .02em;
}
.hero__side-txt{
  font-family: var(--f-display);
  font-size: 11px;
  line-height: 1.3;
  letter-spacing: .3em;
  color: var(--ink-dim);
  padding-bottom: 6px;
}

.hero__framelines{
  position: absolute;
  inset: 16px;
  z-index: 2;
  pointer-events: none;
}
.hero__framelines .corner{
  position: absolute;
  width: 28px; height: 28px;
  border: 1px solid rgba(204,0,0,.55);
}
.hero__framelines .corner.tl{ top: 0; left: 0; border-right: none; border-bottom: none; }
.hero__framelines .corner.tr{ top: 0; right: 0; border-left: none; border-bottom: none; }
.hero__framelines .corner.bl{ bottom: 0; left: 0; border-right: none; border-top: none; }
.hero__framelines .corner.br{ bottom: 0; right: 0; border-left: none; border-top: none; }

.hero__ticker{
  position: relative;
  z-index: 3;
  width: 100%;
  overflow: hidden;
  padding: 18px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(10,10,10,.4);
  backdrop-filter: blur(4px);
}
.ticker__track{
  display: flex; gap: 42px;
  font-family: var(--f-display); font-size: 18px;
  letter-spacing: .3em;
  white-space: nowrap;
  animation: tick 40s linear infinite;
  color: var(--ink);
}
.ticker__track i{ color: var(--red); font-style: normal; }
@keyframes tick{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}

/* ============ Intro / About ============ */
.intro{
  position: relative;
  padding: 180px 28px 140px;
  border-top: 1px solid var(--line);
}
.intro__grid{
  max-width: 1600px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 100px;
}
.intro__tag,
.services__tag,
.truck-scene__tag,
.capabilities__tag,
.cta__tag{
  font-family: var(--f-display);
  letter-spacing: .28em; font-size: 13px;
  color: var(--ink-dim);
  display: flex; flex-direction: column; gap: 10px;
  padding-top: 10px;
  position: relative;
}
.intro__tag .num,
.services__tag .num,
.truck-scene__tag .num,
.capabilities__tag .num,
.cta__tag .num{
  font-size: 16px; color: var(--red);
}
.intro__headline{
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(32px, 4vw, 64px);
  line-height: 1.05;
  letter-spacing: -.005em;
  color: #fff;
  max-width: 22ch;
}
.intro__body{
  margin-top: 60px;
  max-width: 700px;
  color: var(--ink);
}
.intro__body p{
  font-size: clamp(15px, 1.15vw, 18px);
  line-height: 1.6;
  color: var(--ink-dim);
}
.intro__facts{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 48px;
  border-top: 1px solid var(--line);
  padding-top: 28px;
}
.fact{
  display: flex; flex-direction: column; gap: 10px;
}
.fact__k{
  font-family: var(--f-display); font-size: 11px;
  letter-spacing: .3em;
  color: var(--red);
}
.fact__v{
  font-family: var(--f-display);
  font-size: clamp(20px, 2vw, 32px);
  color: #fff;
  letter-spacing: .02em;
}

@media (max-width: 900px){
  .intro__grid{ grid-template-columns: 1fr; gap: 40px; }
  .intro__body{ margin-top: 30px; }
}

/* Word reveal utility */
.reveal-words .word-w{
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
  padding-bottom: .05em;
}
.reveal-words .word-w > span{
  display: inline-block;
  will-change: transform;
}

/* ============ Truck Scene ============ */
.truck-scene{
  position: relative;
  height: 400vh;
  background: #050505;
  border-top: 1px solid var(--line);
}
.truck-scene__sticky{
  position: relative;
  height: 100vh;
  overflow: hidden;
  width: 100%;
}
.truck-canvas{
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  display: block;
  z-index: 1;
}
.truck-scene__ui{
  position: absolute;
  inset: 0;
  padding: 140px 48px 80px;
  display: flex; flex-direction: column;
  justify-content: space-between;
  pointer-events: none;
  z-index: 2;
}
.truck-scene__ui > *{ pointer-events: auto; }
.truck-scene__top{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 24px;
}
.truck-scene__headline{
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(56px, 10vw, 160px);
  line-height: .88;
  letter-spacing: -.01em;
  color: #fff;
  max-width: 14ch;
  margin-top: 30px;
}
.line-clip{
  display: block; overflow: hidden;
}
.line-clip .inner{
  display: block;
  will-change: transform;
}

.truck-scene__stats{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
  max-width: 900px;
  pointer-events: auto;
}
.stat{ display: flex; flex-direction: column; gap: 8px; }
.stat__num{
  font-family: var(--f-display);
  font-size: clamp(40px, 4.5vw, 80px);
  line-height: 1;
  color: #fff;
  letter-spacing: .01em;
}
.stat__label{
  font-family: var(--f-body);
  font-size: 13px; letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.stat__num[data-suffix]::after{
  content: attr(data-suffix);
  color: var(--red);
  margin-left: 4px;
  font-size: .6em;
  vertical-align: middle;
}

.truck-scene__caption{
  display: flex; align-items: center; gap: 14px;
  font-family: var(--f-display); letter-spacing: .3em; font-size: 12px;
  color: var(--ink-dim);
  z-index: 3;
  padding-top: 10px;
}
.truck-scene__caption .dash{
  width: 40px; height: 1px; background: var(--red);
  box-shadow: 0 0 6px var(--red-glow);
}
.quote__cite .dash{
  width: 40px; height: 1px; background: var(--red);
  box-shadow: 0 0 6px var(--red-glow);
  display: inline-block;
  margin-right: 14px;
}

@media (max-width: 900px){
  .truck-scene__stats{ grid-template-columns: repeat(2, 1fr); }
  .truck-scene__ui{ padding: 120px 20px 40px; }
  .truck-scene__caption{ right: 20px; top: 120px; }
}

/* ============ Services horizontal scroll ============ */
.services{
  position: relative;
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.services__intro{
  max-width: 1600px; margin: 0 auto;
  padding: 160px 28px 80px;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 80px;
  align-items: end;
}
.services__headline{
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(48px, 7vw, 128px);
  line-height: .9;
  letter-spacing: -.01em;
  color: #fff;
}
.services__lead{
  grid-column: 2;
  max-width: 560px;
  color: var(--ink-dim);
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.6;
  margin-top: 30px;
}

.services__pin{
  height: 100vh;
  overflow: hidden;
  position: relative;
}
.services__track{
  display: flex;
  gap: 28px;
  padding: 0 28px;
  height: 100%;
  align-items: center;
  will-change: transform;
}
.service{
  flex: 0 0 min(480px, 85vw);
  height: 72vh;
  padding: 48px 44px;
  background: linear-gradient(180deg, #101010, #070707);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color .5s var(--ease);
}
.service::before{
  content:""; position: absolute; inset: 0;
  background: radial-gradient(60% 50% at 50% 0%, rgba(204,0,0,.14), transparent 70%);
  opacity: 0;
  transition: opacity .6s var(--ease);
  pointer-events: none;
}
.service:hover{ border-color: rgba(204,0,0,.45); }
.service:hover::before{ opacity: 1; }
.service:hover .service__sweep{ transform: scaleX(1); }

.service__no{
  font-family: var(--f-display);
  color: var(--red);
  letter-spacing: .24em; font-size: 13px;
  margin-bottom: 26px;
}
.service__sub{
  font-family: var(--f-display);
  color: var(--ink-dim);
  letter-spacing: .28em; font-size: 11px;
  margin-bottom: 14px;
}
.service__title{
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(48px, 5.5vw, 96px);
  line-height: .92;
  color: #fff;
  letter-spacing: .005em;
  margin-bottom: auto;
}
.service__desc{
  margin-top: 30px;
  color: var(--ink);
  font-size: 15px; line-height: 1.55;
  max-width: 36ch;
}
.service__tags{
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 24px;
}
.service__tags li{
  font-family: var(--f-display);
  font-size: 11px; letter-spacing: .2em;
  padding: 6px 10px;
  color: var(--ink);
  border: 1px solid var(--line-2);
}
.service__sweep{
  position: absolute; left: 44px; right: 44px; bottom: 34px;
  height: 2px;
  background: var(--red);
  box-shadow: 0 0 10px var(--red-glow);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .6s var(--ease);
}
.service--cta{
  background: linear-gradient(180deg, #180000, #080000);
  border-color: rgba(204,0,0,.35);
}
.service--cta .service__title{ color: #fff; }
.service__cta{
  margin-top: 30px;
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--f-display);
  letter-spacing: .2em; font-size: 20px;
  color: var(--red);
  transition: gap .4s var(--ease);
}
.service__cta:hover{ gap: 20px; }

/* ============ Capabilities ============ */
.capabilities{
  padding: 160px 28px;
  background: var(--bg-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.capabilities__head{
  max-width: 1600px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 80px;
  align-items: end;
}
.capabilities__headline{
  font-family: var(--f-display);
  font-size: clamp(36px, 4.5vw, 72px);
  line-height: 1.02;
  color: #fff;
  letter-spacing: -.005em;
}
.cap-grid{
  max-width: 1600px;
  margin: 80px auto 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid var(--line);
}
.cap-grid li{
  display: flex; flex-direction: column; gap: 10px;
  padding: 40px 24px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  position: relative;
  font-family: var(--f-display);
  font-size: clamp(18px, 1.4vw, 22px);
  letter-spacing: .02em;
  color: #fff;
  transition: background .5s var(--ease);
  overflow: hidden;
}
.cap-grid li::before{
  content:""; position: absolute; left:0; right:0; bottom:0;
  height: 2px;
  background: var(--red);
  transform: scaleX(0); transform-origin: left;
  transition: transform .6s var(--ease);
}
.cap-grid li:hover{ background: rgba(204,0,0,.05); }
.cap-grid li:hover::before{ transform: scaleX(1); }
.cap-grid__n{
  font-size: 12px; letter-spacing: .3em;
  color: var(--red);
}
@media (max-width: 1100px){ .cap-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 900px){
  .capabilities__head{ grid-template-columns: 1fr; gap: 30px; }
  .services__intro{ grid-template-columns: 1fr; gap: 30px; padding: 120px 20px 60px; }
  .services__lead{ grid-column: 1; }
}

/* ============ Quote ============ */
.quote{
  position: relative;
  padding: 180px 28px;
  background: #050505;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.quote::before{
  content:""; position: absolute;
  left: 50%; top: 50%;
  width: 70vw; height: 70vw;
  background: radial-gradient(circle, rgba(204,0,0,.14), transparent 60%);
  transform: translate(-50%,-50%);
  pointer-events: none;
}
.quote__inner{
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  text-align: left;
}
.quote__mark{
  font-family: var(--f-display);
  font-size: clamp(140px, 20vw, 360px);
  line-height: .7;
  color: var(--red);
  opacity: .85;
  text-shadow: 0 0 40px rgba(204,0,0,.25);
  display: block;
}
.quote__text{
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(32px, 4.5vw, 72px);
  line-height: 1.08;
  color: #fff;
  letter-spacing: -.005em;
  max-width: 22ch;
}
.quote__cite{
  display: inline-flex; align-items: center;
  margin-top: 48px;
  font-family: var(--f-display);
  letter-spacing: .28em; font-size: 13px;
  color: var(--ink-dim);
  font-style: normal;
}

/* ============ CTA ============ */
.cta{
  position: relative;
  padding: 180px 28px 140px;
  overflow: hidden;
  background: var(--bg);
}
.cta__bg{
  position: absolute; inset: 0;
  background:
    radial-gradient(50% 50% at 50% 80%, rgba(204,0,0,.25) 0%, transparent 60%),
    radial-gradient(80% 40% at 50% 100%, rgba(204,0,0,.15) 0%, transparent 60%);
  pointer-events: none;
}
.cta__inner{
  position: relative;
  max-width: 1600px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 60px;
  align-items: end;
}
.cta__headline{
  grid-column: 2;
  font-family: var(--f-display);
  font-size: clamp(56px, 11vw, 180px);
  line-height: .86;
  color: #fff;
  letter-spacing: -.01em;
}
.cta__phone{
  grid-column: 2;
  margin-top: 60px;
  display: block;
  position: relative;
  padding-top: 30px;
  border-top: 1px solid var(--line);
}
.cta__phone-label{
  display: block;
  font-family: var(--f-display);
  letter-spacing: .3em; font-size: 12px;
  color: var(--red);
}
.cta__phone-num{
  display: block;
  font-family: var(--f-display);
  font-size: clamp(56px, 9vw, 160px);
  line-height: .9;
  color: #fff;
  margin-top: 18px;
  letter-spacing: .01em;
}
.cta__phone-line{
  position: absolute; bottom: -2px; left: 0;
  height: 2px; width: 0;
  background: var(--red);
  box-shadow: 0 0 10px var(--red-glow);
  transition: width .7s var(--ease-out);
}
.cta__phone:hover .cta__phone-line{ width: 100%; }

.cta__meta{
  grid-column: 2;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  margin-top: 80px;
  padding-top: 36px;
  border-top: 1px solid var(--line);
}
.cta__meta .k{
  display: block;
  font-family: var(--f-display);
  font-size: 11px; letter-spacing: .3em;
  color: var(--red);
  margin-bottom: 12px;
}
.cta__meta .v{
  display: block;
  font-family: var(--f-display);
  font-size: clamp(16px, 1.3vw, 20px);
  color: #fff;
  line-height: 1.3;
  letter-spacing: .04em;
}
@media (max-width: 900px){
  .cta__inner{ grid-template-columns: 1fr; }
  .cta__headline, .cta__phone, .cta__meta{ grid-column: 1; }
  .cta__meta{ grid-template-columns: 1fr; gap: 20px; }
}

/* ============ Footer ============ */
.footer{
  position: relative;
  padding: 80px 28px 40px;
  background: #030303;
  border-top: 1px solid var(--line);
  overflow: hidden;
}
.footer__top{
  max-width: 1600px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 80px;
}
.footer__mark{
  font-family: var(--f-display);
  font-size: clamp(28px, 2.4vw, 40px);
  color: #fff;
  letter-spacing: .04em;
}
.footer__cols{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
.footer__cols > div{
  display: flex; flex-direction: column; gap: 12px;
}
.footer__cols .k{
  font-family: var(--f-display);
  font-size: 11px; letter-spacing: .3em;
  color: var(--red);
  margin-bottom: 8px;
}
.footer__cols a,
.footer__cols span{
  font-family: var(--f-body);
  font-size: 15px; color: var(--ink);
  letter-spacing: .02em;
  transition: color .4s var(--ease), padding-left .4s var(--ease);
}
.footer__cols a:hover{ color: var(--red); padding-left: 8px; }

.footer__bottom{
  max-width: 1600px; margin: 80px auto 0;
  padding-top: 30px;
  border-top: 1px solid var(--line);
  display: flex; justify-content: space-between;
  gap: 20px; flex-wrap: wrap;
  font-size: 12px;
  letter-spacing: .18em;
  color: var(--ink-dim);
  text-transform: uppercase;
  font-family: var(--f-display);
}
.footer__mega{
  position: absolute;
  left: -2vw; right: -2vw; bottom: -4vw;
  font-family: var(--f-display);
  font-size: clamp(100px, 22vw, 400px);
  line-height: .8;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,.08);
  pointer-events: none;
  white-space: nowrap;
  letter-spacing: .01em;
}
@media (max-width: 900px){
  .footer__top{ grid-template-columns: 1fr; gap: 40px; }
  .footer__cols{ grid-template-columns: 1fr 1fr; }
}

/* Section number style block reset */
.services__tag,
.truck-scene__tag,
.capabilities__tag,
.cta__tag{
  flex-direction: row; gap: 18px; align-items: center;
}
.services__tag .num,
.truck-scene__tag .num,
.capabilities__tag .num,
.cta__tag .num{
  font-size: 13px; color: var(--red);
}

/* Prevent horizontal scrollbars during pin */
.services__pin { overflow: hidden; }

/* ============ Scroll telemetry HUD ============ */
.hud{
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 90;
  width: 340px;
  font-family: var(--f-display);
  letter-spacing: .14em;
  color: var(--ink);
  pointer-events: none;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .9s var(--ease), transform .9s var(--ease);
}
.hud.is-ready{ opacity: 1; transform: translateY(0); }
.hud__bar{
  background: linear-gradient(180deg, rgba(8,8,8,.85), rgba(0,0,0,.9));
  border: 1px solid rgba(204,0,0,.4);
  box-shadow: 0 0 0 1px rgba(0,0,0,.6), 0 18px 40px rgba(0,0,0,.55), 0 0 24px rgba(204,0,0,.12);
  padding: 12px 14px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-size: 11px;
  position: relative;
}
.hud__bar::before{
  content:""; position: absolute; inset: 0;
  background: repeating-linear-gradient(0deg, transparent 0 2px, rgba(255,255,255,.025) 2px 3px);
  pointer-events: none;
}
.hud__row{ display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.hud__row + .hud__row{ margin-top: 6px; }
.hud__row--top{ font-size: 10.5px; letter-spacing: .26em; }
.hud__row--lg{
  font-size: 24px;
  padding: 6px 0 4px;
  letter-spacing: .08em;
  align-items: baseline;
}
.hud__row--sm{
  font-size: 10px;
  color: var(--ink-dim);
  letter-spacing: .22em;
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 8px;
  font-variant-numeric: tabular-nums;
}
.hud__pulse{
  width: 9px; height: 9px;
  background: var(--red);
  border-radius: 50%;
  box-shadow: 0 0 14px var(--red), 0 0 4px var(--red);
  animation: hudPulse 1.6s infinite var(--ease);
  flex-shrink: 0;
}
@keyframes hudPulse{
  0%,100%{ opacity: 1; transform: scale(1); }
  50%{ opacity: .35; transform: scale(1.55); }
}
.hud__status{
  color: #fff;
  flex: 1;
  text-align: left;
  margin-left: 4px;
  transition: color .3s var(--ease);
}
.hud__status.is-transit{ color: var(--red); }
.hud__id{
  color: var(--ink-dim);
  font-size: 10px;
}
.hud__sect-num{
  color: var(--red);
  font-weight: 400;
  min-width: 46px;
  text-shadow: 0 0 14px rgba(204,0,0,.45);
}
.hud__sect-name{
  color: #fff;
  flex: 1;
  font-size: 22px;
  letter-spacing: .12em;
  white-space: nowrap;
  overflow: hidden;
  display: inline-block;
  position: relative;
  transition: transform .35s var(--ease), opacity .35s var(--ease);
}
.hud__sect-name.is-flick{ animation: hudFlick .42s steps(1) both; }
@keyframes hudFlick{
  0%   { opacity: 1;   transform: translateY(0); }
  10%  { opacity: 0;   transform: translateY(-6px); }
  20%  { opacity: 1;   transform: translateY(2px); }
  30%  { opacity: .25; transform: translateY(0); }
  45%  { opacity: 1;   transform: translateY(0); }
  100% { opacity: 1;   transform: translateY(0); }
}
.hud__pct{
  color: var(--ink-dim);
  font-size: 13px;
  letter-spacing: .18em;
  font-variant-numeric: tabular-nums;
  min-width: 60px;
  text-align: right;
}
.hud__progress{
  position: relative;
  height: 3px;
  background: rgba(255,255,255,.08);
  margin: 10px 0 8px;
}
.hud__progress-fill{
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 0%;
  background: linear-gradient(90deg, rgba(204,0,0,.3), var(--red));
  box-shadow: 0 0 10px var(--red);
}
.hud__progress-knob{
  position: absolute; top: 50%;
  left: 0%;
  width: 8px; height: 8px;
  background: var(--red);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 12px var(--red), 0 0 4px var(--red);
}
.hud__progress-ticks{
  position: absolute; inset: 0;
  display: flex; justify-content: space-between;
  pointer-events: none;
}
.hud__progress-ticks i{
  width: 1px; height: 100%;
  background: rgba(255,255,255,.18);
}
@media (max-width: 880px){
  .hud{ width: 260px; right: 16px; bottom: 16px; }
  .hud__sect-name, .hud__row--lg{ font-size: 18px; }
}
@media (max-width: 540px){
  .hud{ display: none; }
}

/* Prevent horizontal scrollbars during pin */
.services__pin { overflow: hidden; }

/* Motion reduced */
@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
}
