/* =========================================================================
   FREIGHT FORCE — "Industrial Premium" v2
   Dark-mode-first identity · kinetic type · bento · scroll cinema.
   Red-on-charcoal (matches red truck livery). Vanilla, no deps.
   ========================================================================= */

:root {
  /* Surfaces */
  --ink:        #0a0b0d;   /* base */
  --ink-2:      #0e1013;
  --surface:    #131619;   /* cards */
  --surface-2:  #1a1e23;   /* raised */
  --glass:      rgba(22,26,31,.6);
  --line:       #262b32;
  --line-soft:  #1c2026;

  /* Ink */
  --fg:         #f0ede7;
  --fg-dim:     #aab0b8;
  --muted:      #7c828b;

  /* Light moment */
  --paper:      #f2f0ea;
  --paper-ink:  #101317;
  --paper-dim:  #51565e;

  /* Brand — freight red */
  --red:        #e8182b;
  --red-bright: #ff3346;
  --red-deep:   #a30d1a;
  --glow:       rgba(232,24,43,.45);

  --radius: 14px;
  --radius-sm: 8px;
  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 68px);
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --display: "Archivo", "Arial Narrow", sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, monospace;
  --sans: "IBM Plex Sans", system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  background: var(--ink);
  color: var(--fg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
::selection { background: var(--red); color: #fff; }

/* Grain + ambient mesh that slowly drifts (atmosphere, not noise) */
body::before {
  content: ""; position: fixed; inset: -20%; z-index: -2; pointer-events: none;
  background:
    radial-gradient(40% 35% at 15% 12%, rgba(232,24,43,.16), transparent 60%),
    radial-gradient(45% 40% at 88% 8%, rgba(232,24,43,.12), transparent 60%),
    radial-gradient(50% 45% at 70% 95%, rgba(70,90,130,.10), transparent 60%);
  filter: blur(20px);
  animation: drift 26s ease-in-out infinite alternate;
}
@keyframes drift {
  0%   { transform: translate3d(0,0,0) scale(1); }
  100% { transform: translate3d(-3%, 2%, 0) scale(1.08); }
}
body::after {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 9999; opacity: .04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Scroll progress bar */
.scrollbar { position: fixed; top: 0; left: 0; height: 3px; width: 100%; z-index: 200; transform-origin: 0 50%; transform: scaleX(var(--p,0)); background: linear-gradient(90deg, var(--red), var(--red-bright)); box-shadow: 0 0 14px var(--glow); }

/* ----- Layout ------------------------------------------------------------ */
.wrap { width: min(100% - 2*var(--gutter), var(--maxw)); margin-inline: auto; }
.section { padding-block: clamp(72px, 11vw, 150px); position: relative; }
.section--paper { background: var(--paper); color: var(--paper-ink); }

.eyebrow {
  font-family: var(--mono); font-size: 12px; letter-spacing: .3em;
  text-transform: uppercase; color: var(--red-bright);
  display: inline-flex; align-items: center; gap: 12px;
}
.eyebrow::before { content: ""; width: 30px; height: 2px; background: var(--red); }
.section--paper .eyebrow { color: var(--red-deep); }
.section--paper .eyebrow::before { background: var(--red-deep); }

.h2 {
  font-family: var(--display); font-weight: 900;
  font-size: clamp(2.1rem, 6vw, 4.2rem);
  line-height: .94; letter-spacing: -.03em; text-transform: uppercase;
  margin-block: 22px 0;
}
.lede { max-width: 56ch; color: var(--fg-dim); font-size: clamp(1.02rem, 1.4vw, 1.18rem); margin-top: 20px; }
.section--paper .lede { color: var(--paper-dim); }

.hazard { height: 10px; background: repeating-linear-gradient(-45deg, var(--red) 0 18px, var(--ink) 18px 36px); }

/* ----- Buttons (glow + shine) ------------------------------------------- */
.btn {
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--red); color: #fff;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 16px 26px; border: 1px solid transparent; border-radius: var(--radius-sm);
  transition: transform .3s var(--ease-out), box-shadow .3s var(--ease-out), background .3s;
  box-shadow: 0 6px 24px -10px var(--glow);
}
.btn::after { /* shine sweep */
  content: ""; position: absolute; top: 0; left: -120%; width: 60%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.35), transparent);
  transform: skewX(-20deg); transition: left .6s var(--ease-out);
}
.btn:hover { transform: translateY(-3px); box-shadow: 0 16px 40px -10px var(--glow); }
.btn:hover::after { left: 130%; }
.btn:active { transform: translateY(-1px); }
.btn .arrow { transition: transform .3s var(--ease-out); }
.btn:hover .arrow { transform: translateX(5px); }
.btn--ghost { background: rgba(255,255,255,.03); color: var(--fg); border-color: var(--line); box-shadow: none; backdrop-filter: blur(6px); }
.btn--ghost:hover { background: rgba(255,255,255,.07); border-color: var(--fg-dim); box-shadow: none; }
.section--paper .btn--ghost { color: var(--paper-ink); border-color: #cfcbc0; background: rgba(0,0,0,.02); }

/* ----- Header (glass) ---------------------------------------------------- */
.site-head {
  position: sticky; top: 0; z-index: 150;
  background: color-mix(in srgb, var(--ink) 70%, transparent);
  backdrop-filter: blur(16px) saturate(1.2);
  border-bottom: 1px solid transparent; transition: border-color .3s, background .3s;
}
.site-head.scrolled { border-bottom-color: var(--line); background: color-mix(in srgb, var(--ink) 88%, transparent); }
.site-head__row { display: flex; align-items: center; gap: 24px; height: 74px; }
.brand { display: flex; align-items: center; gap: 12px; font-family: var(--display); font-weight: 900; letter-spacing: -.01em; text-transform: uppercase; font-size: 1.12rem; }
.brand__mark {
  width: 36px; height: 36px; flex: none; display: grid; place-items: center;
  background: var(--red); color: #fff; font-family: var(--display); font-weight: 900; font-size: 15px;
  border-radius: var(--radius-sm); box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 4px 16px -6px var(--glow);
}
.brand small { color: var(--muted); font-family: var(--mono); font-weight: 400; font-size: 9.5px; letter-spacing: .2em; display: block; }
.nav { margin-left: auto; display: flex; align-items: center; gap: 30px; }
.nav a { position: relative; font-family: var(--mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-dim); transition: color .2s; }
.nav a::after { content: ""; position: absolute; left: 0; bottom: -6px; height: 2px; width: 0; background: var(--red); transition: width .3s var(--ease-out); }
.nav a:hover { color: var(--fg); } .nav a:hover::after { width: 100%; }
.head-cta { display: flex; align-items: center; gap: 14px; }
.phone-link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 13px; letter-spacing: .04em; color: var(--fg); }
.phone-link b { color: var(--red-bright); }
.nav-toggle { display: none; background: none; border: 1px solid var(--line); border-radius: var(--radius-sm); width: 46px; height: 42px; align-items: center; justify-content: center; }
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after { content:""; display:block; width: 20px; height: 2px; background: var(--fg); position: relative; transition: .25s; }
.nav-toggle span::before { position: absolute; top: -6px; } .nav-toggle span::after { position: absolute; top: 6px; }

/* ----- Hero -------------------------------------------------------------- */
.hero { position: relative; padding-block: clamp(56px, 9vw, 116px); overflow: clip; }
.hero::after { /* faint moving grid */
  content: ""; position: absolute; inset: 0; z-index: -1; opacity: .4;
  background-image: linear-gradient(var(--line-soft) 1px, transparent 1px), linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size: 58px 58px;
  -webkit-mask-image: radial-gradient(130% 80% at 50% 0%, #000 25%, transparent 72%);
          mask-image: radial-gradient(130% 80% at 50% 0%, #000 25%, transparent 72%);
}
.hero__grid { display: grid; grid-template-columns: .92fr 1.08fr; gap: clamp(28px, 4vw, 60px); align-items: center; }
.hero__visual { position: relative; }
.hero__visual::before { content: ""; position: absolute; inset: -14% -10%; z-index: 0; background: radial-gradient(58% 55% at 60% 42%, var(--glow), transparent 70%); filter: blur(34px); opacity: .85; pointer-events: none; }

.hero__manifest { font-family: var(--mono); font-size: 12px; letter-spacing: .18em; color: var(--muted); text-transform: uppercase; display: flex; gap: 18px; flex-wrap: wrap; margin-bottom: 26px; }
.hero__manifest b { color: var(--red-bright); font-weight: 600; }

/* Kinetic headline: lines clip-reveal upward on load */
.hero h1 { font-family: var(--display); font-weight: 900; font-size: clamp(2.9rem, 8.6vw, 6.2rem); line-height: .9; letter-spacing: -.035em; text-transform: uppercase; }
.hero h1 .line { display: block; overflow: hidden; }
.hero h1 .line > span { display: block; transform: translateY(108%); animation: lineUp .9s var(--ease-out) forwards; }
.hero h1 .line:nth-child(1) > span { animation-delay: .12s; }
.hero h1 .line:nth-child(2) > span { animation-delay: .24s; }
.hero h1 .line:nth-child(3) > span { animation-delay: .36s; }
@keyframes lineUp { to { transform: translateY(0); } }
.hero h1 .grad { background: linear-gradient(100deg, var(--red-bright), var(--red) 55%, var(--red-deep)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero h1 .outline { color: transparent; -webkit-text-stroke: 1.5px var(--fg-dim); }

.hero__sub, .hero__cta, .hero__trust { opacity: 0; transform: translateY(16px); animation: fadeUp .8s var(--ease-out) forwards; }
.hero__sub { margin-top: 26px; max-width: 44ch; color: var(--fg-dim); font-size: clamp(1.02rem, 1.5vw, 1.22rem); animation-delay: .5s; }
.hero__cta { margin-top: 36px; display: flex; gap: 14px; flex-wrap: wrap; animation-delay: .62s; }
.hero__trust { margin-top: 40px; display: flex; gap: 28px; flex-wrap: wrap; font-family: var(--mono); font-size: 12px; letter-spacing: .06em; color: var(--muted); animation-delay: .74s; }
.hero__trust b { color: var(--fg); }
@keyframes fadeUp { to { opacity: 1; transform: none; } }

/* Hero visual: live dispatch / route panel (glass + animated SVG route) */
.routecard { position: relative; z-index: 1; aspect-ratio: 1/1.02; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); background: linear-gradient(160deg, #14181d, #0a0c0f); box-shadow: 0 50px 100px -45px #000, 0 0 60px -30px var(--glow), inset 0 0 0 1px rgba(255,255,255,.03); opacity: 0; transform: translateY(20px) scale(.98); animation: fadeUp .9s var(--ease-out) .35s forwards; }
.routecard .route { filter: drop-shadow(0 0 6px rgba(232,24,43,.85)); }
.routecard__console { position: absolute; left: 14px; right: 14px; bottom: 24px; z-index: 5; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; box-shadow: 0 14px 30px -16px #000; }
.routecard__console > div { background: rgba(9,11,14,.78); backdrop-filter: blur(10px); padding: 13px 15px; }
.routecard__console .k { display: block; font-family: var(--mono); font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--muted); }
.routecard__console .v { display: block; font-family: var(--display); font-weight: 800; font-size: 1.02rem; text-transform: uppercase; margin-top: 5px; letter-spacing: -.01em; }
.routecard__console .v.green { color: #41d18a; }
.routecard__chip { position: absolute; z-index: 3; top: 16px; left: 16px; display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--fg-dim); background: rgba(10,12,15,.55); backdrop-filter: blur(8px); border: 1px solid var(--line); padding: 7px 12px; border-radius: 100px; }
.routecard__dot { width: 7px; height: 7px; border-radius: 50%; background: #41d18a; box-shadow: 0 0 0 0 rgba(65,209,138,.6); animation: pulse 2s infinite; }
@keyframes pulse { 70% { box-shadow: 0 0 0 8px rgba(65,209,138,0); } 100% { box-shadow: 0 0 0 0 rgba(65,209,138,0); } }
.routecard svg.map { position: absolute; inset: 0; width: 100%; height: 100%; }
.routecard__lettering { position: absolute; left: 20px; bottom: 56px; z-index: 3; font-family: var(--display); font-weight: 900; text-transform: uppercase; color: var(--red); font-size: clamp(1.5rem, 3.4vw, 2.2rem); line-height: .92; letter-spacing: -.01em; text-shadow: 0 4px 26px var(--glow); }
.routecard__lettering small { display: block; color: var(--fg-dim); font-family: var(--mono); font-weight: 400; font-size: 10px; letter-spacing: .22em; margin-top: 8px; }
.routecard__hazard { position: absolute; left: 0; right: 0; bottom: 0; z-index: 4; }

/* ----- Marquee ----------------------------------------------------------- */
.marquee { border-block: 1px solid var(--line); background: var(--ink-2); padding-block: 18px; overflow: hidden; --gap: 56px; }
.marquee__track { display: flex; gap: var(--gap); width: max-content; animation: scrollx 30s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__track span { display: inline-flex; align-items: center; gap: var(--gap); font-family: var(--display); font-weight: 800; font-size: clamp(1rem, 2vw, 1.5rem); text-transform: uppercase; letter-spacing: -.01em; color: var(--fg-dim); white-space: nowrap; }
.marquee__track span::after { content: "✦"; color: var(--red); font-size: .7em; }
@keyframes scrollx { to { transform: translateX(calc(-50% - var(--gap)/2)); } }

/* ----- Stats (count-up) -------------------------------------------------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: -1px; }
.stat { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 30px 26px; position: relative; overflow: hidden; transition: transform .35s var(--ease-out), border-color .35s; }
.stat:hover { transform: translateY(-4px); border-color: color-mix(in srgb, var(--red) 50%, var(--line)); }
.stat::before { content: ""; position: absolute; inset: 0; background: radial-gradient(80% 60% at 50% 120%, var(--glow), transparent 70%); opacity: 0; transition: opacity .35s; }
.stat:hover::before { opacity: .5; }
.stat__k { font-family: var(--display); font-weight: 900; font-size: clamp(2rem, 3.4vw, 2.9rem); line-height: 1; letter-spacing: -.02em; position: relative; }
.stat__k .red { color: var(--red); }
.stat__v { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-top: 12px; position: relative; }

/* ----- Services ---------------------------------------------------------- */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 52px; }
.svc { background: var(--surface); padding: 34px 30px 32px; position: relative; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; transition: transform .4s var(--ease-out), border-color .4s; }
.svc::before { content: ""; position: absolute; left: 0; top: 0; height: 3px; width: 0; background: linear-gradient(90deg, var(--red), var(--red-bright)); transition: width .5s var(--ease-out); }
.svc:hover { transform: translateY(-6px); border-color: color-mix(in srgb, var(--red) 40%, var(--line)); }
.svc:hover::before { width: 100%; }
.svc__no { font-family: var(--mono); font-size: 12px; letter-spacing: .2em; color: var(--muted); }
.svc__name { font-family: var(--display); font-weight: 900; text-transform: uppercase; font-size: 1.55rem; line-height: .98; margin-top: 16px; letter-spacing: -.015em; }
.svc__price { font-family: var(--mono); font-size: 12px; letter-spacing: .12em; color: var(--red-bright); text-transform: uppercase; margin-top: 12px; }
.svc ul { list-style: none; padding: 0; margin-top: 22px; display: grid; gap: 12px; }
.svc li { display: flex; gap: 12px; align-items: flex-start; color: var(--fg-dim); font-size: .95rem; }
.svc li::before { content: ""; flex: none; width: 7px; height: 7px; margin-top: 8px; background: var(--red); transform: rotate(45deg); }
.svc--featured { background: linear-gradient(180deg, rgba(232,24,43,.10), var(--surface) 55%); border-color: color-mix(in srgb, var(--red) 35%, var(--line)); }
.svc__flag { position: absolute; top: 0; right: 0; background: var(--red); color: #fff; font-family: var(--mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; padding: 6px 12px; border-bottom-left-radius: var(--radius-sm); }

/* ----- Bento (Why) ------------------------------------------------------- */
.bento { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: minmax(190px, auto); gap: 16px; margin-top: 52px; }
.tile { position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); padding: 30px; transition: transform .4s var(--ease-out), border-color .4s, background .4s; }
.tile:hover { transform: translateY(-5px); border-color: color-mix(in srgb, var(--red) 45%, var(--line)); }
.tile__glow { position: absolute; inset: 0; background: radial-gradient(60% 60% at var(--mx,70%) var(--my,0%), var(--glow), transparent 65%); opacity: 0; transition: opacity .4s; pointer-events: none; }
.tile:hover .tile__glow { opacity: .55; }
.tile svg.ic { width: 38px; height: 38px; color: var(--red); }
.tile h3 { font-family: var(--display); font-weight: 800; text-transform: uppercase; font-size: 1.3rem; margin-top: 18px; letter-spacing: -.01em; position: relative; }
.tile p { color: var(--fg-dim); margin-top: 10px; font-size: .97rem; position: relative; max-width: 42ch; }
.tile--wide { grid-column: span 2; }
.tile--feature { grid-column: span 2; grid-row: span 2; background: linear-gradient(150deg, #16191e, #0b0d10); display: flex; flex-direction: column; justify-content: space-between; }
.tile--feature .big { font-family: var(--display); font-weight: 900; font-size: clamp(2.4rem, 5vw, 4rem); line-height: .92; text-transform: uppercase; letter-spacing: -.03em; }
.tile--feature .big .grad { background: linear-gradient(100deg, var(--red-bright), var(--red-deep)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.tile__num { font-family: var(--display); font-weight: 900; font-size: clamp(2.6rem,5vw,3.6rem); color: var(--red); line-height: 1; }

/* ----- Service area ------------------------------------------------------ */
.area-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,68px); align-items: center; margin-top: 40px; }
.area__list { display: flex; flex-wrap: wrap; gap: 10px; }
.area__list span { font-family: var(--mono); font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--fg-dim); border: 1px solid var(--line); padding: 9px 15px; border-radius: 100px; transition: .3s var(--ease-out); cursor: default; }
.area__list span:hover { transform: translateY(-3px); color: var(--fg); border-color: var(--red); box-shadow: 0 8px 20px -10px var(--glow); }
.area__list span.hot { border-color: color-mix(in srgb, var(--red) 60%, var(--line)); color: var(--fg); }

/* ----- How it works (connected timeline) -------------------------------- */
.steps { position: relative; display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 52px; }
.steps::before { content: ""; position: absolute; top: 38px; left: 8%; right: 8%; height: 2px; background: repeating-linear-gradient(90deg, var(--line) 0 10px, transparent 10px 20px); }
.step { position: relative; background: var(--ink-2); border: 1px solid var(--line); border-radius: var(--radius); padding: 32px 28px; }
.step__n { display: inline-grid; place-items: center; width: 56px; height: 56px; border-radius: 50%; background: var(--ink); border: 1px solid var(--line); font-family: var(--display); font-weight: 900; font-size: 1.4rem; color: var(--red); position: relative; z-index: 1; box-shadow: 0 0 0 6px var(--ink-2); }
.step h3 { font-family: var(--display); font-weight: 800; text-transform: uppercase; font-size: 1.25rem; margin-top: 18px; }
.step p { color: var(--fg-dim); margin-top: 10px; font-size: .96rem; }

/* ----- FAQ (light) ------------------------------------------------------- */
.faq { margin-top: 44px; border-top: 1px solid #d8d4c9; }
.faq details { border-bottom: 1px solid #d8d4c9; }
.faq summary { list-style: none; cursor: pointer; padding: 26px 0; display: flex; align-items: center; gap: 20px; font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: clamp(1.05rem,2vw,1.4rem); letter-spacing: -.01em; transition: color .2s; }
.faq summary:hover { color: var(--red-deep); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::before { content: "+"; font-family: var(--mono); color: var(--red-deep); font-size: 1.6rem; transition: transform .3s var(--ease-out); flex: none; }
.faq details[open] summary::before { transform: rotate(135deg); }
.faq p { padding: 0 0 28px 44px; color: var(--paper-dim); max-width: 70ch; }
.faq a { color: var(--red-deep); text-decoration: underline; }

/* ----- Contact ----------------------------------------------------------- */
.contact { position: relative; }
.contact__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(32px,5vw,72px); align-items: center; }
.contact h2 { font-family: var(--display); font-weight: 900; text-transform: uppercase; font-size: clamp(2.3rem,6.5vw,4.6rem); line-height: .92; letter-spacing: -.03em; }
.contact h2 .grad { background: linear-gradient(100deg, var(--red-bright), var(--red-deep)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.contact__lines { display: grid; gap: 16px; }
.contact__line { display: flex; gap: 16px; align-items: center; padding: 20px 22px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); transition: transform .35s var(--ease-out), border-color .35s; }
.contact__line:hover { transform: translateX(6px); border-color: color-mix(in srgb, var(--red) 45%, var(--line)); }
.contact__line svg { width: 24px; height: 24px; color: var(--red); flex: none; }
.contact__line .k { font-family: var(--mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--muted); }
.contact__line .v { font-size: 1.05rem; font-weight: 600; }

/* ----- Pricing reassurance note ----------------------------------------- */
.pricenote { margin-top: 28px; display: flex; align-items: center; gap: 14px; padding: 18px 22px; border: 1px solid var(--line); border-left: 3px solid var(--red); border-radius: var(--radius); background: var(--surface); max-width: 70ch; }
.pricenote svg { width: 22px; height: 22px; color: var(--red); flex: none; }
.pricenote p { color: var(--fg-dim); font-size: .98rem; }
.pricenote b { color: var(--fg); }

/* ----- Sticky mobile call bar ------------------------------------------- */
.callbar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 140; display: none; grid-template-columns: 1fr 1fr; gap: 10px; padding: 10px 14px calc(10px + env(safe-area-inset-bottom, 0px)); background: color-mix(in srgb, var(--ink) 90%, transparent); backdrop-filter: blur(14px); border-top: 1px solid var(--line); }
.callbar a { display: flex; align-items: center; justify-content: center; gap: 9px; min-height: 52px; border-radius: var(--radius-sm); font-family: var(--mono); font-size: 13px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; }
.callbar svg { width: 18px; height: 18px; }
.callbar .call { background: var(--surface-2); color: var(--fg); border: 1px solid var(--line); }
.callbar .quote { background: var(--red); color: #fff; box-shadow: 0 6px 20px -8px var(--glow); }

/* ----- Footer ------------------------------------------------------------ */
.site-foot { background: #060708; border-top: 1px solid var(--line); padding-block: 50px 34px; }
.foot__row { display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; align-items: center; }
.foot__brand { font-family: var(--display); font-weight: 900; text-transform: uppercase; font-size: 1.2rem; }
.foot__meta { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; color: var(--muted); text-transform: uppercase; }
.foot__meta a:hover { color: var(--fg); }

/* ----- Quote page -------------------------------------------------------- */
.qhero { padding-block: clamp(44px,6vw,72px) 0; }
.qhero h1 { font-family: var(--display); font-weight: 900; text-transform: uppercase; font-size: clamp(2.3rem,6.5vw,4.4rem); line-height: .92; letter-spacing: -.03em; }
.qhero h1 .grad { background: linear-gradient(100deg, var(--red-bright), var(--red-deep)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.qnote { display: flex; gap: 14px; align-items: flex-start; margin-top: 24px; padding: 18px 22px; border: 1px solid var(--line); border-left: 3px solid var(--red); border-radius: var(--radius); background: var(--surface); max-width: 62ch; }
.qnote svg { width: 22px; height: 22px; color: var(--red); flex: none; margin-top: 2px; }
.qnote p { color: var(--fg-dim); font-size: .95rem; }
.form { margin-top: 46px; max-width: 880px; }
.form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px 24px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field--full { grid-column: 1 / -1; }
.field label { font-family: var(--mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--fg-dim); }
.field label .req { color: var(--red-bright); }
.field input, .field select, .field textarea { font-family: var(--sans); font-size: 1rem; color: var(--fg); background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 14px 16px; transition: border-color .2s, box-shadow .2s; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 3px rgba(232,24,43,.2); }
.field textarea { resize: vertical; min-height: 110px; }
.field select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' stroke='%237c828b' stroke-width='2'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px; }
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form__actions { margin-top: 30px; display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.form__hint { font-family: var(--mono); font-size: 11px; letter-spacing: .08em; color: var(--muted); }
.form__status { margin-top: 22px; padding: 18px 20px; border-radius: var(--radius-sm); font-size: .98rem; display: none; }
.form__status.ok { display: block; background: rgba(40,160,90,.12); border: 1px solid rgba(40,160,90,.4); color: #9be3b6; }
.form__status.err { display: block; background: rgba(232,24,43,.12); border: 1px solid rgba(232,24,43,.4); color: #ffb3bb; }

/* ----- Reveal on scroll -------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-d="1"] { transition-delay: .08s; }
.reveal[data-d="2"] { transition-delay: .16s; }
.reveal[data-d="3"] { transition-delay: .24s; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero h1 .line > span, .hero__sub, .hero__cta, .hero__trust, .routecard { opacity: 1; transform: none; }
  html { scroll-behavior: auto; }
}

/* ----- Responsive -------------------------------------------------------- */
@media (max-width: 1000px) {
  .hero__grid { grid-template-columns: 1fr; }
  .routecard { max-width: 460px; aspect-ratio: 16/12; }
  .svc-grid, .steps { grid-template-columns: 1fr; }
  .steps::before { display: none; }
  .bento { grid-template-columns: repeat(2, 1fr); }
  .tile--feature, .tile--wide { grid-column: span 2; grid-row: auto; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .area-grid, .contact__grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .nav, .head-cta .phone-link .lbl { display: none; }
  .nav-toggle { display: inline-flex; }
  .callbar { display: grid; }
  body { padding-bottom: 80px; }
  .site-head__row { gap: 14px; }
  .head-cta { gap: 10px; }
  .head-cta .btn { padding: 13px 16px; }
  .nav.open { display: flex; position: absolute; top: 74px; left: 0; right: 0; flex-direction: column; gap: 0; background: var(--ink); border-bottom: 1px solid var(--line); padding: 8px 0; }
  .nav.open a { padding: 16px var(--gutter); } .nav.open a::after { display: none; }
  .bento, .stats, .form__grid { grid-template-columns: 1fr; }
  .tile--feature, .tile--wide { grid-column: auto; }
}
@media (max-width: 560px) {
  .head-cta .phone-link { display: none; }
  .head-cta .btn { font-size: 11px; letter-spacing: .08em; }
  .brand small { display: none; }
}
