:root{
  /* Palette matched to the truck/trailer wrap: charcoal + brand blue.
     To switch the accent to the logo red instead, change --accent/--accent-d to #e2231a / #bd1a13. */
  --charcoal:#1b1e23;
  --charcoal-2:#282d35;
  --accent:#1f5fc4;
  --accent-d:#174a9e;
  --accent-tint:#e9f0fb;
  --ink:#16181c;
  --slate:#5d636b;
  --line:#e6e7ea;
  --bg:#f6f7f8;
  --radius:14px;
  --shadow:0 10px 30px rgba(20,26,40,.12);
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"Segoe UI",-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
/* Logo font is DIN Alternate Bold; macOS has "DIN Alternate", Windows has "Bahnschrift". Self-host DIN at build for full fidelity. */
h1,h2,h3,.h2{font-family:"DIN Alternate","Bahnschrift","Segoe UI Semibold",Oswald,"Arial Narrow",sans-serif}
.h2,.hero h1{text-transform:uppercase;letter-spacing:-.01em}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.tag{display:inline-block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.eyebrow{color:var(--accent)}

/* top utility bar */
.topbar{background:var(--charcoal-2);color:#d6dae0;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:14px;flex-wrap:wrap;padding-top:6px;padding-bottom:6px}
.topbar a{color:#fff;font-weight:600}

/* header */
header.site{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:82px;gap:18px}
.brand{display:flex;align-items:center;flex:0 0 auto}
.brand img{height:58px;width:auto;max-width:none}
nav.main{display:flex;gap:24px;font-weight:600;font-size:.95rem}
nav.main a{padding:6px 0;border-bottom:2px solid transparent}
nav.main a:hover,nav.main a.active{color:var(--accent);border-color:var(--accent)}
.head-cta{display:flex;align-items:center;gap:12px}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:10px;padding:11px 18px;font-size:.92rem;transition:.15s;cursor:pointer;border:0;font-family:inherit}
.btn-call{background:#f0f1f3;color:var(--charcoal)}
.btn-call:hover{background:#e6e7ea}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 16px rgba(31,95,196,.32)}
.btn-primary:hover{background:var(--accent-d)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-dark{background:var(--charcoal);color:#fff}
.btn-dark:hover{background:#000}
@media(max-width:980px){nav.main{display:none}.btn-call .lbl{display:none}.brand img{height:50px}header.site .wrap{height:70px}}

/* hero (home) */
.hero{background:linear-gradient(160deg,var(--charcoal) 0%,var(--charcoal-2) 60%,#101216 100%);color:#fff;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 400px at 85% -10%,rgba(31,95,196,.28),transparent 60%);pointer-events:none}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;padding:64px 22px 72px}
.hero h1{font-size:clamp(2rem,4.2vw,3.15rem);line-height:1.08;font-weight:800}
.hero h1 em{color:#7fb0f3;font-style:normal}
.hero .sub{margin-top:18px;font-size:1.12rem;color:#c9ced6;max-width:32ch}
.hero .script{margin-top:14px;font-size:1.25rem;color:#fff;font-weight:600}
.hero .script b{color:#7fb0f3}
.hero-cta{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.hero-cta .btn{padding:14px 22px;font-size:1rem}
.hero-photo{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.14);aspect-ratio:4/3}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
@media(max-width:880px){.hero .wrap{grid-template-columns:1fr;padding:42px 22px 50px}.hero-photo{order:-1}}

/* page hero (inner pages) */
.page-hero{background:linear-gradient(160deg,var(--charcoal) 0%,var(--charcoal-2) 65%,#101216 100%);color:#fff;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 360px at 88% -20%,rgba(31,95,196,.26),transparent 60%);pointer-events:none}
.page-hero .wrap{position:relative;padding:42px 22px 48px}
.page-hero h1{font-size:clamp(1.8rem,3.6vw,2.7rem);font-weight:800;text-transform:uppercase;letter-spacing:-.01em;line-height:1.12}
.page-hero h1 em{color:#7fb0f3;font-style:normal}
.page-hero p{color:#c9ced6;margin-top:14px;max-width:62ch;font-size:1.08rem}
.crumbs{font-size:.8rem;color:#9aa3ad;margin-bottom:14px}
.crumbs a{color:#c9ced6}
.crumbs a:hover{color:#fff}

/* trust bar */
.trust{background:#0f1115;color:#e3e4e7}
.trust .wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:16px 22px}
.trust .item{display:flex;align-items:center;gap:9px;font-weight:600;font-size:.92rem}
.trust .item .c{color:#7fb0f3;font-size:1.05rem}

section{padding:68px 0}
.h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;margin-top:8px;line-height:1.15}
.lead{color:var(--slate);margin-top:12px;max-width:62ch}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* prose / content */
.prose{max-width:760px}
.prose h2{font-size:1.55rem;margin-top:34px;text-transform:none;letter-spacing:normal}
.prose h2:first-child{margin-top:0}
.prose p{margin-top:12px;color:#3f454c}
.prose ul{margin:16px 0 0 0;list-style:none;display:grid;gap:10px}
.prose ul li{padding-left:28px;position:relative;color:#3f454c}
.prose ul li::before{content:"\2713";position:absolute;left:0;top:0;color:var(--accent);font-weight:800}
.linkchips{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.linkchips a{background:var(--accent-tint);color:var(--accent);padding:8px 14px;border-radius:999px;font-weight:700;font-size:.9rem}
.linkchips a:hover{background:#dbe7f9}

/* services */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:.18s;position:relative;overflow:hidden;display:block;color:inherit}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#d3dde6}
.card .bar{position:absolute;top:0;left:0;height:4px;width:100%;background:var(--accent)}
.card .ic{width:52px;height:52px;border-radius:12px;background:var(--accent-tint);color:var(--accent);display:grid;place-items:center;font-size:1.5rem;margin-bottom:16px}
.card h3{font-size:1.2rem}
.card p{color:var(--slate);margin-top:8px;font-size:.95rem}
.card .more{margin-top:16px;color:var(--accent);font-weight:700;font-size:.9rem}
@media(max-width:880px){.cards{grid-template-columns:1fr}}

/* why / about / split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.why-photo{border-radius:16px;overflow:hidden;aspect-ratio:5/4;border:1px solid var(--line);box-shadow:var(--shadow)}
.why-photo img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.checklist{list-style:none;margin-top:22px;display:grid;gap:14px}
.checklist li{display:flex;gap:12px;align-items:flex-start;font-weight:500}
.checklist .ck{flex:0 0 24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:800;margin-top:1px}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:28px}}

/* reviews */
.reviews{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stars{color:#f5a623;letter-spacing:2px;font-size:1.05rem}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
.quote{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.quote p{font-size:.98rem;margin-top:10px}
.quote .who{margin-top:16px;font-weight:700;font-size:.9rem}
.quote .who span{color:var(--slate);font-weight:500}
@media(max-width:880px){.quotes{grid-template-columns:1fr}}

/* service area */
.area{background:linear-gradient(160deg,var(--charcoal-2),var(--charcoal));color:#fff}
.area .lead{color:#c9ced6}
.towns{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.towns span,.towns a{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:8px 14px;border-radius:999px;font-weight:600;font-size:.9rem;color:#fff}
.towns a:hover{background:rgba(255,255,255,.18)}

/* faq */
.faq{display:grid;gap:14px;margin:36px auto 0;max-width:780px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:4px 20px}
.faq summary{cursor:pointer;font-weight:700;padding:16px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:1.4rem;font-weight:700}
.faq details[open] summary::after{content:"\2013"}
.faq details p{color:var(--slate);padding:0 0 18px;margin:0}

/* contact + form */
.final{background:var(--accent);color:#fff;text-align:center}
.final .h2{color:#fff}
.final>.wrap>p{max-width:54ch;margin:12px auto 0;color:#eaf1fc}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;margin-top:40px;text-align:left}
.cform{display:grid;gap:14px}
.cform label{font-weight:700;font-size:.85rem;color:#fff;display:block;margin-bottom:6px}
.cform input,.cform textarea{width:100%;padding:13px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.96);font:inherit;font-size:.95rem;color:var(--ink)}
.cform textarea{min-height:110px;resize:vertical}
.cform .btn{width:100%;justify-content:center;margin-top:4px}
.recaptcha-disclosure{font-size:.72rem;color:#cfe0fb;margin-top:4px}
.recaptcha-disclosure a{color:#fff;text-decoration:underline}
.formnote{font-size:.82rem;margin-top:10px;min-height:1.2em}
.formnote.ok{color:#d6ffe0}
.formnote.err{color:#ffd9d6}
.cinfo{list-style:none}
.cinfo li{display:flex;gap:12px;align-items:flex-start;margin-bottom:18px;color:#eaf1fc}
.cinfo .ic{flex:0 0 38px;height:38px;border-radius:10px;background:rgba(0,0,0,.18);display:grid;place-items:center;font-size:1.1rem}
.cinfo b{display:block;color:#fff}
.cinfo a{color:#fff;text-decoration:underline}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:28px}}

/* footer */
footer{background:#0f1115;color:#a8acb3;padding:54px 0 30px;font-size:.92rem}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
footer h4{color:#fff;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}
footer a:hover{color:#fff}
.flogo{background:#fff;border-radius:12px;padding:12px 14px;display:inline-block}
.flogo img{height:62px;width:auto}
footer ul{list-style:none;display:grid;gap:9px}
.fbar{border-top:1px solid rgba(255,255,255,.1);margin-top:34px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem;opacity:.85}
@media(max-width:880px){.fgrid{grid-template-columns:1fr;gap:26px}}

/* success modal */
.modal-overlay{position:fixed;inset:0;background:rgba(15,17,21,.55);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}
.modal-overlay.show{opacity:1;visibility:visible}
.modal-card{background:#fff;border-radius:16px;padding:36px 30px;max-width:390px;width:100%;text-align:center;box-shadow:0 24px 70px rgba(0,0,0,.32);transform:translateY(12px) scale(.97);transition:transform .28s ease}
.modal-overlay.show .modal-card{transform:none}
.modal-card .check{width:64px;height:64px;border-radius:50%;background:#2e9e5b;color:#fff;display:grid;place-items:center;font-size:2.1rem;margin:0 auto 18px;box-shadow:0 6px 18px rgba(46,158,91,.4)}
.modal-card h3{font-size:1.5rem}
.modal-card p{color:var(--slate);margin-top:8px}

/* mobile sticky call bar */
.mobilebar{display:none}
@media(max-width:980px){
  .mobilebar{display:grid;grid-template-columns:1fr 1fr;position:fixed;bottom:0;left:0;right:0;z-index:60;box-shadow:0 -6px 20px rgba(0,0,0,.18)}
  .mobilebar a{padding:15px 0;text-align:center;font-weight:800;font-size:.98rem;color:#fff}
  .mobilebar .mcall{background:var(--charcoal)}
  .mobilebar .mreq{background:var(--accent)}
  footer{padding-bottom:84px}
}
