/* ═══════════════════════════════════════════════════════════
   BORA TOWING v5 — TOWA-Inspired · Blue & White · Mobile First
   Fonts: Rajdhani (display) + Open Sans (body)
   All pages share this file
═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@500;600;700&family=Open+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root {
  --blue:       #1250aa;
  --blue-dk:    #0b3474;
  --blue-deep:  #071f4a;
  --blue-lt:    #1a6dd4;
  --blue-pale:  #e8f0fb;
  --white:      #ffffff;
  --off:        #f4f7fc;
  --charcoal:   #0f1823;
  --dark:       #0d1b33;
  --dark2:      #162040;
  --border:     #dde5f0;
  --text:       #1e293b;
  --text-mid:   #4a5a72;
  --text-light: #8fa3c0;
  --gold:       #f0a500;
  --green:      #22c55e;
  --font-d:     'Rajdhani', sans-serif;
  --font-b:     'Open Sans', sans-serif;
  --ease:       cubic-bezier(.25,.46,.45,.94);
  --r:          6px;
  --shadow:     0 4px 20px rgba(11,52,116,.10);
  --shadow-lg:  0 12px 48px rgba(11,52,116,.16);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-b);color:var(--text);background:var(--white);line-height:1.65;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
address{font-style:normal}
ul{list-style:none}
button{cursor:pointer;font-family:inherit}

/* ── LAYOUT ── */
.container{max-width:1180px;margin:0 auto;padding:0 20px}
@media(min-width:640px){.container{padding:0 28px}}
@media(min-width:1024px){.container{padding:0 40px}}
.section{padding:64px 0}
@media(min-width:768px){.section{padding:88px 0}}
.section-sm{padding:48px 0}
@media(min-width:768px){.section-sm{padding:64px 0}}

/* ── TYPE ── */
.tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-d);font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin-bottom:10px}
.tag::before{content:'';display:block;width:24px;height:3px;background:var(--blue);border-radius:2px;flex-shrink:0}
.tag-w{color:rgba(255,255,255,.65)}.tag-w::before{background:rgba(255,255,255,.5)}
.h-title{font-family:var(--font-d);font-size:clamp(28px,5vw,50px);font-weight:700;line-height:1.08;color:var(--text);letter-spacing:.01em}
.h-title span{color:var(--blue)}
.h-title-w{color:#fff}.h-title-w span{color:#90c0ff}
.h-sub{font-size:15px;color:var(--text-mid);line-height:1.78;max-width:540px;margin-top:12px}
@media(min-width:640px){.h-sub{font-size:16px}}
.h-sub-w{color:rgba(255,255,255,.7)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-d);font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;padding:12px 22px;border-radius:var(--r);border:2px solid transparent;transition:all .22s var(--ease);white-space:nowrap}
@media(min-width:640px){.btn{font-size:15px;padding:13px 26px}}
.btn-blue{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-blue:hover{background:var(--blue-dk);border-color:var(--blue-dk);transform:translateY(-2px);box-shadow:0 8px 24px rgba(18,80,170,.35)}
.btn-white{background:#fff;color:var(--blue-dk);border-color:#fff}
.btn-white:hover{background:var(--off);transform:translateY(-2px)}
.btn-ow{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ow:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.btn-ob{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-ob:hover{background:var(--blue);color:#fff}
.btn-lg{padding:15px 28px;font-size:15px}
@media(min-width:640px){.btn-lg{padding:16px 34px;font-size:16px}}

/* ── ACCENT STRIPE ── */
.accent-stripe{height:5px;background:linear-gradient(90deg,var(--blue-dk),var(--blue),var(--blue-lt))}

/* ── ALERT BAR ── */
.alert-bar{background:var(--blue-dk);padding:10px 0}
.alert-bar-inner{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;text-align:center;font-size:13px;color:rgba(255,255,255,.85)}
.alert-bar strong{color:#fff}
.alert-bar a{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:2px}

/* ── NAV ── */
.site-nav{background:var(--dark);position:sticky;top:0;z-index:500;box-shadow:0 2px 16px rgba(0,0,0,.35)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:66px;gap:16px}
@media(min-width:768px){.nav-inner{height:72px}}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-logo img{height:52px;width:auto;mix-blend-mode:screen;filter:brightness(1.05)}
@media(min-width:768px){.nav-logo img{height:60px}}
.nav-logo-text{font-family:var(--font-d);font-size:20px;font-weight:700;color:#fff;letter-spacing:.04em;text-transform:uppercase;line-height:1}
.nav-logo-text span{color:var(--blue-lt);display:block;font-size:.65em;letter-spacing:.1em}
.nav-links{display:none;list-style:none;align-items:center;gap:2px}
@media(min-width:960px){.nav-links{display:flex}}
.nav-links a{font-family:var(--font-d);font-size:13.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.65);padding:8px 12px;border-radius:4px;transition:color .2s,background .2s}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(255,255,255,.08)}
.nav-links .has-drop{position:relative}
.nav-links .has-drop:hover .drop{display:block}
.drop{display:none;position:absolute;top:100%;left:0;min-width:220px;background:var(--dark2);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);box-shadow:var(--shadow-lg);z-index:100;padding:8px 0}
.drop a{display:block;padding:10px 16px;font-size:13px;color:rgba(255,255,255,.7);white-space:nowrap;transition:color .18s,background .18s}
.drop a:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav-phone{display:none;align-items:center;gap:8px;background:var(--blue);color:#fff;font-family:var(--font-d);font-weight:700;font-size:14px;letter-spacing:.05em;text-transform:uppercase;padding:9px 18px;border-radius:var(--r);transition:background .2s;white-space:nowrap;flex-shrink:0}
@media(min-width:768px){.nav-phone{display:flex}}
.nav-phone:hover{background:var(--blue-lt)}
.hamburger{display:flex;flex-direction:column;gap:5px;background:none;border:none;padding:6px;flex-shrink:0}
@media(min-width:960px){.hamburger{display:none}}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .28s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE DRAWER ── */
.mob-drawer{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--dark);z-index:499;flex-direction:column;overflow-y:auto;padding-top:72px}
.mob-drawer.open{display:flex}
.mob-drawer-inner{padding:16px 20px 40px}
.mob-drawer a{display:block;font-family:var(--font-d);font-size:20px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.8);padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08);transition:color .18s}
.mob-drawer a:hover{color:#fff}
.mob-drawer .mob-sub{padding-left:16px}
.mob-drawer .mob-sub a{font-size:16px;color:rgba(255,255,255,.55);padding:10px 0}
.mob-drawer-cta{margin:20px 0 0;background:var(--blue);color:#fff;text-align:center;padding:18px;border-radius:var(--r);font-family:var(--font-d);font-weight:700;font-size:18px;letter-spacing:.06em;text-transform:uppercase;display:block}
.mob-social{display:flex;gap:10px;margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap}
.mob-social .soc{width:42px;height:42px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:#fff;transition:all .2s}
.mob-social .soc:hover{transform:translateY(-2px)}
.mob-social .soc-fb:hover{background:#1877f2;border-color:#1877f2}
.mob-social .soc-ig:hover{background:linear-gradient(135deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);border-color:#d62976}
.mob-social .soc-x:hover{background:#000;border-color:#000}
.mob-social .soc-google:hover{background:#fff;border-color:#fff}
.mob-social .soc-yt:hover{background:#ff0000;border-color:#ff0000}

/* ── FLOATING CALL ── */
.float-call{position:fixed;bottom:20px;right:16px;z-index:600;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
@media(min-width:640px){.float-call{bottom:28px;right:28px}}
.float-btn{display:flex;align-items:center;gap:9px;background:var(--blue);color:#fff;font-family:var(--font-d);font-weight:700;font-size:15px;padding:13px 20px;border-radius:50px;box-shadow:0 6px 24px rgba(18,80,170,.45);animation:pulse-f 2.8s ease infinite;transition:transform .2s,box-shadow .2s}
.float-btn:hover{transform:scale(1.05);box-shadow:0 10px 32px rgba(18,80,170,.55)}
@keyframes pulse-f{0%{box-shadow:0 6px 24px rgba(18,80,170,.45),0 0 0 0 rgba(18,80,170,.4)}70%{box-shadow:0 6px 24px rgba(18,80,170,.45),0 0 0 16px rgba(18,80,170,0)}100%{box-shadow:0 6px 24px rgba(18,80,170,.45),0 0 0 0 rgba(18,80,170,0)}}
.float-badge{background:var(--dark);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.8);font-family:var(--font-b);font-size:11px;font-weight:600;padding:5px 12px;border-radius:20px;display:flex;align-items:center;gap:6px}
.live-dot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:blink 1.5s ease infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.15}}

/* ── PAGE HERO ── */
.page-hero{background:var(--dark);padding:72px 0 64px;position:relative;overflow:hidden}
.page-hero-photo{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.18}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,31,74,.97) 35%,rgba(7,31,74,.7) 100%)}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{font-family:var(--font-d);font-size:clamp(30px,6vw,62px);font-weight:700;color:#fff;line-height:1.05;letter-spacing:.01em;text-transform:uppercase}
.page-hero h1 span{color:var(--blue-lt)}
.page-hero p{font-size:15px;color:rgba(255,255,255,.68);max-width:560px;margin-top:12px;line-height:1.75}
@media(min-width:640px){.page-hero p{font-size:17px}}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.38);font-family:var(--font-d);margin-bottom:18px;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.55);transition:color .18s}
.breadcrumb a:hover{color:#fff}

/* ── TRUST BAR ── */
.trust-bar{background:var(--blue-dk)}
.trust-inner{display:grid;grid-template-columns:1fr 1fr}
@media(min-width:768px){.trust-inner{grid-template-columns:repeat(4,1fr)}}
.trust-cell{display:flex;align-items:center;gap:12px;padding:18px 16px;border-right:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);transition:background .2s}
.trust-cell:hover{background:rgba(255,255,255,.05)}
@media(min-width:768px){.trust-cell{padding:20px 22px;border-bottom:none}}
.t-icon{font-size:26px;flex-shrink:0}
.t-head{font-family:var(--font-d);font-size:13px;font-weight:700;color:#fff;letter-spacing:.04em;text-transform:uppercase;line-height:1.2}
.t-sub{font-size:11px;color:rgba(255,255,255,.5);margin-top:2px}

/* ── STATS ── */
.stats-grid{display:grid;grid-template-columns:1fr 1fr}
@media(min-width:768px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat-block{padding:40px 20px;text-align:center;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--white)}
@media(min-width:768px){.stat-block{padding:52px 28px;border-bottom:none}}
.stat-block.blue{background:var(--blue)}
.stat-block.blue .stat-n{color:#fff}.stat-block.blue .stat-l{color:rgba(255,255,255,.65)}
.stat-n{font-family:var(--font-d);font-size:clamp(38px,5vw,56px);font-weight:700;color:var(--blue-dk);line-height:1;letter-spacing:-.02em}
.stat-n sup{font-size:.42em;vertical-align:super;color:var(--blue);font-weight:600}
.stat-l{font-family:var(--font-d);font-size:12px;font-weight:600;color:var(--text-light);margin-top:8px;letter-spacing:.06em;text-transform:uppercase}

/* ── SERVICE CARDS (dark bg) ── */
.svc-grid{display:grid;grid-template-columns:1fr}
@media(min-width:540px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.svc-grid{grid-template-columns:repeat(3,1fr)}}
.svc-card{background:var(--dark2);padding:30px 26px 28px;position:relative;overflow:hidden;transition:background .28s;border:1px solid rgba(255,255,255,.05);border-left:3px solid var(--blue)}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.svc-card:hover{background:rgba(18,80,170,.12);border-left-color:var(--blue-lt)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-icon{width:58px;height:58px;background:rgba(18,80,170,.18);border:2px solid rgba(18,80,170,.35);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:background .25s,border-color .25s;overflow:hidden;flex-shrink:0}
.svc-card:hover .svc-icon{background:var(--blue);border-color:var(--blue)}
.svc-icon img{width:32px;height:32px;object-fit:contain;filter:brightness(0) invert(1)}
.svc-card h3{font-family:var(--font-d);font-size:19px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}
.svc-card p{font-size:13.5px;color:rgba(255,255,255,.6);line-height:1.72}
.svc-link{display:inline-flex;align-items:center;gap:5px;margin-top:16px;font-family:var(--font-d);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-lt);transition:gap .22s}
.svc-card:hover .svc-link{gap:10px;color:#fff}

/* ── WHY SPLIT ── */
.why-split{display:grid;grid-template-columns:1fr}
@media(min-width:900px){.why-split{grid-template-columns:1fr 1fr;min-height:520px}}
.why-photo{overflow:hidden;position:relative;min-height:280px}
@media(min-width:900px){.why-photo{clip-path:polygon(0 0, 88% 0, 100% 100%, 0 100%)}}
.why-photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.why-split:hover .why-photo img{transform:scale(1.04)}
.why-content{background:var(--off);padding:48px 24px}
@media(min-width:640px){.why-content{padding:56px 40px}}
@media(min-width:900px){.why-content{padding:72px 56px 72px 64px;display:flex;flex-direction:column;justify-content:center}}
.why-pts{margin-top:28px}
.why-pt{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.why-pt:first-child{border-top:1px solid var(--border)}
.why-num{font-family:var(--font-d);font-size:38px;font-weight:700;color:var(--border);line-height:1;min-width:46px;flex-shrink:0;transition:color .25s}
.why-pt:hover .why-num{color:var(--blue)}
.why-pt h4{font-family:var(--font-d);font-size:16px;font-weight:700;color:var(--blue-dk);text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px}
.why-pt p{font-size:13.5px;color:var(--text-mid);line-height:1.65}

/* ── AREA ── */
.area-wrap{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:768px){.area-wrap{grid-template-columns:1fr 1fr;gap:64px}}
.area-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.area-tag{display:inline-block;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:4px;padding:7px 14px;font-family:var(--font-d);font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.75);text-decoration:none;transition:background .18s,border-color .18s,color .18s;margin:0 4px 6px 0}
.area-tag:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.4);color:#fff}
a.area-tag{cursor:pointer}
.hours-panel{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:var(--r);padding:28px}
.hours-panel h3{font-family:var(--font-d);font-size:18px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.05em;margin-bottom:18px}
.h-row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:14px}
.h-row:last-of-type{border-bottom:none}
.h-day{color:rgba(255,255,255,.6);font-family:var(--font-d);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.h-time{font-family:var(--font-d);font-size:16px;font-weight:700;color:#fff}

/* ── REVIEWS ── */
.reviews-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-top:44px}
@media(min-width:640px){.reviews-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.reviews-grid{grid-template-columns:repeat(3,1fr)}}
.rev-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:28px;transition:box-shadow .25s,transform .25s}
.rev-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.rev-stars{font-size:15px;color:var(--gold);letter-spacing:2px;margin-bottom:12px}
.rev-text{font-size:14px;color:var(--text-mid);line-height:1.75;font-style:italic;margin-bottom:16px}
.rev-author{font-family:var(--font-d);font-size:15px;font-weight:700;color:var(--blue-dk);text-transform:uppercase;letter-spacing:.04em}
.rev-loc{font-size:11px;color:var(--text-light);margin-top:2px;font-weight:600}
.rev-q{font-size:64px;line-height:.7;color:var(--blue-pale);font-family:Georgia,serif;float:right;margin:0 0 6px 10px}

/* ── CTA BAND ── */
.cta-band{background:var(--blue);position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:-80px;right:-80px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.05);pointer-events:none}
.cta-inner{display:flex;flex-direction:column;gap:24px;padding:52px 0}
@media(min-width:768px){.cta-inner{flex-direction:row;align-items:center;justify-content:space-between;gap:32px;padding:60px 0}}
.cta-text h2{font-family:var(--font-d);font-size:clamp(24px,4vw,44px);font-weight:700;color:#fff;line-height:1.08;text-transform:uppercase;letter-spacing:.02em}
.cta-text p{font-size:15px;color:rgba(255,255,255,.78);margin-top:6px}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap}

/* ── FAQ ── */
.faq-layout{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:768px){.faq-layout{grid-template-columns:1fr 2fr;gap:72px}}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-btn{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 0;background:none;border:none;text-align:left;font-family:var(--font-d);font-size:16px;font-weight:700;color:var(--blue-dk);text-transform:uppercase;letter-spacing:.02em;transition:color .18s}
.faq-btn:hover{color:var(--blue)}
.faq-icon{width:28px;height:28px;border-radius:50%;background:var(--blue-pale);border:2px solid var(--blue);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--blue);flex-shrink:0;transition:all .3s var(--ease);font-family:monospace;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--blue);color:#fff}
.faq-body{max-height:0;overflow:hidden;transition:max-height .42s var(--ease),padding .3s;font-size:14.5px;color:var(--text-mid);line-height:1.78}
.faq-item.open .faq-body{max-height:300px;padding-bottom:18px}

/* ── FLEET CARDS ── */
.fleet-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(min-width:640px){.fleet-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.fleet-grid{grid-template-columns:repeat(4,1fr)}}
.fleet-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:22px 18px;transition:box-shadow .25s,transform .25s,border-color .25s}
.fleet-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:#bed3f0}
.fleet-year{display:inline-block;background:var(--blue-pale);border:1px solid #93c5fd;border-radius:3px;padding:3px 9px;font-family:var(--font-d);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.fleet-card h3{font-family:var(--font-d);font-size:16px;font-weight:700;color:var(--blue-dk);margin-bottom:2px;text-transform:uppercase}
.fleet-type{font-size:12px;color:var(--text-light);margin-bottom:8px}
.fleet-badge{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--text-mid);margin-top:5px;font-family:var(--font-d);font-weight:600}
.fleet-card.cta{background:var(--blue);border-color:var(--blue);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px}

/* ── GALLERY ── */
.gallery-masonry{columns:1;column-gap:8px}
@media(min-width:480px){.gallery-masonry{columns:2}}
@media(min-width:760px){.gallery-masonry{columns:3}}
@media(min-width:1100px){.gallery-masonry{columns:4}}
.gal-item{break-inside:avoid;margin-bottom:8px;border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;display:block}
/* Homepage "Our Trucks in Action" grid — mobile-first responsive */
/* Mobile (default): featured photo full-width on top, 4 photos in 2x2 below */
.trucks-grid{display:grid;gap:8px;border-radius:var(--r);overflow:hidden;grid-template-columns:1fr 1fr;grid-auto-rows:180px}
.trucks-grid .gal-item{margin:0;height:100%}
.trucks-grid .gal-item img{height:100%;width:100%;object-fit:cover}
.trucks-grid .gal-feat{grid-column:1 / -1}
 @media(min-width:640px){.trucks-grid{grid-auto-rows:200px}}
/* Desktop: featured tall on left + 2x2 grid on right, all photos smaller/compact */
 @media(min-width:900px){
  .trucks-grid{grid-template-columns:2fr 1fr 1fr;grid-template-rows:160px 160px;grid-auto-rows:auto}
  .trucks-grid .gal-feat{grid-column:1;grid-row:1 / span 2}
 }
.gal-item img{width:100%;display:block;transition:transform .45s var(--ease),filter .35s;filter:brightness(.86)}
.gal-item:hover img{transform:scale(1.05);filter:brightness(1)}
.gal-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,52,116,.72) 0%,transparent 55%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:14px}
.gal-item:hover .gal-ov{opacity:1}
.gal-cap{font-family:var(--font-d);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff}

/* ── LIGHTBOX ── */
#lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.93);z-index:9999;align-items:center;justify-content:center;padding:16px}
#lb.open{display:flex!important}
#lb img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:var(--r);box-shadow:0 24px 80px rgba(0,0,0,.6)}
.lb-x{position:absolute;top:14px;right:18px;font-size:40px;color:#fff;background:none;border:none;opacity:.5;line-height:1;transition:opacity .2s;padding:4px}
.lb-x:hover{opacity:1}

/* ── FORM ── */
.form-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:32px 24px;box-shadow:var(--shadow)}
@media(min-width:640px){.form-card{padding:40px}}
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.fg label{font-family:var(--font-d);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-light)}
.fg input,.fg select,.fg textarea{width:100%;padding:11px 14px;background:var(--off);border:1.5px solid var(--border);border-radius:4px;font-family:var(--font-b);font-size:14px;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s,background .2s;-webkit-appearance:none}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(18,80,170,.1)}
.fg input.err,.fg select.err,.fg textarea.err{border-color:#ef4444!important;background:#fef2f2!important}
.form-error{background:#fef2f2;border:1px solid #fca5a5;border-radius:4px;padding:10px 14px;font-size:13.5px;color:#dc2626;margin-bottom:14px}
.fg.err{padding:8px 10px;background:#fef2f2;border-radius:4px;border:1px solid #fca5a5}
.fg.err .radio-group{margin:0}
.fg small{font-size:11px;color:var(--text-light);margin-top:4px;display:block}
.fg textarea{resize:vertical;min-height:90px}
.fg select{cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr;gap:0}
@media(min-width:540px){.form-row{grid-template-columns:1fr 1fr;gap:14px}}
.submit-btn{width:100%;padding:14px;background:var(--blue);color:#fff;border:none;border-radius:4px;font-family:var(--font-d);font-size:16px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:background .2s,transform .15s;margin-top:4px}
.submit-btn:hover{background:var(--blue-dk);transform:translateY(-1px)}
.form-note{font-size:12px;color:var(--text-light);text-align:center;margin-top:8px;line-height:1.6}
.form-ok{display:none;background:#f0fdf4;border:1px solid #86efac;border-radius:var(--r);padding:36px;text-align:center}
.form-ok h3{font-family:var(--font-d);font-size:24px;font-weight:700;color:var(--blue-dk);margin:10px 0 6px;text-transform:uppercase}
.form-ok p{font-size:14px;color:var(--text-mid)}

/* ── INFO CARDS ── */
.info-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;display:flex;gap:14px;align-items:flex-start;transition:border-color .2s,box-shadow .2s}
.info-card:hover{border-color:#bed3f0;box-shadow:var(--shadow)}
.ic-icon{width:42px;height:42px;background:var(--blue-pale);border:1px solid #93c5fd;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ic-label{font-family:var(--font-d);font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-light);margin-bottom:3px}
.ic-value{font-size:14px;font-weight:600;color:var(--blue-dk)}
.ic-value a{color:var(--blue);transition:color .18s}
.ic-value a:hover{color:var(--blue-dk)}
.ic-note{font-size:11.5px;color:var(--text-light);margin-top:2px}

/* ── ADDRESSES ── */
.addresses-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:540px){.addresses-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.addresses-grid{grid-template-columns:repeat(4,1fr)}}
.addr-card{background:var(--off);border:1px solid var(--border);border-radius:var(--r);padding:20px;transition:border-color .2s,box-shadow .2s}
.addr-card:hover{border-color:#bed3f0;box-shadow:var(--shadow)}
.addr-type{font-family:var(--font-d);font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--blue);margin-bottom:6px}
.addr-card address{font-size:13.5px;color:var(--text-mid);line-height:1.75}
.addr-card a{color:var(--blue);font-size:12px;font-weight:600;margin-top:6px;display:inline-block;transition:color .18s}
.addr-card a:hover{color:var(--blue-dk)}

/* ── SOCIAL ICONS ── */
.social-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.social-btn{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:18px;transition:background .2s,border-color .2s;color:#fff}
.social-btn:hover{background:var(--blue);border-color:var(--blue)}

/* ── FOOTER ── */
.site-footer{background:var(--charcoal);color:rgba(255,255,255,.72)}
.footer-top{padding:64px 0 48px}
@media(min-width:768px){.footer-top{padding:80px 0 60px}}
.footer-grid{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:640px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(min-width:960px){.footer-grid{grid-template-columns:2.2fr 1fr 1fr 1fr 1fr;gap:44px}}
.f-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.f-logo img{height:56px;width:auto;mix-blend-mode:screen;filter:brightness(1.05)}
.f-logo-text{font-family:var(--font-d);font-size:18px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.04em;line-height:1}
.f-logo-text span{color:var(--blue-lt);display:block;font-size:.65em;letter-spacing:.1em}
.f-desc{font-size:13.5px;color:rgba(255,255,255,.45);line-height:1.82;margin-bottom:18px}
.f-contact a{display:flex;align-items:center;gap:9px;font-size:13.5px;color:rgba(255,255,255,.58);margin-bottom:8px;transition:color .18s}
.f-contact a:hover{color:#fff}
.f-col h4{font-family:var(--font-d);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:14px}
.f-col ul li{margin-bottom:8px}
.f-col ul li a{font-size:13.5px;color:rgba(255,255,255,.5);transition:color .18s}
.f-col ul li a:hover{color:#fff}
.f-col .f-addr{font-size:13px;color:rgba(255,255,255,.35);line-height:1.85;margin-bottom:10px}
.f-col .f-addr strong{color:rgba(255,255,255,.55);font-weight:600;font-family:var(--font-d);letter-spacing:.04em;text-transform:uppercase;display:block;font-size:11px;margin-bottom:4px}
.f-social{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.f-social .soc{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.85);display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:all .22s ease}
.f-social .soc:hover{transform:translateY(-2px);color:#fff}
.f-social .soc-fb:hover{background:#1877f2;border-color:#1877f2}
.f-social .soc-ig:hover{background:linear-gradient(135deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);border-color:#d62976}
.f-social .soc-x:hover{background:#000;border-color:#000}
.f-social .soc-google:hover{background:#fff;border-color:#fff}
.f-social .soc-yt:hover{background:#ff0000;border-color:#ff0000}
/* Light-background variant (e.g. contact page Follow Us on white) */
/* Light-background variant (e.g. contact page Follow Us on white) — dark icons */
.f-social-light .soc{background:#f1f5f9;border:1px solid #d8e0ea;color:#0d1b33}
.f-social-light .soc:hover{color:#fff}
.f-social-light .soc-google{color:inherit}
.f-social-light .soc-google:hover{background:#f1f5f9;border-color:#d8e0ea}
.footer-mid{border-top:1px solid rgba(255,255,255,.06);padding:28px 0}
.footer-mid-inner{display:flex;flex-wrap:wrap;gap:16px;align-items:start}
.f-hours{font-size:13px;color:rgba(255,255,255,.35);line-height:1.9}
.f-hours strong{color:rgba(255,255,255,.55);font-family:var(--font-d);font-weight:700;letter-spacing:.04em;text-transform:uppercase;display:block;font-size:11px;margin-bottom:4px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:20px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:12px;color:rgba(255,255,255,.28);font-family:var(--font-d);font-weight:600;letter-spacing:.04em}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.up{opacity:1;transform:none}
/* Fallback: if JS fails or is slow, reveal everything after 1.5s so content never stays hidden */
@keyframes revealFallback{to{opacity:1;transform:none}}
.reveal{animation:revealFallback 0s linear 1.5s forwards}
.reveal.up{animation:none}

/* ── HERO SLIDER ── */
.hero-slider{position:relative;overflow:hidden;min-height:85vh;background:var(--dark)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;pointer-events:none}
.hero-slide.active{opacity:1;pointer-events:auto}
.hero-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);transition:transform 6s ease}
.hero-slide.active .hero-slide-bg{transform:scale(1)}
.hero-slide-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(7,31,74,.96) 35%,rgba(7,31,74,.65) 70%,rgba(7,31,74,.25) 100%)}
.hero-content{position:relative;z-index:2;padding:100px 0 72px;display:flex;flex-direction:column;justify-content:flex-end;min-height:85vh}
@media(min-width:768px){.hero-content{padding:120px 0 80px}}
.hero-slide-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);transition:background .3s,transform .3s;cursor:pointer}
.dot.active{background:#fff;transform:scale(1.3)}

/* hero text */
.hero-tag{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-d);font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:18px;animation:fadeUp .7s var(--ease) both}
.hero-tag-line{width:32px;height:3px;background:var(--blue-lt);border-radius:2px;flex-shrink:0}
.hero h1{font-family:var(--font-d);font-size:clamp(44px,8vw,92px);font-weight:700;line-height:.93;color:#fff;text-transform:uppercase;letter-spacing:.01em;margin-bottom:20px;animation:fadeUp .8s var(--ease) .1s both}
.hero h1 .line-b{color:var(--blue-lt);display:block}
.hero h1 .line-o{-webkit-text-stroke:2px rgba(255,255,255,.32);color:transparent;display:block}
.hero-desc{font-size:16px;color:rgba(255,255,255,.72);line-height:1.7;max-width:520px;margin-bottom:14px;animation:fadeUp .8s var(--ease) .18s both}
@media(min-width:640px){.hero-desc{font-size:18px}}
.status-chip{display:inline-flex;align-items:center;gap:8px;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);border-radius:30px;padding:6px 14px;font-family:var(--font-d);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#4ade80;margin-bottom:22px;animation:fadeUp .8s var(--ease) .05s both}
.s-dot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:blink 1.5s ease infinite;flex-shrink:0}
.hero-phone-row{display:flex;align-items:center;gap:12px;margin-bottom:28px;animation:fadeUp .8s var(--ease) .26s both}
.phone-circle{width:46px;height:46px;background:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;box-shadow:0 0 0 8px rgba(18,80,170,.2);animation:pulse-f 2.8s ease infinite}
.hero-phone{font-family:var(--font-d);font-size:clamp(28px,4vw,48px);font-weight:700;color:#fff;letter-spacing:.01em;line-height:1;transition:color .2s}
.hero-phone:hover{color:var(--blue-lt)}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;animation:fadeUp .8s var(--ease) .34s both}
.hero-pills{display:flex;gap:8px;flex-wrap:wrap;margin-top:36px;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);animation:fadeUp .8s var(--ease) .42s both}
.hero-pill{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:30px;padding:6px 12px;font-family:var(--font-d);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.75)}
.pill-check{font-size:10px;color:var(--green)}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ── TESTIMONIALS ── */
.testi-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){.testi-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.testi-grid{grid-template-columns:repeat(3,1fr)}}

/* ── JOBS ── */
.job-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:28px 24px;display:flex;flex-direction:column;gap:14px;transition:box-shadow .25s,border-color .25s}
.job-card:hover{box-shadow:var(--shadow-lg);border-color:#bed3f0}
.job-title{font-family:var(--font-d);font-size:20px;font-weight:700;color:var(--blue-dk);text-transform:uppercase;letter-spacing:.03em}
.job-meta{display:flex;gap:10px;flex-wrap:wrap}
.job-badge{background:var(--blue-pale);border:1px solid #93c5fd;border-radius:3px;padding:4px 10px;font-family:var(--font-d);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue)}
.job-desc{font-size:14px;color:var(--text-mid);line-height:1.72}
