/* =========================================================================
   ISMAIL LIAQAT CARGO TRANSPORT — Design System
   "Industrial Dispatch" — asphalt navy, safety-amber livery, manifest mono
   ========================================================================= */

:root{
  /* ---- Palette ---- */
  --asphalt:        #0E1726;   /* primary deep background (blue-black) */
  --asphalt-2:      #131F33;   /* raised dark surface */
  --asphalt-3:      #1B2A44;   /* hover / borders on dark */
  --steel:          #3D5A80;   /* secondary cool accent */
  --steel-soft:     #6E8CB5;
  --amber:          #FFB200;   /* signature: fleet/safety amber */
  --amber-2:        #FFC247;
  --amber-deep:     #E09400;
  --concrete:       #F4F3EF;   /* light section background */
  --concrete-2:     #ECEAE3;
  --paper:          #FFFFFF;
  --ink:            #11192A;   /* text on light */
  --ink-soft:       #495468;
  --ink-faint:      #79839A;
  --line:           #E2E0D8;   /* hairlines on light */
  --line-dark:      #26344E;   /* hairlines on dark */
  --on-dark:        #EAF0F8;
  --on-dark-soft:   #A7B4C8;
  --success:        #2BB673;
  --danger:         #E14C4C;

  /* ---- Type ---- */
  --display: "Archivo", system-ui, -apple-system, sans-serif;
  --body:    "Inter", system-ui, -apple-system, sans-serif;
  --mono:    "Space Mono", ui-monospace, "SFMono-Regular", monospace;

  /* ---- Spacing / radius / shadow ---- */
  --radius:    14px;
  --radius-sm: 9px;
  --radius-lg: 22px;
  --shadow:     0 18px 50px -22px rgba(8,14,28,.45);
  --shadow-amber: 0 14px 38px -14px rgba(255,178,0,.55);
  --shadow-card:  0 12px 34px -20px rgba(8,14,28,.40);
  --container: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.62;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,canvas{ max-width:100%; display:block; }
svg{ width:1.1em; height:1.1em; flex:none; }            /* default icon size; specific rules override */
.eyebrow svg{ width:15px; height:15px; }
.verify-head svg{ width:48px; height:48px; }
.emblem{ width:108px; height:108px; border-radius:24px; display:grid; place-items:center;
  background:linear-gradient(180deg,rgba(255,178,0,.18),rgba(255,178,0,.05)); border:1px solid rgba(255,178,0,.3); }
.emblem svg{ width:56px; height:56px; color:var(--amber-2); }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:800; line-height:1.06; letter-spacing:-.02em; margin:0; }
p{ margin:0 0 1rem; }
:focus-visible{ outline:3px solid var(--amber); outline-offset:3px; border-radius:4px; }

/* ---------- layout helpers ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:22px; }
.section{ padding:92px 0; position:relative; }
.section.tight{ padding:64px 0; }
.section.dark{ background:var(--asphalt); color:var(--on-dark); }
.section.dark h1,.section.dark h2,.section.dark h3{ color:#fff; }
.section.concrete{ background:var(--concrete); }
.grid{ display:grid; gap:26px; }
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }
.measure{ max-width:62ch; }
.measure-sm{ max-width:48ch; }

/* ---------- eyebrow / manifest label ---------- */
.eyebrow{
  font-family:var(--mono); font-size:.72rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--amber-deep); display:inline-flex; align-items:center; gap:.55rem;
  margin-bottom:1rem;
}
.section.dark .eyebrow{ color:var(--amber-2); }
.eyebrow::before{ content:""; width:26px; height:2px; background:currentColor; display:inline-block; }
.eyebrow.no-line::before{ display:none; }

/* ---------- headings scale ---------- */
.display-xl{ font-size:clamp(2.5rem,6vw,4.4rem); line-height:1.02; }
.display-lg{ font-size:clamp(2.1rem,4.6vw,3.3rem); }
.display-md{ font-size:clamp(1.7rem,3.4vw,2.4rem); }
.lead{ font-size:clamp(1.05rem,1.6vw,1.22rem); color:var(--ink-soft); }
.section.dark .lead{ color:var(--on-dark-soft); }
.amber-text{ color:var(--amber-deep); }
.section.dark .amber-text{ color:var(--amber-2); }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--amber); --fg:#1a1300;
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  padding:15px 26px; border-radius:var(--radius-sm); border:2px solid transparent;
  background:var(--bg); color:var(--fg); font-weight:700; font-size:1rem;
  letter-spacing:.01em; transition:transform .18s var(--ease), box-shadow .25s var(--ease), background .2s;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:19px; height:19px; }
.btn:hover{ transform:translateY(-3px); box-shadow:var(--shadow-amber); }
.btn:active{ transform:translateY(-1px); }
.btn-amber{ --bg:linear-gradient(180deg,var(--amber-2),var(--amber)); --fg:#1a1300; }
.btn-ghost{ --bg:transparent; --fg:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ box-shadow:none; border-color:var(--ink); background:var(--ink); color:#fff; }
.section.dark .btn-ghost{ --fg:#fff; border-color:var(--line-dark); }
.section.dark .btn-ghost:hover{ background:#fff; color:var(--asphalt); border-color:#fff; }
.btn-dark{ --bg:var(--asphalt); --fg:#fff; }
.btn-dark:hover{ box-shadow:var(--shadow); }
.btn-wa{ --bg:#25D366; --fg:#063b1c; }
.btn-lg{ padding:18px 34px; font-size:1.06rem; }
.btn-block{ width:100%; }

/* ---------- tonnage chip / route code (manifest motif) ---------- */
.chip{
  font-family:var(--mono); font-weight:700; font-size:.78rem; letter-spacing:.04em;
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.32rem .66rem; border-radius:6px;
  background:rgba(255,178,0,.14); color:var(--amber-deep);
  border:1px solid rgba(255,178,0,.34);
}
.section.dark .chip{ color:var(--amber-2); background:rgba(255,178,0,.12); border-color:rgba(255,178,0,.3); }
.chip.steel{ background:rgba(61,90,128,.12); color:var(--steel); border-color:rgba(61,90,128,.32); }
.section.dark .chip.steel{ color:var(--steel-soft); border-color:rgba(110,140,181,.35); }
.route-code{
  font-family:var(--mono); font-weight:700; letter-spacing:.06em;
  display:inline-flex; align-items:center; gap:.5rem; color:var(--ink);
}
.section.dark .route-code{ color:#fff; }
.route-code .arrow{ color:var(--amber-deep); }
.section.dark .route-code .arrow{ color:var(--amber-2); }

/* =========================================================================
   HEADER / NAV
   ========================================================================= */
.site-header{
  position:sticky; top:0; z-index:90;
  background:rgba(14,23,38,.0);
  transition:background .3s var(--ease), box-shadow .3s var(--ease), border-color .3s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(11,18,31,.92);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom-color:var(--line-dark);
  box-shadow:0 10px 30px -20px rgba(0,0,0,.7);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; gap:18px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{ width:42px; height:42px; flex:none; }
.brand-text{ line-height:1.05; }
.brand-name{ font-family:var(--display); font-weight:900; font-size:1.02rem; color:#fff; letter-spacing:-.01em; }
.brand-sub{ font-family:var(--mono); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--amber-2); }
.nav-links{ display:flex; align-items:center; gap:4px; margin-left:auto; }
.nav-links a{
  color:var(--on-dark-soft); font-weight:600; font-size:.95rem;
  padding:9px 14px; border-radius:8px; transition:color .2s, background .2s; position:relative;
}
.nav-links a:hover{ color:#fff; background:rgba(255,255,255,.06); }
.nav-links a.active{ color:#fff; }
.nav-links a.active::after{
  content:""; position:absolute; left:14px; right:14px; bottom:3px; height:2px; background:var(--amber); border-radius:2px;
}
.nav-cta{ display:flex; align-items:center; gap:10px; margin-left:8px; }
.nav-phone{
  display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-weight:700;
  color:#fff; font-size:.92rem; padding:9px 14px; border:1px solid var(--line-dark); border-radius:9px;
  transition:border-color .2s, background .2s;
}
.nav-phone:hover{ border-color:var(--amber); background:rgba(255,178,0,.08); }
.nav-phone svg{ width:16px; height:16px; flex:none; color:var(--amber-2); }
.nav-toggle{ display:none; background:transparent; border:1px solid var(--line-dark); border-radius:9px; width:46px; height:42px; align-items:center; justify-content:center; }
.nav-toggle span{ width:20px; height:2px; background:#fff; position:relative; transition:.25s; }
.nav-toggle span::before,.nav-toggle span::after{ content:""; position:absolute; left:0; width:20px; height:2px; background:#fff; transition:.25s; }
.nav-toggle span::before{ top:-6px; } .nav-toggle span::after{ top:6px; }
.nav-toggle.open span{ background:transparent; }
.nav-toggle.open span::before{ top:0; transform:rotate(45deg); }
.nav-toggle.open span::after{ top:0; transform:rotate(-45deg); }

/* mobile drawer */
.mobile-menu{
  position:fixed; inset:0 0 0 auto; width:min(86vw,360px); background:var(--asphalt-2);
  border-left:1px solid var(--line-dark); transform:translateX(100%); transition:transform .32s var(--ease);
  z-index:120; padding:26px 22px; display:flex; flex-direction:column; gap:6px; overflow-y:auto;
}
.mobile-menu.open{ transform:translateX(0); }
.mobile-menu a{ color:var(--on-dark); font-weight:600; padding:14px 12px; border-radius:10px; border:1px solid transparent; }
.mobile-menu a:hover,.mobile-menu a.active{ background:var(--asphalt-3); border-color:var(--line-dark); }
.mobile-menu .mm-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.mm-close{ background:transparent; border:1px solid var(--line-dark); border-radius:9px; width:42px; height:42px; display:grid; place-items:center; color:#fff; transition:.2s; }
.mm-close:hover{ border-color:var(--amber); background:rgba(255,178,0,.08); }
.mm-close svg{ width:20px; height:20px; }
.mobile-menu .mm-cta{ margin-top:16px; display:grid; gap:10px; }
.overlay{ position:fixed; inset:0; background:rgba(6,10,20,.6); opacity:0; pointer-events:none; transition:opacity .3s; z-index:110; }
.overlay.show{ opacity:1; pointer-events:auto; }

/* =========================================================================
   HERO
   ========================================================================= */
.hero{ background:radial-gradient(120% 120% at 80% -10%, #1c2c47 0%, var(--asphalt) 55%); color:var(--on-dark); position:relative; overflow:hidden; margin-top:-76px; }
.hero::after{ /* faint route grid */
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);
  background-size:64px 64px; -webkit-mask-image:radial-gradient(120% 80% at 70% 0%,#000 10%,transparent 70%); mask-image:radial-gradient(120% 80% at 70% 0%,#000 10%,transparent 70%);
}
.hero-inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:36px; align-items:center; padding:140px 0 78px; }
.hero h1{ color:#fff; margin-bottom:18px; }
.hero h1 em{ font-style:normal; color:var(--amber); }
.hero-sub{ font-size:clamp(1.05rem,1.7vw,1.24rem); color:var(--on-dark-soft); max-width:54ch; margin-bottom:26px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:30px; }
.hero-trust{ display:flex; flex-wrap:wrap; gap:10px 22px; align-items:center; }
.hero-trust .t{ display:flex; align-items:center; gap:9px; font-size:.86rem; color:var(--on-dark-soft); }
.hero-trust .t svg{ width:18px; height:18px; color:var(--amber-2); flex:none; }
.hero-stage{ position:relative; }
.truck-stage{
  position:relative; aspect-ratio:1/.84; width:100%;
  background:radial-gradient(120% 110% at 50% 30%, #1b2c49 0%, #0d1626 70%);
  border:1px solid var(--line-dark); border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow); display:grid; place-items:center;
}
.stage-glow{ position:absolute; width:80%; height:62%; top:14%; left:10%; z-index:1;
  background:radial-gradient(circle at 50% 45%, rgba(255,178,0,.26), rgba(255,178,0,.05) 55%, transparent 72%); filter:blur(8px); }
.truck-img{
  position:absolute; left:50%; top:47%; width:88%; z-index:3;
  transform:translate(-50%,-50%) scale(.96); opacity:0;
  transition:opacity .5s var(--ease), transform .5s var(--ease);
  filter:drop-shadow(0 30px 26px rgba(0,0,0,.55));
}
.truck-img.is-active{ opacity:1; transform:translate(-50%,-50%); animation:truckbob 5s ease-in-out infinite; }
@keyframes truckbob{ 0%,100%{ transform:translate(-50%,-50%); } 50%{ transform:translate(-50%,calc(-50% - 9px)); } }
.truck-ground{ position:absolute; bottom:12%; left:50%; transform:translateX(-50%); width:60%; height:22px; z-index:2;
  background:radial-gradient(ellipse at center, rgba(0,0,0,.6), transparent 70%); filter:blur(7px); }
.float-chip{
  position:absolute; z-index:5; font-family:var(--mono); font-weight:700; font-size:.72rem; letter-spacing:.03em;
  background:rgba(8,14,26,.82); border:1px solid var(--line-dark); color:var(--on-dark); padding:8px 12px; border-radius:10px;
  display:flex; align-items:center; gap:7px; box-shadow:0 10px 26px -12px rgba(0,0,0,.7);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
}
.float-chip b{ color:var(--amber-2); }
.float-chip svg{ width:14px; height:14px; color:var(--amber-2); }
.float-chip.fc-1{ top:13%; right:5%; animation:floaty 5s ease-in-out infinite; }
.float-chip.fc-2{ top:44%; left:2%; animation:floaty 6s ease-in-out infinite .6s; }
.float-chip.fc-3{ bottom:18%; right:7%; animation:floaty 5.4s ease-in-out infinite 1.1s; }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-11px); } }
.stage-tag{
  position:absolute; left:16px; top:16px; z-index:3; font-family:var(--mono); font-size:.66rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--on-dark-soft); background:rgba(8,14,26,.6); padding:6px 10px; border-radius:7px; border:1px solid var(--line-dark);
}
.stage-hint{ position:absolute; right:16px; bottom:14px; z-index:3; font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; color:var(--on-dark-soft); display:flex; align-items:center; gap:7px; }
.stage-hint svg{ width:15px; height:15px; }
.stage-switch{ position:absolute; left:16px; bottom:14px; z-index:4; display:flex; gap:6px; }
.stage-switch button{
  font-family:var(--mono); font-weight:700; font-size:.72rem; letter-spacing:.04em;
  padding:7px 12px; border-radius:7px; background:rgba(8,14,26,.7); color:var(--on-dark-soft);
  border:1px solid var(--line-dark); transition:.2s;
}
.stage-switch button.active{ background:var(--amber); color:#1a1300; border-color:var(--amber); }

/* hero ticker */
.ticker{ background:var(--asphalt-2); border-top:1px solid var(--line-dark); border-bottom:1px solid var(--line-dark); overflow:hidden; position:relative; }
.ticker-track{ display:flex; gap:42px; white-space:nowrap; padding:13px 0; animation:ticker 32s linear infinite; width:max-content; }
.ticker-item{ font-family:var(--mono); font-size:.82rem; letter-spacing:.06em; color:var(--on-dark-soft); display:inline-flex; align-items:center; gap:11px; }
.ticker-item b{ color:var(--amber-2); font-weight:700; }
.ticker-item .dot{ width:5px; height:5px; border-radius:50%; background:var(--steel); }
@keyframes ticker{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* =========================================================================
   CARDS
   ========================================================================= */
.tilt{ transform-style:preserve-3d; transition:transform .3s var(--ease); will-change:transform; }
.card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:28px; transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s;
  position:relative; height:100%;
}
.card:hover{ box-shadow:var(--shadow-card); border-color:var(--concrete-2); }
.section.dark .card{ background:var(--asphalt-2); border-color:var(--line-dark); }
.section.dark .card:hover{ border-color:var(--steel); }
.card .ic{
  width:54px; height:54px; border-radius:12px; display:grid; place-items:center; margin-bottom:18px;
  background:linear-gradient(180deg,rgba(255,178,0,.16),rgba(255,178,0,.06)); border:1px solid rgba(255,178,0,.28);
}
.card .ic svg{ width:27px; height:27px; color:var(--amber-deep); }
.card h3{ font-size:1.22rem; margin-bottom:8px; }
.card p{ color:var(--ink-soft); font-size:.97rem; margin-bottom:14px; }
.section.dark .card p{ color:var(--on-dark-soft); }
.card .more{ font-family:var(--mono); font-size:.78rem; font-weight:700; letter-spacing:.06em; color:var(--amber-deep); display:inline-flex; align-items:center; gap:7px; }
.section.dark .card .more{ color:var(--amber-2); }
.card .more svg{ width:14px; height:14px; transition:transform .2s; }
.card:hover .more svg{ transform:translateX(4px); }
.card .card-no{ position:absolute; top:20px; right:22px; font-family:var(--mono); font-size:.72rem; color:var(--ink-faint); letter-spacing:.08em; }
.section.dark .card .card-no{ color:var(--steel-soft); }

.cards-3{ grid-template-columns:repeat(3,1fr); }
.cards-2{ grid-template-columns:repeat(2,1fr); }
.cards-4{ grid-template-columns:repeat(4,1fr); }

/* feature list with check */
.checklist{ display:grid; gap:12px; }
.checklist li{ display:flex; gap:12px; align-items:flex-start; font-size:.98rem; color:var(--ink-soft); }
.section.dark .checklist li{ color:var(--on-dark-soft); }
.checklist li svg{ width:22px; height:22px; flex:none; color:var(--success); margin-top:1px; }

/* =========================================================================
   TRUST / CREDENTIALS STRIP
   ========================================================================= */
.cred-grid{ grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); border-radius:var(--radius); overflow:hidden; }
.cred{ background:var(--asphalt-2); padding:24px 22px; }
.cred .lbl{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--steel-soft); margin-bottom:8px; }
.cred .val{ font-family:var(--display); font-weight:800; font-size:1.32rem; color:#fff; }
.cred .val small{ font-family:var(--mono); font-weight:700; font-size:.74rem; color:var(--amber-2); display:block; margin-top:4px; letter-spacing:.04em; }

/* verification card (license) */
.verify{
  background:linear-gradient(135deg,var(--asphalt-2),var(--asphalt-3)); border:1px solid var(--line-dark);
  border-radius:var(--radius-lg); padding:32px; position:relative; overflow:hidden;
}
.verify::before{ content:""; position:absolute; right:-40px; top:-40px; width:200px; height:200px; background:radial-gradient(circle,rgba(255,178,0,.16),transparent 70%); }
.verify-head{ display:flex; align-items:center; gap:14px; margin-bottom:22px; }
.verify-seal{ width:54px; height:54px; flex:none; }
.verify-rows{ display:grid; gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); border-radius:12px; overflow:hidden; }
.verify-row{ display:flex; justify-content:space-between; gap:14px; padding:13px 18px; background:rgba(8,14,26,.45); }
.verify-row .k{ font-size:.86rem; color:var(--on-dark-soft); }
.verify-row .v{ font-family:var(--mono); font-weight:700; font-size:.9rem; color:#fff; letter-spacing:.02em; }
.verify-badge{ display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:.74rem; font-weight:700; letter-spacing:.06em; color:var(--success); margin-top:16px; }
.verify-badge svg{ width:18px; height:18px; }

/* =========================================================================
   STATS
   ========================================================================= */
.stats{ grid-template-columns:repeat(4,1fr); gap:0; }
.stat{ text-align:center; padding:14px 18px; position:relative; }
.stat + .stat::before{ content:""; position:absolute; left:0; top:18%; height:64%; width:1px; background:var(--line-dark); }
.section.concrete .stat + .stat::before, .stat.light + .stat.light::before{ background:var(--line); }
.stat .num{ font-family:var(--display); font-weight:900; font-size:clamp(2.2rem,4.4vw,3.1rem); color:var(--amber); line-height:1; letter-spacing:-.03em; }
.stat .num .suffix{ color:#fff; }
.section.concrete .stat .num .suffix, .stat.light .num .suffix{ color:var(--ink); }
.stat .lbl{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--on-dark-soft); margin-top:10px; }
.section.concrete .stat .lbl, .stat.light .lbl{ color:var(--ink-soft); }

/* =========================================================================
   PROCESS / STEPS
   ========================================================================= */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; }
.step{ position:relative; }
.step .no{ font-family:var(--mono); font-weight:700; font-size:.8rem; letter-spacing:.1em; color:var(--amber-deep); margin-bottom:14px; display:inline-flex; align-items:center; gap:8px; }
.section.dark .step .no{ color:var(--amber-2); }
.step .no .ring{ width:34px; height:34px; border-radius:50%; border:2px solid currentColor; display:grid; place-items:center; font-size:.95rem; }
.step h3{ font-size:1.12rem; margin-bottom:8px; }
.step p{ font-size:.94rem; color:var(--ink-soft); }
.section.dark .step p{ color:var(--on-dark-soft); }
.steps-line{ position:absolute; top:17px; left:8%; right:8%; height:2px; background:repeating-linear-gradient(90deg,var(--amber-deep) 0 14px,transparent 14px 26px); opacity:.5; z-index:0; }
.section.dark .steps-line{ background:repeating-linear-gradient(90deg,var(--amber-2) 0 14px,transparent 14px 26px); }

/* =========================================================================
   FLEET
   ========================================================================= */
.fleet-card{ background:var(--asphalt-2); border:1px solid var(--line-dark); border-radius:var(--radius-lg); overflow:hidden; display:grid; grid-template-rows:auto auto; }
.fleet-stage{ position:relative; aspect-ratio:16/10; background:radial-gradient(120% 110% at 50% 35%, #1a2b48, #0e1828 72%); border-bottom:1px solid var(--line-dark); display:grid; place-items:center; overflow:hidden; }
.fleet-stage::before{ content:""; position:absolute; inset:12% 10% 18%; z-index:1; background:radial-gradient(circle at 50% 50%, rgba(255,178,0,.18), transparent 64%); filter:blur(6px); }
.fleet-truck{ position:relative; z-index:2; width:86%; filter:drop-shadow(0 22px 22px rgba(0,0,0,.55)); transition:transform .4s var(--ease); }
.fleet-card:hover .fleet-truck{ transform:translateY(-6px) scale(1.02); }
.gallery-item{ margin:0; }
.gallery-stage{ position:relative; aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden; display:grid; place-items:center;
  background:radial-gradient(120% 110% at 50% 35%, #1a2b48, #0e1828 72%); border:1px solid var(--line-dark); }
.gallery-stage::before{ content:""; position:absolute; inset:14% 12% 20%; background:radial-gradient(circle at 50% 50%, rgba(255,178,0,.16), transparent 64%); filter:blur(6px); }
.gallery-stage .tonnage{ position:absolute; top:14px; left:14px; z-index:3; }
.gallery-stage img{ position:relative; z-index:2; width:84%; filter:drop-shadow(0 18px 20px rgba(0,0,0,.5)); transition:transform .4s var(--ease); }
.gallery-item:hover .gallery-stage img{ transform:scale(1.05); }
.gallery-item figcaption{ font-family:var(--mono); font-size:.8rem; color:var(--on-dark-soft); letter-spacing:.02em; margin-top:14px; text-align:center; }
.fleet-stage .tonnage{ position:absolute; top:16px; left:16px; z-index:3; }
.fleet-body{ padding:26px; }
.fleet-body h3{ color:#fff; font-size:1.5rem; }
.fleet-body .tagline{ font-family:var(--mono); font-size:.78rem; color:var(--amber-2); letter-spacing:.06em; margin:4px 0 16px; }
.spec-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); border-radius:12px; overflow:hidden; margin:18px 0; }
.spec{ background:rgba(8,14,26,.4); padding:14px 16px; }
.spec .k{ font-family:var(--mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--steel-soft); margin-bottom:5px; }
.spec .v{ font-family:var(--display); font-weight:800; color:#fff; font-size:1.06rem; }
.spec .v small{ font-size:.78rem; color:var(--on-dark-soft); font-family:var(--body); font-weight:500; }

/* =========================================================================
   COVERAGE / EMIRATES
   ========================================================================= */
.emirates{ grid-template-columns:repeat(4,1fr); gap:16px; }
.emirate{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:22px; transition:.25s; }
.section.dark .emirate{ background:var(--asphalt-2); border-color:var(--line-dark); }
.emirate:hover{ border-color:var(--amber); transform:translateY(-3px); }
.emirate .ar{ font-family:var(--mono); font-size:.72rem; color:var(--amber-deep); letter-spacing:.04em; margin-bottom:6px; }
.section.dark .emirate .ar{ color:var(--amber-2); }
.emirate h3{ font-size:1.18rem; margin-bottom:6px; }
.emirate p{ font-size:.88rem; color:var(--ink-soft); margin:0; }
.section.dark .emirate p{ color:var(--on-dark-soft); }
.zones{ display:flex; flex-wrap:wrap; gap:8px; }
.zone-tag{ font-family:var(--mono); font-size:.76rem; padding:.4rem .8rem; border-radius:7px; background:var(--concrete); border:1px solid var(--line); color:var(--ink-soft); }
.section.dark .zone-tag{ background:var(--asphalt-2); border-color:var(--line-dark); color:var(--on-dark-soft); }
.routes{ display:grid; gap:10px; }
.route-row{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:15px 20px; background:var(--paper); border:1px solid var(--line); border-radius:11px; transition:.2s; }
.section.dark .route-row{ background:var(--asphalt-2); border-color:var(--line-dark); }
.route-row:hover{ border-color:var(--amber); }
.route-row .meta{ font-family:var(--mono); font-size:.78rem; color:var(--ink-faint); }
.section.dark .route-row .meta{ color:var(--steel-soft); }

/* =========================================================================
   TESTIMONIALS
   ========================================================================= */
.quotes{ grid-template-columns:repeat(3,1fr); gap:24px; }
.quote-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:28px; position:relative; }
.section.dark .quote-card{ background:var(--asphalt-2); border-color:var(--line-dark); }
.quote-card .stars{ display:flex; gap:3px; margin-bottom:14px; color:var(--amber); }
.quote-card .stars svg{ width:18px; height:18px; }
.quote-card blockquote{ margin:0 0 18px; font-size:1.02rem; color:var(--ink); line-height:1.6; }
.section.dark .quote-card blockquote{ color:var(--on-dark); }
.quote-card .who{ display:flex; align-items:center; gap:12px; }
.quote-card .av{ width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--steel),var(--asphalt-3)); display:grid; place-items:center; font-family:var(--display); font-weight:800; color:#fff; font-size:1rem; }
.quote-card .who .nm{ font-weight:700; font-size:.92rem; }
.quote-card .who .rl{ font-family:var(--mono); font-size:.72rem; color:var(--ink-faint); }
.section.dark .quote-card .who .rl{ color:var(--steel-soft); }

/* =========================================================================
   FAQ ACCORDION
   ========================================================================= */
.faq{ max-width:860px; margin-inline:auto; display:grid; gap:12px; }
.faq-item{ border:1px solid var(--line); border-radius:12px; overflow:hidden; background:var(--paper); }
.section.dark .faq-item{ background:var(--asphalt-2); border-color:var(--line-dark); }
.faq-q{ width:100%; text-align:left; background:transparent; border:none; padding:20px 24px; display:flex; justify-content:space-between; align-items:center; gap:16px; font-family:var(--display); font-weight:700; font-size:1.06rem; color:var(--ink); }
.section.dark .faq-q{ color:#fff; }
.faq-q .pm{ flex:none; width:28px; height:28px; border-radius:50%; border:1.5px solid var(--line); display:grid; place-items:center; transition:.25s; position:relative; }
.section.dark .faq-q .pm{ border-color:var(--line-dark); }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; background:var(--amber-deep); }
.section.dark .faq-q .pm::before,.section.dark .faq-q .pm::after{ background:var(--amber-2); }
.faq-q .pm::before{ width:12px; height:2px; } .faq-q .pm::after{ width:2px; height:12px; transition:.25s; }
.faq-item.open .faq-q .pm{ border-color:var(--amber); }
.faq-item.open .faq-q .pm::after{ transform:rotate(90deg); opacity:0; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s var(--ease); }
.faq-a-inner{ padding:0 24px 22px; color:var(--ink-soft); font-size:.98rem; }
.section.dark .faq-a-inner{ color:var(--on-dark-soft); }

/* =========================================================================
   QUOTE / ESTIMATE TOOL
   ========================================================================= */
.estimator{ background:var(--asphalt-2); border:1px solid var(--line-dark); border-radius:var(--radius-lg); padding:30px; }
.field{ margin-bottom:20px; }
.field > label{ display:block; font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--steel-soft); margin-bottom:11px; }
.opt-row{ display:grid; gap:10px; }
.opt-row.cols-2{ grid-template-columns:repeat(2,1fr); }
.opt-row.cols-3{ grid-template-columns:repeat(3,1fr); }
.opt{ position:relative; }
.opt input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.opt .face{
  border:1.5px solid var(--line-dark); border-radius:11px; padding:16px; background:rgba(8,14,26,.4);
  transition:.2s; cursor:pointer; height:100%;
}
.opt .face .ttl{ display:block; font-family:var(--display); font-weight:800; color:#fff; font-size:1.04rem; }
.opt .face .sub{ display:block; font-size:.82rem; color:var(--on-dark-soft); margin-top:3px; }
.opt .face .tn{ display:block; font-family:var(--mono); font-size:.72rem; color:var(--amber-2); margin-top:8px; letter-spacing:.04em; }
.opt input:checked + .face{ border-color:var(--amber); background:rgba(255,178,0,.08); box-shadow:0 0 0 3px rgba(255,178,0,.12); }
.opt input:focus-visible + .face{ outline:3px solid var(--amber); outline-offset:2px; }
.input, select.input, textarea.input{
  width:100%; background:rgba(8,14,26,.5); border:1.5px solid var(--line-dark); border-radius:10px;
  padding:14px 16px; color:#fff; font-family:var(--body); font-size:1rem; transition:.2s;
}
.input::placeholder{ color:var(--steel-soft); }
.input:focus{ outline:none; border-color:var(--amber); background:rgba(8,14,26,.7); }
select.input{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23FFC247' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; padding-right:42px; }
.estimate-out{
  margin-top:8px; background:linear-gradient(135deg,rgba(255,178,0,.1),rgba(255,178,0,.03));
  border:1px solid rgba(255,178,0,.3); border-radius:14px; padding:22px 24px; text-align:center;
}
.estimate-out .lbl{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--amber-2); }
.estimate-out .amt{ font-family:var(--display); font-weight:900; font-size:2.3rem; color:#fff; margin:6px 0 2px; }
.estimate-out .amt .cur{ font-size:1.1rem; color:var(--amber-2); vertical-align:super; }
.estimate-out .note{ font-size:.8rem; color:var(--on-dark-soft); }

/* =========================================================================
   FORMS (contact / quote)
   ========================================================================= */
.form-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.form-grid .full{ grid-column:1/-1; }
.form-label{ display:block; font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--steel-soft); margin-bottom:9px; }
.form-note{ font-size:.82rem; color:var(--on-dark-soft); margin-top:14px; }

/* =========================================================================
   CTA BAND
   ========================================================================= */
.cta-band{ background:linear-gradient(120deg,var(--asphalt) 0%,#16233b 60%,#1d2f4d 100%); position:relative; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; inset:0; background-image:repeating-linear-gradient(90deg,rgba(255,178,0,.06) 0 2px,transparent 2px 60px); opacity:.6; }
.cta-inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.4fr auto; gap:30px; align-items:center; }
.cta-inner h2{ color:#fff; font-size:clamp(1.8rem,3.6vw,2.6rem); }
.cta-inner p{ color:var(--on-dark-soft); margin:10px 0 0; }
.cta-actions{ display:flex; flex-direction:column; gap:12px; min-width:240px; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{ background:#0A111E; color:var(--on-dark-soft); border-top:1px solid var(--line-dark); padding-top:64px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:36px; padding-bottom:44px; }
.footer-brand .brand-name{ font-size:1.1rem; }
.footer-about{ font-size:.9rem; margin:16px 0; max-width:34ch; }
.footer h4{ font-family:var(--mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--amber-2); font-weight:700; margin-bottom:16px; }
.footer-links{ display:grid; gap:10px; }
.footer-links a{ font-size:.92rem; color:var(--on-dark-soft); transition:color .2s; }
.footer-links a:hover{ color:#fff; }
.footer-contact .row{ display:flex; gap:11px; align-items:flex-start; margin-bottom:14px; font-size:.9rem; }
.footer-contact .row svg{ width:18px; height:18px; color:var(--amber-2); flex:none; margin-top:2px; }
.footer-contact .row a{ color:#fff; font-family:var(--mono); font-weight:700; font-size:.9rem; }
.footer-bottom{ border-top:1px solid var(--line-dark); padding:22px 0; display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; font-size:.82rem; }
.footer-bottom .lic{ font-family:var(--mono); letter-spacing:.04em; }
.footer-social{ display:flex; gap:10px; }
.footer-social a{ width:38px; height:38px; border-radius:9px; border:1px solid var(--line-dark); display:grid; place-items:center; transition:.2s; }
.footer-social a:hover{ border-color:var(--amber); background:rgba(255,178,0,.08); }
.footer-social svg{ width:18px; height:18px; }

/* =========================================================================
   FLOATING WHATSAPP + MOBILE CALL BAR
   ========================================================================= */
.wa-float{
  position:fixed; right:20px; bottom:26px; z-index:88; width:64px; height:64px; border-radius:50%;
  background:#25D366; display:grid; place-items:center; box-shadow:0 16px 34px -8px rgba(37,211,102,.7);
  transition:transform .25s var(--ease); animation:wa-bob 2.6s ease-in-out infinite;
}
.wa-float:hover{ transform:scale(1.1); animation-play-state:paused; }
.wa-float svg{ width:34px; height:34px; }
.wa-float .pulse{ position:absolute; inset:0; border-radius:50%; border:2px solid #25D366; animation:pulse 2.2s ease-out infinite; }
.wa-float .pulse.p2{ animation-delay:1.1s; }
@keyframes pulse{ 0%{ transform:scale(1); opacity:.7; } 100%{ transform:scale(1.85); opacity:0; } }
@keyframes wa-bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-11px); } }

.mobile-bar{
  position:fixed; left:0; right:0; bottom:0; z-index:85; display:none; grid-template-columns:1fr 1fr;
  background:var(--asphalt); border-top:1px solid var(--line-dark); padding:10px 12px calc(10px + env(safe-area-inset-bottom)); gap:10px;
}
.mobile-bar a{ display:flex; align-items:center; justify-content:center; gap:9px; padding:14px; border-radius:11px; font-weight:700; font-size:.96rem; }
.mobile-bar .call{ background:var(--amber); color:#1a1300; }
.mobile-bar .wa{ background:#25D366; color:#063b1c; }
.mobile-bar a svg{ width:19px; height:19px; }

/* =========================================================================
   PAGE HERO (interior pages)
   ========================================================================= */
.page-hero{ background:radial-gradient(120% 130% at 85% -20%,#1c2c47,var(--asphalt) 60%); color:var(--on-dark); padding:130px 0 60px; margin-top:-76px; position:relative; overflow:hidden; }
.page-hero::after{ content:""; position:absolute; inset:0; opacity:.4; background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px); background-size:60px 60px; -webkit-mask-image:radial-gradient(100% 80% at 80% 0%,#000,transparent 70%); mask-image:radial-gradient(100% 80% at 80% 0%,#000,transparent 70%); }
.page-hero .inner{ position:relative; z-index:2; max-width:760px; }
.breadcrumb{ font-family:var(--mono); font-size:.76rem; letter-spacing:.04em; color:var(--on-dark-soft); margin-bottom:18px; display:flex; gap:8px; flex-wrap:wrap; }
.breadcrumb a:hover{ color:#fff; } .breadcrumb .sep{ color:var(--steel); }
.page-hero h1{ color:#fff; font-size:clamp(2.1rem,5vw,3.4rem); margin-bottom:16px; }
.page-hero p{ color:var(--on-dark-soft); font-size:clamp(1.02rem,1.7vw,1.18rem); max-width:60ch; }

/* split content */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.split.reverse > :first-child{ order:2; }
.section-head{ max-width:680px; margin-bottom:48px; }
.section-head.center{ margin-inline:auto; }

/* media block placeholder w/ pattern */
.media-card{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line-dark); background:linear-gradient(160deg,#16243d,#0e1828); aspect-ratio:4/3; position:relative; }
.media-card canvas{ width:100% !important; height:100% !important; }

/* pill list */
.pill-list{ display:flex; flex-wrap:wrap; gap:10px; }
.pill{ padding:.5rem .95rem; border-radius:999px; border:1px solid var(--line); font-size:.88rem; color:var(--ink-soft); background:var(--paper); }
.section.dark .pill{ border-color:var(--line-dark); background:var(--asphalt-2); color:var(--on-dark-soft); }

/* compare table */
.compare{ width:100%; border-collapse:collapse; background:var(--asphalt-2); border:1px solid var(--line-dark); border-radius:var(--radius); overflow:hidden; }
.compare th,.compare td{ padding:16px 20px; text-align:left; border-bottom:1px solid var(--line-dark); }
.compare thead th{ font-family:var(--mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:var(--amber-2); background:rgba(8,14,26,.5); }
.compare td:first-child{ font-weight:600; color:var(--on-dark); }
.compare td{ color:var(--on-dark-soft); font-size:.94rem; }
.compare tr:last-child td{ border-bottom:none; }
.compare .tn{ font-family:var(--mono); color:#fff; font-weight:700; }

/* =========================================================================
   REVEAL ANIMATIONS
   ========================================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
html:not(.js) .reveal{ opacity:1 !important; transform:none !important; }  /* no-JS / crawler safety */
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:1024px){
  .hero-inner{ grid-template-columns:1fr; gap:40px; }
  .hero-stage{ max-width:560px; margin-inline:auto; width:100%; }
  .cards-4{ grid-template-columns:repeat(2,1fr); }
  .cred-grid{ grid-template-columns:repeat(2,1fr); }
  .emirates{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); gap:24px 0; }
  .stat:nth-child(3)::before{ display:none; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:28px; }
  .split{ grid-template-columns:1fr; gap:32px; }
  .split.reverse > :first-child{ order:0; }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .steps-line{ display:none; }
  .cta-inner{ grid-template-columns:1fr; }
  .cta-actions{ flex-direction:row; flex-wrap:wrap; }
}
@media (max-width:860px){
  .nav-links,.nav-phone{ display:none; }
  .nav-toggle{ display:inline-flex; }
  .nav-cta .btn{ display:none; }
  body{ padding-bottom:74px; } /* room for mobile bar */
  .mobile-bar{ display:grid; }
  .wa-float{ bottom:92px; right:15px; width:56px; height:56px; } /* sits above the call bar on Android/iOS */
  .wa-float svg{ width:30px; height:30px; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .section{ padding:64px 0; }
  .hero-inner{ padding:108px 0 56px; }
  .page-hero{ padding:104px 0 48px; }
  .cards-3,.cards-2,.quotes{ grid-template-columns:1fr; }
  .cards-4,.cred-grid,.emirates{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .spec-grid{ grid-template-columns:1fr; }
  .form-grid{ grid-template-columns:1fr; }
  .opt-row.cols-3,.opt-row.cols-2{ grid-template-columns:1fr; }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ width:100%; }
  .route-row{ flex-direction:column; align-items:flex-start; gap:8px; }
  .cta-actions .btn{ flex:1; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}
