/* HaulAtlas — Highway Signage. Locked palette + Overpass (Highway Gothic). */
:root{
  --bg:#f3f4ee; --sign:#0c6b3d; --sign-d:#08542f; --white:#fff;
  --yellow:#f4c20d; --asphalt:#18201c; --blue:#1b4f9c; --orange:#e8662a;
  --hair:#d3dac9; --muted:#5f6b5f;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--asphalt);font-family:"Overpass",system-ui,sans-serif;line-height:1.5;
  background-image:radial-gradient(110% 55% at 50% -8%,rgba(12,107,61,.06),transparent 60%);}
.wrap{max-width:1180px;margin:auto;padding:0 clamp(16px,4vw,48px)}
a{color:var(--sign);text-decoration:none}
a:hover{text-decoration:underline}
.mono{font-family:"Overpass Mono",ui-monospace,monospace}

/* header */
header.site{border-bottom:3px solid var(--asphalt)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:18px;padding-bottom:18px}
.brand{display:flex;align-items:center;gap:12px;font:900 clamp(24px,2.6vw,32px)/1 "Overpass";letter-spacing:-.025em;color:var(--asphalt)}
.brand:hover{text-decoration:none}
.brand svg{width:42px;height:42px;flex:none}
nav.top{display:flex;gap:8px;flex-wrap:wrap}
nav.top a{font:700 12px "Overpass Mono",monospace;text-transform:uppercase;letter-spacing:.04em;color:var(--asphalt);padding:8px 12px;border:2px solid var(--asphalt);border-radius:4px}
nav.top a:hover{background:var(--asphalt);color:var(--bg);text-decoration:none}

/* breadcrumb */
.crumb{font:600 12px "Overpass Mono",monospace;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:18px 0 0}
.crumb a{color:var(--blue)}

/* hero guide-sign */
.hero{margin:30px 0;background:var(--sign);color:var(--white);border-radius:14px;position:relative;overflow:hidden;box-shadow:0 22px 50px rgba(8,84,47,.3)}
.hero::before{content:"";position:absolute;inset:11px;border:3px solid rgba(255,255,255,.9);border-radius:8px;pointer-events:none}
.hero-inner{position:relative;padding:clamp(30px,5vw,60px)}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font:700 12px "Overpass Mono",monospace;text-transform:uppercase;letter-spacing:.1em;color:var(--yellow);margin-bottom:16px}
.eyebrow::before{content:"EXIT";background:var(--yellow);color:var(--sign-d);padding:3px 7px;border-radius:3px;letter-spacing:.05em}
.hero h1{margin:0;font:900 clamp(34px,6vw,80px)/.98 "Overpass";letter-spacing:-.035em;max-width:18ch}
.hero p.lead{max-width:62ch;margin:18px 0 26px;font-size:clamp(16px,1.6vw,21px);font-weight:600;color:rgba(255,255,255,.92)}

/* search */
.search{display:grid;grid-template-columns:auto 1fr auto;align-items:center;max-width:680px;background:var(--white);border-radius:8px;overflow:hidden;box-shadow:0 8px 0 rgba(8,84,47,.4)}
.search .mag{padding:0 4px 0 18px;display:flex;color:var(--sign)}
.search input{min-width:0;border:0;background:transparent;padding:18px 12px;font:700 18px "Overpass";color:var(--asphalt);outline:0}
.search input::placeholder{color:#8a948c}
.search button{border:0;background:var(--asphalt);color:var(--white);padding:19px 24px;font:800 14px "Overpass";text-transform:uppercase;letter-spacing:.04em;cursor:pointer}
.search button:hover{background:var(--orange)}
.facts{display:flex;flex-wrap:wrap;gap:9px;margin-top:18px}
.facts span{font:700 12px "Overpass Mono",monospace;text-transform:uppercase;letter-spacing:.04em;background:rgba(255,255,255,.14);border:1.5px solid rgba(255,255,255,.5);padding:7px 11px;border-radius:5px}

/* search results (homepage) */
#results{margin-top:18px;display:grid;gap:8px;max-width:680px}
#results a.res{display:flex;justify-content:space-between;gap:12px;background:var(--white);border:2px solid var(--asphalt);border-radius:8px;padding:13px 16px;color:var(--asphalt)}
#results a.res:hover{border-color:var(--sign);text-decoration:none}
#results .rn{font-weight:800}
#results .rm{font:600 12px "Overpass Mono",monospace;color:var(--muted)}
.res-empty{color:var(--muted);font-size:14px;padding:6px 2px}

/* generic section */
section{margin:42px 0}
h2.sec{font:900 clamp(24px,3vw,38px)/1.05 "Overpass";letter-spacing:-.025em;margin:0 0 6px}
.sub{color:var(--muted);font-size:15px;margin:0 0 22px;max-width:70ch}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:0;border:3px solid var(--asphalt);border-radius:12px;overflow:hidden;background:var(--white)}
.stats div{padding:18px 20px;border-right:2px solid var(--hair)}
.stats div:last-child{border-right:0}
.stats b{display:block;font:900 30px "Overpass";letter-spacing:-.02em}
.stats small{font:700 11px "Overpass Mono",monospace;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}

/* card grid (cities, carriers) */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
a.card{display:block;background:var(--white);border:2px solid var(--asphalt);border-radius:12px;padding:18px 20px;color:var(--asphalt)}
a.card:hover{border-color:var(--sign);text-decoration:none;transform:translateY(-2px);transition:.15s}
a.card .ct{font:800 18px "Overpass";letter-spacing:-.01em}
a.card .cm{margin-top:6px;font:600 12px "Overpass Mono",monospace;color:var(--muted)}
a.card .cd{margin-top:10px;font-size:14px;color:var(--muted)}
.badge{display:inline-flex;align-items:center;gap:6px;font:800 11px "Overpass Mono",monospace;text-transform:uppercase;letter-spacing:.04em;padding:5px 9px;border-radius:5px;background:var(--yellow);color:var(--sign-d)}
.badge.green{background:rgba(12,107,61,.12);color:var(--sign)}

/* carrier profile */
.profile{border:3px solid var(--asphalt);border-radius:14px;overflow:hidden;background:var(--white);margin:8px 0}
.pf-h{background:var(--sign);color:var(--white);padding:clamp(20px,3vw,30px)}
.pf-h .id{font:700 12px "Overpass Mono",monospace;letter-spacing:.06em;opacity:.9;text-transform:uppercase}
.pf-h h1{margin:8px 0 4px;font:900 clamp(26px,3.4vw,42px)/1.04 "Overpass";letter-spacing:-.025em}
.pf-h .dba{font:600 15px "Overpass";opacity:.9}
.fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.field{padding:16px 20px;border-top:2px solid var(--hair);border-right:2px solid var(--hair)}
.field b{display:block;font:700 10.5px "Overpass Mono",monospace;text-transform:uppercase;letter-spacing:.05em;color:var(--blue);margin-bottom:6px}
.field span{font-weight:800;font-size:16px}
.field span.ok{color:var(--sign)}

/* SAFER callout */
.callout{margin:22px 0;background:rgba(244,194,13,.16);border:2px solid var(--yellow);border-radius:12px;padding:20px 22px}
.callout h3{margin:0 0 6px;font:800 18px "Overpass"}
.callout p{margin:0 0 12px;font-size:15px;color:var(--asphalt)}
.btn{display:inline-block;background:var(--sign);color:var(--white);font:800 14px "Overpass";text-transform:uppercase;letter-spacing:.03em;padding:13px 20px;border-radius:8px}
.btn:hover{background:var(--orange);text-decoration:none}
.btn.dark{background:var(--asphalt)}

/* prose */
.prose{max-width:72ch}
.prose p{font-size:16px;margin:0 0 16px}
.prose h3{font:800 20px "Overpass";margin:26px 0 8px}
.prose ul{padding-left:20px}.prose li{margin:6px 0}

/* list of carriers (city/state) */
.clist{display:grid;gap:8px}
a.row{display:grid;grid-template-columns:1fr auto auto;gap:14px;align-items:center;background:var(--white);border:2px solid var(--asphalt);border-radius:10px;padding:14px 18px;color:var(--asphalt)}
a.row:hover{border-color:var(--sign);text-decoration:none}
a.row .rn{font-weight:800;font-size:16px}
a.row .rl{font:600 12px "Overpass Mono",monospace;color:var(--muted)}
a.row .rf{font:700 13px "Overpass Mono",monospace;text-align:right;white-space:nowrap}

/* footer */
footer.site{border-top:3px solid var(--asphalt);margin-top:54px;background:var(--white)}
footer.site .wrap{padding:30px 0;display:grid;gap:16px}
footer .frow{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;align-items:center}
footer .brand{font-size:22px}
footer nav{display:flex;gap:18px;flex-wrap:wrap;font:700 12px "Overpass Mono",monospace;text-transform:uppercase;letter-spacing:.04em}
footer nav a{color:var(--asphalt)}
.disclaimer{font-size:12.5px;color:var(--muted);line-height:1.55;max-width:90ch;border-top:1px solid var(--hair);padding-top:14px}

@media(max-width:680px){
  .search{grid-template-columns:1fr}.search .mag{display:none}
  a.row{grid-template-columns:1fr;gap:4px}a.row .rf{text-align:left}
  nav.top{display:none}
}
