/* ============================================================
   DAMAR TOWING CO. — v2 · immersive 3D · near-black · steel-blue
   ============================================================ */

:root{
  --bg:#080a0f;
  --bg-2:#0d1018;
  --panel:#11151e;
  --line:rgba(244,246,251,.10);
  --line-2:rgba(244,246,251,.2);
  --text:#f4f6fb;
  --muted:#8a92a3;
  --muted-2:#565e6e;
  --blue:#5b9bff;
  --blue-2:#8cbcff;
  --grad:linear-gradient(100deg,#5b9bff 0%,#8cbcff 55%,#c6dcff 100%);

  --display:"Bricolage Grotesque", system-ui, sans-serif;
  --sans:"Manrope", system-ui, sans-serif;

  --wrap:1280px;
  --pad:clamp(1.3rem,5vw,5.5rem);
  --ease:cubic-bezier(.19,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
html.js{scroll-behavior:auto}
body{background:var(--bg);color:var(--text);font-family:var(--sans);
  font-size:clamp(1rem,1.04vw,1.075rem);line-height:1.62;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img,svg,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul,ol{list-style:none}
::selection{background:var(--blue);color:#06080d}

h1,h2,h3{font-family:var(--display);font-weight:600;letter-spacing:-.025em;line-height:1.02}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.kick{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--sans);font-weight:600;font-size:.74rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--blue)}

.progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:100}
.progress span{display:block;height:100%;width:0;background:var(--grad);box-shadow:0 0 12px rgba(91,155,255,.6)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6rem;background:var(--blue);color:#06101f;
  font-family:var(--sans);font-weight:600;font-size:.98rem;padding:1rem 1.7rem;border-radius:100px;
  box-shadow:0 12px 40px -12px rgba(91,155,255,.7);transition:background .3s var(--ease),transform .3s var(--ease),box-shadow .3s;will-change:transform}
.btn svg{width:18px;height:18px}
.btn:hover{background:var(--blue-2);transform:translateY(-2px);box-shadow:0 18px 50px -10px rgba(140,188,255,.8)}
.ghostlink{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-weight:600;color:var(--text)}
.ghostlink span{transition:transform .35s var(--ease);color:var(--blue)}
.ghostlink:hover span{transform:translateX(5px)}

/* ============================================================
   HEADER
   ============================================================ */
.head{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;padding:1.5rem var(--pad);transition:padding .45s var(--ease),background .45s,border-color .45s;border-bottom:1px solid transparent}
.head.scrolled{background:rgba(8,10,15,.74);backdrop-filter:blur(16px) saturate(150%);padding-block:.95rem;border-bottom-color:var(--line)}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;font-size:1.24rem;letter-spacing:-.02em}
.brand__dot{width:9px;height:9px;border-radius:50%;background:var(--grad);box-shadow:0 0 12px rgba(91,155,255,.7)}
.brand__sub{color:var(--muted);font-weight:500}
.head__nav{display:flex;gap:2.2rem;position:absolute;left:50%;transform:translateX(-50%)}
.head__nav a{font-size:.86rem;font-weight:500;color:var(--muted);position:relative;padding:.2rem 0;transition:color .25s}
.head__nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.head__nav a:hover{color:var(--text)}
.head__nav a:hover::after{transform:scaleX(1)}
.head__right{display:flex;align-items:center;gap:1.3rem}
.head__phone{font-family:var(--display);font-weight:600;font-size:1.04rem}
.head__phone:hover{color:var(--blue)}
.head__menu{display:none;width:30px;height:18px;position:relative}
.head__menu span{position:absolute;left:0;width:100%;height:1.5px;background:var(--text);transition:.35s var(--ease)}
.head__menu span:nth-child(1){top:2px}.head__menu span:nth-child(2){bottom:2px}
.head__menu.open span:nth-child(1){top:8px;transform:rotate(45deg)}
.head__menu.open span:nth-child(2){bottom:8px;transform:rotate(-45deg)}

.drawer{position:fixed;inset:0;z-index:75;background:var(--bg-2);display:flex;flex-direction:column;justify-content:center;gap:.5rem;padding:0 var(--pad);clip-path:inset(0 0 100% 0);transition:clip-path .65s var(--ease);pointer-events:none}
.drawer.open{clip-path:inset(0 0 0 0);pointer-events:auto}
.drawer a{font-family:var(--display);font-weight:600;font-size:clamp(2.2rem,11vw,3.2rem);padding:.3rem 0}
.drawer a:hover{color:var(--blue)}
.drawer__call{font-family:var(--sans)!important;font-size:1rem!important;font-weight:600!important;color:var(--blue)!important;margin-top:1.4rem}

/* ============================================================
   HERO — immersive, hook centerpiece
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--pad) clamp(3.5rem,7vw,5.5rem);overflow:hidden;background:var(--bg)}
.hero__video{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;object-position:50% 50%;
  background:var(--bg);filter:grayscale(.16) contrast(1.05) brightness(.6) saturate(.9)}
.hero__scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(90deg, rgba(8,10,15,.96) 0%, rgba(8,10,15,.72) 40%, rgba(8,10,15,.22) 72%, rgba(8,10,15,.5) 100%),
  linear-gradient(180deg, rgba(8,10,15,.5) 0%, transparent 28%, transparent 52%, var(--bg) 100%),
  radial-gradient(75% 60% at 82% 28%, rgba(91,155,255,.2), transparent 60%)}
.hero__inner{position:relative;z-index:2;max-width:var(--wrap);margin-inline:auto;width:100%;text-align:left}
.hero__ey{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--sans);font-weight:600;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-2);margin-bottom:1.5rem}
.hero__ey .dot{width:8px;height:8px;border-radius:50%;background:var(--blue);box-shadow:0 0 12px var(--blue)}
.hero__h{font-family:var(--display);font-weight:700;font-size:clamp(2.7rem,8.6vw,6.6rem);line-height:.96;letter-spacing:-.035em;margin-bottom:1.5rem;filter:drop-shadow(0 14px 60px rgba(91,155,255,.22))}
.hero__h .grad{background-size:220% auto;animation:shimmer 5.5s linear infinite}
@keyframes shimmer{to{background-position:220% center}}
.hero__h .ln{display:block;overflow:hidden;padding-bottom:.06em}
.hero__h .w{display:inline-block}
.hero__sub{max-width:48ch;margin:0 0 2.3rem;font-size:clamp(1.06rem,1.4vw,1.26rem);color:#b9c2d2}
.hero__act{display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap;margin-bottom:2.3rem}
.btn--lg{padding:1.15rem 2rem;font-size:1.05rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:.6rem 1.7rem;font-family:var(--sans);font-size:.92rem;font-weight:500;color:#cdd6e6}
.hero__trust li{position:relative}
.hero__trust li:not(:last-child)::after{content:"";position:absolute;right:-.9rem;top:50%;width:4px;height:4px;border-radius:50%;background:var(--line-2);transform:translateY(-50%)}
.stars{color:#ffc24a;letter-spacing:.06em}
.hero__cue{position:absolute;z-index:2;right:var(--pad);bottom:clamp(2rem,4vw,3rem);font-family:var(--sans);font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-2);display:inline-flex;align-items:center;gap:.55rem}
.hero__cue i{width:1px;height:18px;background:linear-gradient(var(--blue-2),transparent);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media (max-width:620px){.hero__cue{display:none}}

/* assurance strip */
.assure{border-block:1px solid var(--line);background:var(--bg-2)}
.assure__row{max-width:var(--wrap);margin-inline:auto;padding:1.05rem var(--pad);display:flex;flex-wrap:wrap;justify-content:space-between;gap:.7rem 2rem}
.assure__row span{font-family:var(--sans);font-weight:600;font-size:.85rem;color:var(--muted);position:relative;padding-left:1.4rem}
.assure__row span::before{content:"";position:absolute;left:0;top:50%;width:7px;height:7px;border-radius:50%;background:var(--blue);transform:translateY(-50%)}
@media (max-width:640px){.assure__row{justify-content:flex-start;gap:.6rem 1.6rem}.assure__row span{font-size:.8rem}}

/* ============================================================
   TICKER
   ============================================================ */
.ticker{overflow:hidden;border-block:1px solid var(--line);background:var(--bg-2);padding:1.1rem 0}
.ticker__row{display:inline-flex;align-items:center;gap:1.8rem;white-space:nowrap;animation:scrollx 32s linear infinite;will-change:transform}
.ticker__row span{font-family:var(--display);font-weight:600;font-size:clamp(1.2rem,2.4vw,1.9rem);letter-spacing:-.01em}
.ticker__row i{color:var(--blue);font-style:normal;font-size:.7rem}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ============================================================
   STATEMENT
   ============================================================ */
.state{max-width:var(--wrap);margin-inline:auto;padding:clamp(6rem,13vw,11rem) var(--pad)}
.state__line{font-family:var(--display);font-size:clamp(2rem,5vw,4rem);line-height:1.12;letter-spacing:-.03em;font-weight:600;max-width:18ch}
.state__line [data-word]{display:inline-block;color:var(--muted-2)}

/* ============================================================
   SECTIONS
   ============================================================ */
.work,.proof,.area{max-width:var(--wrap);margin-inline:auto;padding:clamp(5.5rem,11vw,9rem) var(--pad)}
.sec__head{margin-bottom:clamp(2.6rem,5vw,4rem)}
.sec__head .kick{margin-bottom:1.4rem}
.sec__head h2{font-size:clamp(2.1rem,5vw,4rem)}

.svc{border-top:1px solid var(--line)}
.svc__row{display:grid;grid-template-columns:auto 4.6fr 6fr;gap:clamp(1rem,4vw,3.5rem);align-items:baseline;
  padding:clamp(1.8rem,3vw,2.7rem) 0;border-bottom:1px solid var(--line);transition:padding-left .55s var(--ease),background .55s}
.svc__row:hover{padding-left:clamp(.5rem,1.6vw,1.6rem)}
.svc__no{font-family:var(--display);font-weight:600;font-size:.95rem;color:var(--blue)}
.svc__t{font-family:var(--display);font-size:clamp(1.55rem,3vw,2.5rem);font-weight:600;line-height:1.02}
.svc__d{color:var(--muted);font-size:1.02rem;max-width:46ch}

/* Showcase */
.show{max-width:var(--wrap);margin-inline:auto;padding:clamp(3rem,7vw,6rem) var(--pad);
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,6vw,5.5rem);align-items:center}
.show__media{position:relative;perspective:1100px;transform-style:preserve-3d}
.show__img{aspect-ratio:4/3;border-radius:16px;background:var(--bg-2) url("../truck.jpg") 50% 45%/cover no-repeat;
  filter:grayscale(.25) contrast(1.06) brightness(.82) saturate(.95);border:1px solid var(--line-2);box-shadow:0 44px 90px -44px rgba(0,0,0,.85)}
.show__line{position:absolute;inset:-1px;border-radius:16px;pointer-events:none;box-shadow:inset 0 0 0 1px rgba(91,155,255,.22);background:linear-gradient(130deg,rgba(91,155,255,.12),transparent 52%)}
.show__copy h2{font-size:clamp(1.9rem,4vw,3rem);margin:1.2rem 0 1.2rem}
.show__copy p{color:var(--muted);font-size:1.08rem;max-width:42ch;margin-bottom:1.6rem}

/* Proof */
.lead-quote{font-family:var(--display);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:600;line-height:1.26;letter-spacing:-.02em;max-width:24ch;margin-bottom:clamp(3rem,5vw,4.5rem)}
.lead-quote cite{display:block;margin-top:1.8rem;font-family:var(--sans);font-style:normal;font-size:.84rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,2.6rem);border-top:1px solid var(--line);padding-top:clamp(2.4rem,4vw,3.4rem)}
.q{display:flex;flex-direction:column}
.q p{color:var(--text);font-size:1.04rem;line-height:1.5}
.q cite{margin-top:1.4rem;font-style:normal;font-weight:600;font-size:.92rem}
.q cite span{display:block;color:var(--muted-2);font-weight:400;font-size:.84rem;margin-top:.2rem}
.q--score{justify-content:center;align-items:flex-start;gap:.5rem}
.q--score b{font-family:var(--display);font-weight:700;font-size:3.4rem;line-height:.9;letter-spacing:-.03em}
.q__stars{color:var(--blue);letter-spacing:.1em}
.q--score .ghostlink{margin-top:1rem;color:var(--muted)}

/* Coverage */
.area{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2.5rem,6vw,5.5rem);align-items:center}
.area__intro{color:var(--muted);font-size:1.08rem;max-width:38ch;margin-top:1.6rem}
.towns{display:flex;flex-wrap:wrap;gap:.5rem 1.2rem;margin:2rem 0;max-width:32ch}
.towns li{font-family:var(--display);font-weight:600;font-size:1.16rem;position:relative;padding-right:1.2rem;color:var(--text)}
.towns li:not(:last-child)::after{content:"";position:absolute;right:0;top:50%;width:4px;height:4px;border-radius:50%;background:var(--blue);transform:translateY(-50%)}
.area__meta{display:flex;flex-direction:column;gap:1.1rem;border-top:1px solid var(--line);padding-top:1.6rem}
.area__meta dt{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.25rem}
.area__map{margin:0;border:1px solid var(--line-2);border-radius:14px;overflow:hidden}
.area__map iframe{width:100%;aspect-ratio:1/.82;border:0;filter:grayscale(.3) invert(.92) hue-rotate(190deg) contrast(.9) brightness(.95)}

/* Contact */
.contact{text-align:center;padding:clamp(6rem,13vw,11rem) var(--pad);background:radial-gradient(70% 130% at 50% 130%,rgba(91,155,255,.16),transparent 60%)}
.contact .kick{justify-content:center;margin-bottom:2rem;color:var(--blue-2)}
.phone{display:block;font-family:var(--display);font-size:clamp(2.6rem,9vw,7.5rem);font-weight:700;letter-spacing:-.04em;line-height:1;transition:color .4s var(--ease)}
.phone:hover{color:var(--blue)}
.contact__sub{max-width:36ch;margin:2rem auto 0;color:var(--muted);font-size:1.1rem}
.contact__meta{display:flex;justify-content:center;flex-wrap:wrap;gap:.8rem 2.4rem;margin-top:2.4rem;font-family:var(--sans);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2)}

/* Footer */
.foot{max-width:var(--wrap);margin-inline:auto;padding:clamp(3rem,6vw,4.5rem) var(--pad)}
.foot__top{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;padding-bottom:2rem;border-bottom:1px solid var(--line)}
.foot__nav{display:flex;gap:2rem;flex-wrap:wrap}
.foot__nav a{font-size:.86rem;color:var(--muted);transition:color .25s}
.foot__nav a:hover{color:var(--text)}
.foot__base{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1.4rem;font-size:.78rem;color:var(--muted-2)}

/* ============================================================
   MOTION HOOKS
   ============================================================ */
.js [data-fade]{opacity:0;transform:translateY(20px)}
.js [data-reveal]{opacity:0;transform:translateY(26px)}
.js .hero__h .w{transform:translateY(110%)}
.js .rm>span{transform:translateY(110%)}
.js .state__line [data-word]{opacity:.16;transform:translateY(.18em)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:920px){
  .head__nav{display:none}
  .head__menu{display:block}
  .head__phone{display:none}
  .quotes{grid-template-columns:1fr}
  .area,.show{grid-template-columns:1fr;gap:2.5rem}
  .show__copy{order:-1}
  .svc__row{grid-template-columns:auto 1fr;gap:.4rem 1.3rem}
  .svc__d{grid-column:2;max-width:none}
}
@media (max-width:520px){
  .hero__meta{gap:.7rem 1.4rem}
  .foot__top{flex-direction:column;align-items:flex-start;gap:1.3rem}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .js [data-fade],.js [data-reveal],.js .hero__h .w,.js .rm>span,.js .state__line [data-word]{opacity:1!important;transform:none!important}
}
