/* ======= Mobile-first premium, boxy, no horizontal scroll ======= */
:root{
  --brand:#F06400;      /* vivid orange */
  --brand-2:#161616;    /* deep charcoal for navbar/accents */
  --info:#F3E9D3;       /* warm cream for info banner */
  --info-text:#2A2A2A;  /* readable on banner */
  --accent:#FFC72C;     /* touch of yellow */
  --black:#0B0B0C;
  --white:#FFFFFF;
  --text:#1A1A1A;
  --muted:#616161;

  --container:1200px;

  --s-2:.25rem; --s-4:.5rem; --s-6:.75rem; --s-8:1rem; --s-10:1.25rem;
  --s-12:1.5rem; --s-16:2rem; --s-20:2.5rem; --s-24:3rem; --s-32:4rem; --s-40:5rem;

  --shadow:0 8px 28px rgba(0,0,0,.18);
  --fast:200ms; --slow:700ms; --ease:cubic-bezier(.25,.1,.25,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{ font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif; color:var(--text); background:#FAFAFA; overflow-x:hidden; }
img{ max-width:100%; display:block; height:auto; }
a{ color:inherit; text-decoration:none; }
.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 var(--s-16); }

/* Headings / brand */
h1,h2{ font-family:Poppins,Inter,sans-serif; font-weight:700; line-height:1.12; margin:0 0 var(--s-10); }
.h2,h2{ font-size:clamp(1.6rem,4.8vw,2.4rem); }
.lead{ font-size:clamp(1rem,3.6vw,1.25rem); color:#222; }
.brand-text .amber{ font-size:1.25rem; color:#fff; letter-spacing:.2px; }
.brand-text .logx{ font-size:.95rem; color:var(--brand); font-weight:700; margin-left:.25rem; }

/* Buttons */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5rem; font-weight:600;
  padding:.9rem 1.1rem; border:2px solid var(--black); background:transparent; color:var(--black);
  transition: transform var(--fast) var(--ease), background var(--fast) var(--ease), color var(--fast) var(--ease), border-color var(--fast) var(--ease);
}
.btn:hover{ transform:translateY(-1px); }
.btn.primary{ background:var(--brand); color:#fff; border-color:var(--brand); }
.btn.ghost{ background:transparent; color:#fff; border-color:#fff; }
.btn-link{ color:#fff; border-color:transparent; padding:.5rem .75rem; }
.btn.wide{ width:100%; }

/* Skip link */
.skip-link{ position:absolute; left:-9999px; top:auto; }
.skip-link:focus{ left:var(--s-16); top:var(--s-16); background:var(--brand); color:#fff; padding:.5rem .75rem; }

/* Sections */
.section{ padding:var(--s-32) 0; position:relative; }
.section.solid{ background:#fff; }
.section.stripe{ background:#F5F5F7; }
.section.accent{ background:#F2F0EA; }
.section .section-head{ margin-bottom:var(--s-20); }
.center{ text-align:center; }
.light{ color:#fff; }

/* Navbar (SOLID + FIXED; color-matched) */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:60;
  background: var(--brand-2); color:#fff; border-bottom:2px solid rgba(255,255,255,.08);
}
.nav-wrap{ display:flex; align-items:center; justify-content:space-between; min-height:72px; gap:var(--s-16); }
.brand{ display:flex; align-items:center; gap:.65rem; }
.brand-mark{ object-fit:contain; }

/* Desktop nav */
.primary-nav{ display:none; }
.menu{ list-style:none; display:flex; gap:.35rem; padding:0; margin:0; }
.menu a{ display:inline-flex; align-items:center; padding:.6rem .7rem; color:#fff; border:2px solid transparent; }
.menu a:hover{ background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.1); }

/* Hamburger */
.hamburger{ width:46px; height:42px; background:transparent; border:0; position:relative; cursor:pointer; }
.hamburger .line{ position:absolute; left:10px; right:10px; height:2px; background:#fff; transition: transform var(--slow) var(--ease), opacity var(--fast) var(--ease), top var(--slow) var(--ease); }
.hamburger .l1{ top:12px; } .hamburger .l2{ top:20px; } .hamburger .l3{ top:28px; }
.hamburger.open .l1{ top:20px; transform:rotate(45deg); } .hamburger.open .l2{ opacity:0; }
.hamburger.open .l3{ top:20px; transform:rotate(-45deg); }

/* Mobile dropdown */
.mobile-menu{ background:#121213; color:#fff; border-top:1px solid rgba(255,255,255,.1); display:block; overflow:hidden; max-height:0; transition:max-height var(--slow) var(--ease); }
.mobile-menu.open{ max-height:82vh; }
.mobile-list{ list-style:none; margin:0; padding:var(--s-12) var(--s-16) var(--s-8); display:grid; gap:6px; }
.mobile-list a{ display:flex; align-items:center; gap:.6rem; padding:.75rem; }
.mobile-list a:hover{ background:rgba(255,255,255,.06); }
.mobile-cta{ background:var(--brand); color:#fff !important; justify-content:center; }
.center{ text-align:center; }
.mobile-socials{ display:flex; justify-content:center; gap:.9rem; padding:var(--s-12) 0; border-top:1px solid rgba(255,255,255,.12); }
.mobile-address{ color:#e4e4e4; display:grid; gap:.35rem; padding-bottom:var(--s-12); }

/* Info banner (contrasting; doubled tracks) */
.info-banner{ background:var(--info); color:var(--info-text); border-top:1px solid rgba(0,0,0,.05); }
.ticker{ position:relative; overflow:hidden; white-space:nowrap; }
.track{ display:inline-flex; gap:2.25rem; padding:.6rem 0; will-change:transform; animation:track 22s linear infinite; }
.track.clone{ position:absolute; left:100%; top:0; }
.track span::before{ content:"•"; color:var(--brand); margin:0 .5rem 0 0; }
@keyframes track{ from{ transform:translateX(0);} to{ transform:translateX(-100%);} }

/* HERO Carousel */
.hero{ padding-top:calc(72px + 40px); } /* account for fixed header + banner */
.carousel{ position:relative; overflow:hidden; }
.slides{ display:flex; transition:transform var(--slow) var(--ease); }
.slide{ position:relative; min-width:100%; aspect-ratio:16/9; background:#000; display:flex; align-items:center; justify-content:center; }
.slide img{ width:100%; height:100%; object-fit:cover; }
.overlay{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.6)); }
.caption{ position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; align-items:flex-start; padding:clamp(1rem,5vw,2.4rem); color:#fff; max-width:var(--container); margin:0 auto; }
.caption .actions{ display:flex; gap:.75rem; margin-top:.75rem; flex-wrap:wrap; }
.caption .accent{ color:var(--accent); }
.dots{ position:absolute; bottom:12px; left:0; right:0; display:flex; gap:.5rem; justify-content:center; }
.dot{ width:9px; height:9px; border:0; background:rgba(255,255,255,.5); }
.dot.is-active{ background:#fff; }

/* WHY */
#why{ background:#FFFFFF; }
.bullets{ list-style:none; padding:0; margin:var(--s-8) 0; display:grid; gap:.6rem; }
.bullets.big li{ font-size:1rem; }
.bullets i{ color:var(--brand); margin-right:.5rem; }
.rating-card{ background:#101010; color:#EDEDED; border:1px solid #2a2a2a; padding:var(--s-16); }
.rating-card .stars{ color:var(--accent); font-size:1.1rem; }
.rating-card .badges{ display:flex; gap:.5rem; flex-wrap:wrap; margin-top:.5rem; }
.rating-card .badges span{ border:1px solid #2a2a2a; padding:.35rem .5rem; }

/* KPIs */
.kpis{ background:#0E0E10; color:#fff; }
.grid-4{ display:grid; grid-template-columns:1fr; gap:var(--s-12); }
.kpi{ background:#141416; border:1px solid #222; padding:var(--s-16); box-shadow:var(--shadow); transition:transform var(--fast) var(--ease), box-shadow var(--fast) var(--ease); }
.kpi:hover{ transform:translateY(-2px); box-shadow:0 10px 28px rgba(0,0,0,.24); }
.kpi-num{ font-family:Poppins,Inter,sans-serif; font-size:clamp(1.8rem,7vw,2.8rem); color:var(--accent); font-weight:800; }

/* SERVICES (image-rich) */
.services .service-grid{ display:grid; grid-template-columns:1fr; gap:var(--s-12); }
.service{ border:1px solid #e3e3e3; background:#fff; box-shadow:var(--shadow); }
.service img{ width:100%; height:auto; object-fit:cover; aspect-ratio:16/9; }
.svc-copy{ padding:var(--s-12); display:grid; gap:.35rem; }
.svc-cta{ color:var(--brand); font-weight:700; }

/* PROCESS */
.process{ color:#fff; background-image:url('../assets/process-bg.png'); background-size:cover; background-position:center; }
.steps{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s-12); }
.step{ background:rgba(0,0,0,.52); border:1px solid rgba(255,255,255,.18); padding:var(--s-16); box-shadow:var(--shadow); transition:transform var(--fast) var(--ease); }
.step:hover{ transform:translateY(-2px); }
.step-num{ color:var(--accent); font-weight:800; margin-bottom:.25rem; }

/* VEHICLES (horizontal rows) */
.vehicles .row-head{ margin:.5rem 0 .35rem; font-weight:700; }
.h-scroll{ display:grid; grid-auto-flow:column; grid-auto-columns:80%; gap:var(--s-12); overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:.25rem; }
.h-scroll::-webkit-scrollbar{ height:8px; } /* subtle horizontal scrollbar if needed */
.h-scroll::-webkit-scrollbar-thumb{ background:#d0d0d0; }
.v-card{ scroll-snap-align:start; border:1px solid #e3e3e3; background:#fff; box-shadow:var(--shadow); padding:var(--s-12); }
.v-card img{ width:100%; height:auto; aspect-ratio:16/9; object-fit:cover; }
.v-card h4{ margin:.4rem 0 .2rem; }

/* PROJECTS */
.projects{ color:#fff; background-image:url('../assets/projects-bg.png'); background-size:cover; background-position:center; }
.cards{ display:grid; grid-template-columns:1fr; gap:var(--s-12); }
.cards.clamp{ overflow:hidden; } /* prevent overflow */
.card{ background:rgba(0,0,0,.5); border:1px solid rgba(255,255,255,.16); padding:var(--s-12); box-shadow:var(--shadow); }

/* COVERAGE */
.coverage .coverage-tags{ list-style:none; padding:0; display:grid; gap:.4rem; margin:.6rem 0 1rem; }
.coverage .coverage-tags i{ color:var(--brand); margin-right:.4rem; }
.map-embed{ width:100%; border:1px solid #ddd; background:#fff; }
.map-embed iframe{ width:100%; height:260px; border:0; display:block; }

/* TESTIMONIALS */
.testi-grid{ display:grid; grid-template-columns:1fr; gap:var(--s-12); }
.testi{ display:grid; grid-template-columns:auto 1fr; gap:.75rem; align-items:flex-start; border:1px solid #e3e3e3; background:#fff; padding:var(--s-12); box-shadow:var(--shadow); }
.testi img{ object-fit:cover; border:1px solid #ddd; }

/* PARTNERS / MARQUEE */
.partners .marquee{ overflow:hidden; border:1px solid #e3e3e3; background:#fff; }
.marquee-track{ display:inline-flex; gap:2.5rem; padding:.85rem 1rem; will-change:transform; animation: marquee 22s linear infinite; }
.marquee-track:hover{ animation-play-state:paused; }
@keyframes marquee{ from{transform:translateX(0);} to{transform:translateX(-50%);} }

/* FAQ */
.faq-list{ display:grid; gap:.6rem; }
.faq-q{ width:100%; text-align:left; display:grid; grid-template-columns:1fr auto; align-items:center; border:1px solid #e3e3e3; background:#fff; padding:.9rem 1rem; font-weight:600; cursor:pointer; }
.faq-q .sign{ color:var(--brand); font-weight:800; }
.faq-a{ border:1px solid #e3e3e3; border-top:0; background:#fff; padding:.8rem 1rem; }

/* CONTACT */
.contact{ color:#fff; background-image:url('../assets/contact-bg.png'); background-size:cover; background-position:center; }
.grid-2{ display:grid; grid-template-columns:1fr; gap:var(--s-16); }
.contact-card{ background:rgba(0,0,0,.55); border:1px solid rgba(255,255,255,.16); padding:var(--s-16); box-shadow:var(--shadow); }
.contact-card label{ display:grid; gap:.25rem; margin-bottom:.75rem; }
.contact-card input, .contact-card select, .contact-card textarea{ width:100%; border:1px solid #303030; background:#0E0E0F; color:#fff; padding:.75rem .8rem; }
.btn-spinner{ display:inline-block; width:16px; height:16px; margin-left:.5rem; border:2px solid rgba(255,255,255,.5); border-left-color:transparent; border-radius:50%; transform:translateY(2px); animation:spin 700ms linear infinite; opacity:0; pointer-events:none; }
@keyframes spin{ to{ transform:rotate(360deg);} }
.loading .btn-spinner{ opacity:1; }
.map-embed.tall iframe{ height:320px; }
.contact-lines{ list-style:none; padding:0; margin:.75rem 0 0; display:grid; gap:.35rem; }

/* Footer */
.site-footer{ color:#fff; background-image:url('../assets/footer-bg.png'); background-size:cover; background-position:center; border-top:1px solid rgba(255,255,255,.1); }
.footer-overlay{ background:rgba(0,0,0,.58); padding:var(--s-24) 0; }
.foot-grid{ display:grid; grid-template-columns:1fr; gap:var(--s-16); }
.foot-heading{ color:#fff; }
.foot-links{ list-style:none; padding:0; margin:0; display:grid; gap:.4rem; }
.foot-brand{ display:flex; align-items:center; gap:.6rem; margin-bottom:.5rem; }
.social{ display:flex; gap:.6rem; margin-top:.75rem; }
.newsletter-row{ display:grid; grid-template-columns:1fr auto; gap:.6rem; }
.newsletter-row input{ border:1px solid rgba(255,255,255,.3); background:rgba(255,255,255,.06); color:#fff; padding:.7rem .8rem; }
.foot-bottom{ margin-top:var(--s-16); padding-top:var(--s-12); border-top:1px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.legal{ display:flex; gap:.75rem; }

/* WhatsApp widget */
.wa-widget{ position:fixed; right:16px; bottom:16px; z-index:50; display:grid; gap:.5rem; }
.wa-btn{ width:56px; height:56px; background:#25D366; color:#fff; border:2px solid #128C7E; display:grid; place-items:center; box-shadow:var(--shadow); }
.wa-panel{ width:min(92vw,360px); max-height:68vh; overflow:hidden; display:flex; flex-direction:column; background:#F7F7F7; color:#0E0E0F; border:2px solid #E0E0E0; box-shadow:var(--shadow); position:fixed; right:16px; bottom:84px; opacity:0; pointer-events:none; transform:translateY(8px); transition:opacity var(--slow) var(--ease), transform var(--slow) var(--ease); }
.wa-panel.open{ opacity:1; transform:translateY(0); pointer-events:auto; }
.wa-header{ display:flex; align-items:center; justify-content:space-between; padding:.6rem .8rem; background:#fff; border-bottom:1px solid #EAEAEA; }
.wa-id{ display:flex; align-items:center; gap:.5rem; }
.wa-close{ background:transparent; border:0; font-size:1.1rem; cursor:pointer; }
.wa-chat{ padding:.75rem; display:grid; gap:.4rem; overflow:auto; }
.bubble{ display:inline-block; padding:.55rem .75rem; border:1px solid #E0E0E0; background:#fff; max-width:80%; }
.bubble.bot{ background:#fff; border-color:#E0E0E0; }
.bubble.me{ background:#DCF8C6; border-color:#B9E5AB; margin-left:auto; }
.wa-quick{ display:grid; grid-template-columns:1fr 1fr; gap:.4rem; padding:.6rem .75rem; background:#FAFAFA; border-top:1px solid #EAEAEA; }
.wa-quick button{ border:1px solid #E0E0E0; background:#fff; padding:.5rem; cursor:pointer; }
.wa-compose{ display:grid; grid-template-columns:1fr auto; gap:.4rem; padding:.6rem .75rem; background:#fff; border-top:1px solid #EAEAEA; }
.wa-compose textarea{ width:100%; border:1px solid #E0E0E0; background:#fff; padding:.6rem; }

/* Cookie bar */
.cookie-bar{ position:fixed; left:0; right:0; bottom:0; z-index:45; background:#111; color:#EDEDED; border-top:2px solid var(--brand); transition:opacity var(--slow) var(--ease), transform var(--slow) var(--ease); }
.cookie-inner{ max-width:var(--container); margin:0 auto; padding:.8rem var(--s-16); display:flex; align-items:center; justify-content:space-between; gap:.75rem; }
.cookie-actions{ display:flex; gap:.5rem; flex-wrap:wrap; }

/* Back to top */
.to-top{ position:fixed; right:16px; bottom:16px; width:44px; height:44px; border:2px solid #111; background:#fff; color:#111; display:grid; place-items:center; box-shadow:var(--shadow); z-index:40; }

/* Splash */
.splash{ position:fixed; inset:0; background:#0B0B0C; color:#fff; z-index:100; display:grid; place-items:center; }
.splash-inner{ text-align:center; }
.brand-reveal .amber{ color:#fff; } .brand-reveal .logx{ color:var(--brand); }

/* Reveal animations */
.reveal{ opacity:0; transform:translateY(16px); }
.revealed{ opacity:1; transform:none; transition:opacity var(--slow) var(--ease), transform var(--slow) var(--ease); }

/* Media / desktop layout */
@media (min-width: 720px){
  .primary-nav{ display:block; }
  .hamburger{ display:none; }
  .grid-2{ grid-template-columns:1.1fr 1fr; }
  .grid-4{ grid-template-columns:repeat(4,1fr); }
  .services .service-grid{ grid-template-columns:repeat(3,1fr); }
  .steps{ grid-template-columns:repeat(4,1fr); }
  .testi-grid{ grid-template-columns:repeat(3,1fr); }
  .foot-grid{ grid-template-columns:1.2fr 1fr 1fr 1fr; }
  .map-embed iframe{ height:320px; }
}
/* Prevent accidental overflow from animated elements */
.slides,.track,.marquee-track{ will-change:transform; }
