/* ============================================================
   CUT THROAT TOWING & RECOVERY
   Archetype: BRUTALIST INDUSTRIAL HAZARD
   black + hazard-yellow + concrete gray, thick borders,
   oversized condensed uppercase type, caution stripes, asphalt
   Mobile-first (375px perfect)
   ============================================================ */

:root{
  --black:#0a0a0a;
  --ink:#141414;
  --concrete:#2a2a2a;
  --concrete-2:#3a3a3a;
  --steel:#8a8d91;
  --hazard:#F2C200;     /* hazard yellow */
  --hazard-dim:#c9a200;
  --amber:#FFB300;
  --white:#f4f4f2;
  --paper:#e9e8e4;
  --line:#000;
  --maxw:1120px;
  --tap:44px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}

body{
  margin:0;
  background:var(--black);
  color:var(--white);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-size:16px;
  line-height:1.55;
  overflow-x:hidden;
  /* raw asphalt texture */
  background-image:
    radial-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    radial-gradient(rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size:6px 6px, 9px 9px;
  background-position:0 0, 3px 4px;
}

img,svg{max-width:100%;display:block;}

h1,h2,h3,.brand-name,.btn,.svc-num,.stat-num,.dispatch-badge,.nav-cta{
  font-family:'Oswald','Arial Narrow',sans-serif;
  text-transform:uppercase;
  letter-spacing:0.01em;
}

a{color:var(--hazard);text-decoration:none;}

.skip-link{
  position:absolute;left:-999px;top:0;z-index:200;
  background:var(--hazard);color:var(--black);
  padding:12px 18px;font-weight:700;font-family:'Oswald',sans-serif;text-transform:uppercase;
}
.skip-link:focus{left:8px;top:8px;}

:focus-visible{outline:3px solid var(--hazard);outline-offset:2px;}

/* ---- caution stripe utility ---- */
.stripe-bar{
  height:10px;
  background:repeating-linear-gradient(45deg,var(--hazard) 0 18px,var(--black) 18px 36px);
}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;
  padding:10px 16px;
  background:var(--black);
  border-bottom:4px solid var(--hazard);
}
.brand{display:flex;align-items:center;gap:10px;min-height:var(--tap);}
.brand-mark svg{width:38px;height:38px;}
.brand-words{display:flex;flex-direction:column;line-height:1;}
.brand-name{color:var(--white);font-size:20px;font-weight:700;}
.brand-sub{color:var(--hazard);font-size:9px;font-weight:600;letter-spacing:0.18em;font-family:'Oswald',sans-serif;text-transform:uppercase;}

.header-nav{display:none;align-items:center;gap:6px;}
.header-nav a{
  color:var(--white);font-family:'Oswald',sans-serif;text-transform:uppercase;
  font-size:14px;font-weight:600;padding:10px 12px;letter-spacing:0.04em;
}
.header-nav a:hover{color:var(--hazard);}
.nav-cta{
  background:var(--hazard);color:var(--black)!important;
  border:3px solid var(--black);box-shadow:3px 3px 0 var(--hazard-dim);
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:var(--tap);padding:14px 22px;
  font-size:16px;font-weight:700;letter-spacing:0.03em;
  border:3px solid var(--black);cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease;
}
.btn-primary{background:var(--hazard);color:var(--black);box-shadow:5px 5px 0 var(--black);}
.btn-primary:hover{transform:translate(-1px,-1px);box-shadow:7px 7px 0 var(--black);}
.btn-primary:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--black);}
.btn-ghost{background:transparent;color:var(--white);border-color:var(--hazard);}
.btn-ghost:hover{background:var(--hazard);color:var(--black);}
.btn-block{width:100%;}

/* ============ SECTION HEADS ============ */
section{padding:48px 16px;border-bottom:4px solid var(--ink);}
.section-head{margin-bottom:26px;}
.section-head h2{
  font-size:clamp(32px,11vw,56px);line-height:0.92;font-weight:700;
  color:var(--white);margin:0;
}
.section-kicker{
  display:inline-block;margin-top:10px;
  background:var(--hazard);color:var(--black);
  font-family:'Oswald',sans-serif;text-transform:uppercase;font-weight:700;
  font-size:12px;letter-spacing:0.12em;padding:5px 10px;
}

/* ============ HERO ============ */
.hero{
  position:relative;padding:34px 16px 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.2), rgba(0,0,0,0.55)),
    var(--ink);
  border-bottom:none;
}
.hero-grid{display:flex;flex-direction:column;gap:24px;max-width:var(--maxw);margin:0 auto;}

.dispatch-badge{
  display:inline-flex;align-items:center;gap:9px;align-self:flex-start;
  background:var(--black);color:var(--hazard);
  border:3px solid var(--hazard);
  font-family:'Oswald',sans-serif;font-weight:700;font-size:13px;letter-spacing:0.1em;
  padding:8px 14px;margin:0 0 16px;
}
.amber-dot{
  width:12px;height:12px;border-radius:50%;background:var(--amber);
  box-shadow:0 0 0 0 rgba(255,179,0,0.7);
  animation:amberPulse 1.6s infinite;
}
.amber-dot.sm{width:9px;height:9px;}
@keyframes amberPulse{
  0%{box-shadow:0 0 0 0 rgba(255,179,0,0.7);}
  70%{box-shadow:0 0 0 10px rgba(255,179,0,0);}
  100%{box-shadow:0 0 0 0 rgba(255,179,0,0);}
}
@media (prefers-reduced-motion:reduce){.amber-dot{animation:none;}}

.hero-copy h1{
  font-size:clamp(54px,18vw,104px);line-height:0.86;font-weight:700;
  margin:0 0 16px;color:var(--white);
}
.hero-copy h1 .hl{
  color:var(--black);
  background:var(--hazard);
  padding:0 8px;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
}
.hero-lead{font-size:17px;color:var(--paper);max-width:48ch;margin:0 0 24px;}
.hero-lead strong{color:var(--hazard);}

.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:26px;}
.hero-cta .btn{flex:1 1 auto;min-width:150px;}

.hero-stats{
  list-style:none;display:flex;gap:0;margin:0 0 28px;padding:0;
  border:3px solid var(--hazard);
}
.hero-stats li{
  flex:1;display:flex;flex-direction:column;align-items:center;
  padding:12px 6px;border-right:3px solid var(--hazard);text-align:center;
}
.hero-stats li:last-child{border-right:none;}
.stat-num{font-size:24px;font-weight:700;color:var(--hazard);line-height:1;}
.stat-label{font-size:11px;letter-spacing:0.1em;color:var(--steel);text-transform:uppercase;margin-top:4px;}

.hero-art{
  background:repeating-linear-gradient(45deg,#111 0 14px,#161616 14px 28px);
  border:4px solid var(--black);
  padding:14px;
  box-shadow:inset 0 0 0 2px var(--concrete);
}
.truck-svg{width:100%;height:auto;}
.beacon{transform-box:fill-box;}

/* caution stripe scroll divider */
.stripe-scroll{
  overflow:hidden;height:24px;margin:26px -16px 0;
  border-top:3px solid var(--black);border-bottom:3px solid var(--black);
}
.stripe-scroll-inner{
  height:100%;width:200%;
  background:repeating-linear-gradient(45deg,var(--hazard) 0 22px,var(--black) 22px 44px);
  animation:stripeMove 8s linear infinite;
}
@keyframes stripeMove{from{transform:translateX(0);}to{transform:translateX(-44px);}}
@media (prefers-reduced-motion:reduce){.stripe-scroll-inner{animation:none;}}

/* ============ SERVICES ============ */
.services{background:var(--black);}
.service-grid{display:grid;grid-template-columns:1fr;gap:0;max-width:var(--maxw);margin:0 auto;border:4px solid var(--hazard);}
.service-card{
  position:relative;padding:24px 20px;
  border-bottom:3px solid var(--concrete);
  background:var(--ink);
}
.service-card:last-child{border-bottom:none;}
.service-card:hover{background:#1c1c1c;}
.svc-num{
  display:block;font-size:14px;color:var(--hazard);font-weight:700;margin-bottom:8px;
  letter-spacing:0.2em;
}
.service-card h3{font-size:21px;font-weight:700;color:var(--white);margin:0 0 8px;line-height:1.05;}
.service-card p{margin:0;color:var(--paper);font-size:15px;}

/* ============ WHY ============ */
.why{background:var(--ink);}
.why-grid{display:flex;flex-direction:column;gap:18px;max-width:var(--maxw);margin:0 auto;}
.why-item{
  background:var(--black);border:3px solid var(--hazard);
  padding:22px 20px;box-shadow:6px 6px 0 rgba(0,0,0,0.6);
}
.why-icon{display:inline-block;margin-bottom:10px;}
.why-icon svg{width:44px;height:44px;}
.why-item h3{font-size:22px;font-weight:700;color:var(--hazard);margin:0 0 8px;}
.why-item p{margin:0;color:var(--paper);font-size:15px;}

/* ============ SERVICE AREA ============ */
.area{background:var(--black);}
.area-grid{display:flex;flex-direction:column;gap:22px;max-width:var(--maxw);margin:0 auto;}
.area-copy p{color:var(--paper);}
.area-list{
  list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0;margin:18px 0;
  border:3px solid var(--hazard);
}
.area-list li{
  padding:13px 14px;font-family:'Oswald',sans-serif;text-transform:uppercase;
  font-weight:600;color:var(--white);letter-spacing:0.05em;
  border-bottom:2px solid var(--concrete);border-right:2px solid var(--concrete);
}
.area-list li:nth-child(2n){border-right:none;}
.area-note{color:var(--steel);font-size:14px;}
.area-map{border:4px solid var(--hazard);}
.map-svg{width:100%;height:auto;}

/* ============ ABOUT ============ */
.about{background:var(--ink);}
.about-inner{max-width:760px;margin:0 auto;}
.about p{color:var(--paper);font-size:16px;margin:0 0 16px;}
.about-credential{
  display:inline-block;background:var(--black);border-left:6px solid var(--hazard);
  padding:10px 14px;color:var(--white)!important;font-family:'Oswald',sans-serif;
  text-transform:uppercase;letter-spacing:0.05em;font-size:14px;
}

/* ============ REVIEWS ============ */
.reviews{background:var(--black);}
.review-grid{display:flex;flex-direction:column;gap:16px;max-width:var(--maxw);margin:0 auto;}
.review-card{
  background:var(--ink);border:3px solid var(--concrete);border-left:6px solid var(--hazard);
  padding:20px;
}
.review-card p{margin:0 0 8px;color:var(--paper);}
.review-card p:last-child{margin-bottom:0;}
.stars{color:var(--hazard);font-size:18px;letter-spacing:2px;}
.review-card strong{color:var(--white);}
.review-tag{
  font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:11px;
  letter-spacing:0.12em;color:var(--steel)!important;
}
.review-disclaimer{
  max-width:var(--maxw);margin:18px auto 0;color:var(--steel);font-size:13px;font-style:italic;
}

/* ============ CONTACT ============ */
.contact{background:var(--ink);border-bottom:none;}
.contact-grid{display:flex;flex-direction:column;gap:28px;max-width:var(--maxw);margin:0 auto;}
.contact-copy p{color:var(--paper);}
.contact-points{list-style:none;padding:0;margin:16px 0;}
.contact-points li{
  display:flex;align-items:center;gap:10px;padding:8px 0;color:var(--white);
  font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:15px;letter-spacing:0.04em;
  border-bottom:1px dashed var(--concrete-2);
}
.contact-points li span{color:var(--hazard);}
.phone-placeholder{
  background:var(--black);border:3px dashed var(--hazard);padding:12px 14px;
  font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:0.05em;
  color:var(--white);font-size:16px;
}
.phone-placeholder strong{color:var(--hazard);}

.tow-form{
  background:var(--black);border:4px solid var(--hazard);
  padding:22px 18px;box-shadow:8px 8px 0 rgba(0,0,0,0.7);
}
.field{margin-bottom:16px;}
.field label{
  display:block;margin-bottom:6px;font-family:'Oswald',sans-serif;text-transform:uppercase;
  font-size:13px;letter-spacing:0.06em;color:var(--hazard);font-weight:600;
}
.field input,.field select,.field textarea{
  width:100%;min-height:var(--tap);padding:12px 12px;
  background:var(--ink);color:var(--white);
  border:3px solid var(--concrete-2);font-family:'Inter',sans-serif;font-size:16px;
}
.field textarea{min-height:84px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--hazard);outline:none;
}
.form-status{margin:12px 0 0;font-family:'Oswald',sans-serif;text-transform:uppercase;
  font-size:14px;letter-spacing:0.04em;color:var(--hazard);min-height:1.2em;}

/* ============ FOOTER ============ */
.site-footer{
  background:var(--black);border-top:6px solid var(--hazard);
  padding:34px 16px 96px;text-align:center;
}
.footer-inner{max-width:var(--maxw);margin:0 auto;}
.footer-brand{font-family:'Oswald',sans-serif;text-transform:uppercase;font-weight:700;
  font-size:22px;color:var(--white);margin:0 0 8px;}
.site-footer p{margin:4px 0;color:var(--steel);font-size:14px;}
.footer-copy{margin-top:14px!important;font-size:12px;}

/* ============ STICKY MOBILE CTA ============ */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:120;
  display:flex;gap:0;
  border-top:4px solid var(--hazard);
}
.sticky-btn{
  flex:1;min-height:56px;display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Oswald',sans-serif;text-transform:uppercase;font-weight:700;font-size:16px;
  letter-spacing:0.05em;
}
.sticky-call{background:var(--black);color:var(--hazard);border-right:3px solid var(--hazard);}
.sticky-tow{background:var(--hazard);color:var(--black);}
.sticky-tow:active{background:var(--hazard-dim);}

/* ============ ANIMATION ENTRY STATES (set by app.js when GSAP present) ============ */
.js-anim .truck-cab,
.js-anim .truck-bed,
.js-anim .tow-hook,
.js-anim .wheels{will-change:transform,opacity;}

/* ============ DESKTOP / TABLET ============ */
@media (min-width:760px){
  .header-nav{display:flex;}
  section{padding:72px 32px;}
  .hero{padding:48px 32px 0;}
  .hero-grid{flex-direction:row;align-items:center;}
  .hero-copy{flex:1 1 56%;}
  .hero-art{flex:1 1 44%;}
  .stripe-scroll{margin-left:-32px;margin-right:-32px;}
  .service-grid{grid-template-columns:1fr 1fr;}
  .service-card{border-right:3px solid var(--concrete);}
  .service-card:nth-child(2n){border-right:none;}
  .why-grid{flex-direction:row;}
  .why-item{flex:1;}
  .area-grid{flex-direction:row;align-items:start;}
  .area-copy{flex:1;}
  .area-map{flex:1;}
  .area-list{grid-template-columns:1fr 1fr 1fr;}
  .area-list li:nth-child(2n){border-right:2px solid var(--concrete);}
  .area-list li:nth-child(3n){border-right:none;}
  .review-grid{flex-direction:row;}
  .review-card{flex:1;}
  .contact-grid{flex-direction:row;align-items:start;}
  .contact-copy{flex:1;}
  .tow-form{flex:1;}
  .sticky-cta{display:none;}
  .site-footer{padding-bottom:48px;}
}

@media (min-width:1080px){
  .service-grid{grid-template-columns:1fr 1fr 1fr;}
  .service-card:nth-child(2n){border-right:3px solid var(--concrete);}
  .service-card:nth-child(3n){border-right:none;}
}
