/* Mwene Express Air Cargo — Redesign "Flight Deck"
   Award-level air-cargo site · brand orange #F7941D + navy #1B3A6B
   Signature: animated flight-path scrollytelling (Guangzhou→HK→Addis→Dar→Zanzibar)
   Plus Jakarta Sans (head) + Inter (body). Vanilla CSS/JS. */
:root {
  --orange: #F7941D;
  --orange-dark: #d97c08;
  --orange-soft: #fff3e2;
  --navy: #1B3A6B;
  --navy-2: #16315c;
  --navy-dark: #0f2342;
  --navy-deep: #0a1a33;
  --navy-soft: #eef3fa;
  --ink: #11202f;
  --paper: #f4f7fb;
  --line: #e2e9f0;
  --line-d: rgba(255,255,255,.12);
  --muted: #57697c;
  --muted-d: #9fb1c9;
  --wa: #1daa50;
  --wa-dark: #168a40;
  --radius: 20px;
  --head: "Plus Jakarta Sans", system-ui, sans-serif;
  --body: "Inter", system-ui, sans-serif;
  --shadow: 0 24px 60px rgba(15,35,66,.16);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--body); color: var(--ink); background: #fff; line-height: 1.65; overflow-x: hidden; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4 { font-family: var(--head); line-height: 1.13; }
h2 { font-size: clamp(1.7rem, 4.2vw, 2.6rem); font-weight: 800; letter-spacing: -.02em; }
::selection { background: var(--orange); color: #fff; }

.kicker { display: inline-flex; align-items: center; gap: .5rem; font-weight: 800; font-size: .74rem; letter-spacing: .18em; text-transform: uppercase; color: var(--orange-dark); margin-bottom: 1rem; }
.kicker__pin { width: 9px; height: 9px; border-radius: 50%; background: var(--orange); box-shadow: 0 0 0 4px rgba(247,148,29,.18); flex: none; }

/* Topbar */
.topbar { background: var(--navy-deep); color: #fff; font-size: .82rem; font-weight: 600; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding: .5rem clamp(1rem, 4vw, 2rem); }
.topbar p { display: flex; align-items: center; gap: .55rem; }
.topbar__right { display: flex; align-items: center; gap: .6rem; }
.topbar__right a { font-weight: 800; }
.topbar__right a:hover { text-decoration: underline; }
.topbar__sep { opacity: .5; }
.topbar__live { width: 9px; height: 9px; border-radius: 50%; background: #5cf28b; box-shadow: 0 0 0 0 rgba(92,242,139,.6); animation: pulse 2.4s ease-out infinite; flex: none; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(92,242,139,.55)} 70%{box-shadow:0 0 0 8px rgba(92,242,139,0)} 100%{box-shadow:0 0 0 0 rgba(92,242,139,0)} }

/* Header */
.header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.9); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.header__in { max-width: 1200px; margin: 0 auto; padding: .55rem 1.25rem; display: flex; align-items: center; gap: 1.25rem; }
.brand { display: flex; align-items: center; }
.brand__logo { height: 40px; width: auto; }
.nav { display: flex; gap: 1.4rem; font-weight: 600; font-size: .92rem; margin-left: auto; }
.nav a { color: var(--ink); padding: .2rem 0; border-bottom: 2px solid transparent; transition: color .15s, border-color .15s; }
.nav a:hover { color: var(--navy); border-color: var(--orange); }
.header__actions { display: flex; align-items: center; gap: .8rem; }
.lang { display: flex; border: 1.5px solid var(--line); border-radius: 10px; overflow: hidden; }
.lang__btn { border: 0; background: #fff; font: 700 .78rem var(--body); padding: .35rem .62rem; cursor: pointer; color: var(--muted); }
.lang__btn.is-active { background: var(--navy); color: #fff; }
.nav-toggle { display: none; border: 0; background: none; cursor: pointer; padding: .4rem; }
.nav-toggle span { display: block; width: 22px; height: 2.5px; background: var(--ink); margin: 4.5px 0; border-radius: 2px; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .55rem; font: 700 .95rem var(--body); padding: .74rem 1.35rem; border-radius: 999px; transition: transform .12s, background .15s, box-shadow .15s; white-space: nowrap; cursor: pointer; border: 0; }
.btn:active { transform: scale(.97); }
.btn--wa { background: var(--wa); color: #fff; box-shadow: 0 6px 18px rgba(29,170,80,.3); }
.btn--wa:hover { background: var(--wa-dark); transform: translateY(-2px); }
.btn--navy { background: var(--navy); color: #fff; box-shadow: 0 6px 18px rgba(27,58,107,.24); }
.btn--navy:hover { background: var(--navy-dark); transform: translateY(-2px); }
.btn--orange { background: var(--orange); color: #fff; box-shadow: 0 6px 18px rgba(247,148,29,.32); }
.btn--orange:hover { background: var(--orange-dark); transform: translateY(-2px); }
.btn--ghost { border: 2px solid rgba(255,255,255,.45); color: #fff; background: rgba(255,255,255,.06); }
.btn--ghost:hover { border-color: #fff; background: rgba(255,255,255,.14); }
.btn--ghost-d { border: 2px solid var(--line); color: var(--ink); background: #fff; }
.btn--ghost-d:hover { border-color: var(--navy); color: var(--navy); }
.btn--light { background: #fff; color: var(--navy); }
.btn--light:hover { background: var(--orange-soft); transform: translateY(-2px); }
.btn--lg { padding: .98rem 1.75rem; font-size: 1.02rem; }

/* ============ HERO — dark cinematic ============ */
.hero { position: relative; background: var(--navy-deep); color: #fff; overflow: hidden; isolation: isolate; }
.hero__bg { position: absolute; inset: 0; z-index: -2; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: .42; transform: scale(1.04); }
.hero::after { content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(120% 90% at 78% 18%, rgba(247,148,29,.20), transparent 55%),
    linear-gradient(180deg, rgba(10,26,51,.74) 0%, rgba(10,26,51,.86) 55%, var(--navy-deep) 100%); }
.hero__in { max-width: 1200px; margin: 0 auto; padding: clamp(2.8rem, 7vw, 5.2rem) 1.25rem clamp(3rem, 7vw, 5rem); display: grid; grid-template-columns: 1.08fr .92fr; gap: 3rem; align-items: center; }
.hero .kicker { color: #ffd9ad; }
.hero .kicker__pin { background: var(--orange); box-shadow: 0 0 0 4px rgba(247,148,29,.3); }
.hero__title { font-size: clamp(2.15rem, 5vw, 3.5rem); font-weight: 800; letter-spacing: -.025em; }
.hero__title em { font-style: normal; color: var(--orange); }
.hero__sub { margin: 1.2rem 0 1.7rem; color: #c7d4e8; max-width: 33rem; font-size: 1.07rem; }
.hero__ctas { display: flex; gap: .8rem; flex-wrap: wrap; }
.hero__trust { list-style: none; display: flex; gap: 1.9rem; flex-wrap: wrap; margin-top: 2rem; font-size: .82rem; color: var(--muted-d); }
.hero__trust strong { color: #fff; display: block; font-size: .94rem; font-family: var(--head); margin-bottom: .12rem; }

/* Hero boarding-pass card */
.hero__pass { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14); border-radius: var(--radius); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); overflow: hidden; box-shadow: 0 30px 70px rgba(0,0,0,.4); }
.pass__top { display: flex; justify-content: space-between; align-items: center; padding: 1rem 1.3rem; background: rgba(247,148,29,.14); border-bottom: 1px dashed rgba(255,255,255,.22); }
.pass__top b { font: 800 .9rem var(--head); letter-spacing: .04em; }
.pass__top span { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: #ffd9ad; font-weight: 700; }
.pass__route { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: .5rem; padding: 1.4rem 1.3rem 1rem; }
.pass__node { text-align: center; }
.pass__node b { display: block; font: 800 1.5rem var(--head); color: #fff; }
.pass__node span { font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted-d); }
.pass__line { position: relative; height: 30px; }
.pass__line::before { content: ""; position: absolute; top: 50%; left: 0; right: 0; height: 0; border-top: 2px dashed rgba(255,255,255,.35); }
.pass__line svg { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); color: var(--orange); }
.pass__grid { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem; padding: 0 1.3rem 1.3rem; }
.pass__cell { background: rgba(255,255,255,.05); border-radius: 12px; padding: .65rem .8rem; }
.pass__cell span { display: block; font-size: .64rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted-d); margin-bottom: .15rem; }
.pass__cell b { font: 700 .92rem var(--head); color: #fff; }
.pass__cta { padding: 0 1.3rem 1.3rem; }
.pass__cta .btn { width: 100%; }

/* ============ METRICS ============ */
.metrics { max-width: 1200px; margin: -2.6rem auto 0; padding: 0 1.25rem; position: relative; z-index: 2; }
.metrics__in { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.7rem 1.5rem; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; text-align: center; box-shadow: var(--shadow); }
.metric { padding: .2rem .4rem; position: relative; }
.metric + .metric::before { content: ""; position: absolute; left: -.6rem; top: 12%; height: 76%; width: 1px; background: var(--line); }
.metric__n { display: block; font: 800 clamp(1.8rem, 4.4vw, 2.6rem) var(--head); color: var(--navy); line-height: 1; letter-spacing: -.02em; }
.metric__n .sfx { color: var(--orange); }
.metric__word { color: var(--orange) !important; }
.metric span:last-child { display: block; margin-top: .5rem; font-size: .82rem; color: var(--muted); font-weight: 500; }

/* ============ Sections ============ */
.section { max-width: 1200px; margin: 0 auto; padding: clamp(3.2rem, 7vw, 5rem) 1.25rem; }
.section--paper { max-width: none; background: var(--paper); }
.section--paper > * { max-width: 1200px; margin-left: auto; margin-right: auto; }
.section__head { margin-bottom: 2.4rem; max-width: 46rem; }
.section__head--center { margin-left: auto; margin-right: auto; text-align: center; }
.section__head--center .kicker { justify-content: center; }
.section__sub { color: var(--muted); margin-top: .6rem; font-size: 1.04rem; }

/* generic card */
.card { transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.card:hover { transform: translateY(-6px); box-shadow: 0 22px 50px rgba(27,58,107,.14); }

/* ============ FLIGHT-PATH SCROLLYTELLING (signature) ============ */
.route { background: var(--navy-deep); color: #fff; position: relative; isolation: isolate; }
.route::before { content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(60% 50% at 80% 12%, rgba(247,148,29,.13), transparent 60%),
    radial-gradient(50% 50% at 12% 88%, rgba(73,130,210,.14), transparent 60%); }
.route__head { max-width: 1200px; margin: 0 auto; padding: clamp(3rem, 7vw, 4.6rem) 1.25rem 0; text-align: center; }
.route__head .kicker { color: #ffd9ad; justify-content: center; }
.route__head .section__sub { color: var(--muted-d); margin-left: auto; margin-right: auto; max-width: 40rem; }
/* scroll track: tall element; sticky stage inside pins the map */
.route__track { position: relative; height: 320vh; }
.route__stage { position: sticky; top: 0; height: 100vh; min-height: 100svh; display: flex; align-items: center; }
.route__inner { max-width: 1200px; margin: 0 auto; padding: 1rem 1.25rem 2rem; width: 100%; }
.map { position: relative; width: 100%; }
.map svg { width: 100%; height: auto; display: block; overflow: visible; }
/* the dashed great-circle arc that draws as you scroll */
.arc-bg { fill: none; stroke: rgba(255,255,255,.14); stroke-width: 2; stroke-dasharray: 6 8; stroke-linecap: round; }
.arc-draw { fill: none; stroke: var(--orange); stroke-width: 3.2; stroke-linecap: round; filter: drop-shadow(0 0 6px rgba(247,148,29,.55)); }
.stop-dot { fill: var(--navy-deep); stroke: rgba(255,255,255,.45); stroke-width: 2; transition: fill .3s ease, stroke .3s ease, r .3s ease; }
.stop-dot.lit { fill: var(--orange); stroke: #fff; }
.stop-pulse { fill: var(--orange); opacity: 0; }
.stop-pulse.lit { animation: stopPulse 1.6s ease-out infinite; }
@keyframes stopPulse { 0%{opacity:.5;r:7} 100%{opacity:0;r:22} }
.stop-label { fill: var(--muted-d); font: 700 13px var(--head); transition: fill .3s ease; }
.stop-label.lit { fill: #fff; }
.stop-sub { fill: rgba(159,177,201,.7); font: 600 10px var(--body); letter-spacing: .04em; }
.plane-ic { fill: #fff; transition: opacity .3s ease; }
.plane-ic circle { fill: var(--orange); }
/* progress readout under the map */
.route__legend { display: flex; flex-wrap: wrap; gap: .6rem 1.2rem; justify-content: center; margin-top: 1.4rem; }
.route__chip { display: inline-flex; align-items: center; gap: .5rem; font-size: .8rem; font-weight: 600; color: var(--muted-d); background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 999px; padding: .38rem .85rem; transition: color .3s, border-color .3s, background .3s; }
.route__chip.lit { color: #fff; border-color: rgba(247,148,29,.6); background: rgba(247,148,29,.14); }
.route__chip .dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.3); transition: background .3s; }
.route__chip.lit .dot { background: var(--orange); }
.route__cap { text-align: center; margin-top: 1.3rem; }
.route__cap .btn { margin-top: .2rem; }
.route__scrollhint { display: inline-flex; align-items: center; gap: .4rem; font-size: .78rem; color: var(--muted-d); margin-top: 1rem; }
.route__scrollhint svg { animation: hintbob 1.8s ease-in-out infinite; }
@keyframes hintbob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(4px)} }

/* ============ Services ============ */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.svc { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.7rem 1.55rem; position: relative; overflow: hidden; }
.svc::after { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--orange), var(--navy)); transform: scaleX(0); transform-origin: left; transition: transform .3s ease; }
.svc:hover::after { transform: scaleX(1); }
.svc__ic { display: inline-flex; width: 52px; height: 52px; border-radius: 15px; background: var(--orange-soft); color: var(--orange-dark); align-items: center; justify-content: center; margin-bottom: 1rem; }
.svc h3 { font-size: 1.1rem; margin-bottom: .5rem; }
.svc p { font-size: .93rem; color: var(--muted); }
.svc--cta { background: linear-gradient(150deg, var(--navy) 0%, var(--navy-dark) 100%); border-color: var(--navy-dark); color: #fff; display: flex; flex-direction: column; }
.svc--cta::after { display: none; }
.svc--cta h3 { color: #fff; }
.svc--cta p { color: #c7d4e8; }
.svc--cta .btn { margin-top: auto; align-self: flex-start; }

/* ============ How it works ============ */
.how { background: var(--paper); }
.how__in { max-width: 1200px; margin: 0 auto; padding: clamp(3.2rem, 7vw, 5rem) 1.25rem; }
.steps { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; align-items: stretch; gap: 0; margin-top: .5rem; }
.step { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.8rem 1.65rem; box-shadow: 0 10px 30px rgba(15,35,66,.05); }
.step__n { display: inline-flex; width: 46px; height: 46px; border-radius: 50%; background: var(--orange); color: #fff; font: 800 1.3rem var(--head); align-items: center; justify-content: center; margin-bottom: 1rem; box-shadow: 0 8px 20px rgba(247,148,29,.35); }
.step h3 { font-size: 1.18rem; margin-bottom: .5rem; color: var(--navy); }
.step p { color: var(--muted); font-size: .95rem; }
.step__line { align-self: center; width: 100%; min-width: 30px; height: 2px; background: repeating-linear-gradient(90deg, var(--orange) 0 8px, transparent 8px 16px); margin: 0 .6rem; }
.how__cta { text-align: center; margin-top: 2.4rem; }

/* ============ Why ============ */
.why__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.why__c { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.7rem 1.55rem; }
.why__c .ic { display: inline-flex; width: 50px; height: 50px; border-radius: 15px; background: var(--navy-soft); color: var(--navy); align-items: center; justify-content: center; margin-bottom: 1rem; }
.why__c h3 { font-size: 1.1rem; margin-bottom: .5rem; }
.why__c p { font-size: .93rem; color: var(--muted); }

/* Partners */
.partners { margin-top: 2.8rem; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.9rem; box-shadow: 0 14px 40px rgba(15,35,66,.06); }
.partners__head { text-align: center; margin-bottom: 1.5rem; }
.partners__head h3 { font-size: 1.25rem; color: var(--navy); }
.partners__head p { color: var(--muted); font-size: .93rem; margin-top: .3rem; }
.partners__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }
.partner { background: #fff; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
.partner img { width: 100%; aspect-ratio: 770/429; object-fit: cover; }
.partner figcaption { padding: .85rem 1.1rem; font-weight: 700; font-size: .9rem; color: var(--navy); display: flex; align-items: center; gap: .5rem; }
.partner figcaption::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--orange); flex: none; }

/* ============ Ticker ============ */
.ticker { background: var(--orange); color: #fff; overflow: hidden; display: flex; align-items: center; gap: 1rem; padding: .9rem 0; }
.ticker__label { flex: none; padding-left: clamp(1rem, 4vw, 2rem); font: 800 .72rem var(--head); letter-spacing: .16em; text-transform: uppercase; color: #fff4e6; white-space: nowrap; }
.ticker__viewport { flex: 1 1 auto; min-width: 0; overflow: hidden; display: flex; -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); }
.ticker__track { flex: none; display: flex; align-items: center; gap: 1.1rem; padding-right: 1.1rem; white-space: nowrap; font-weight: 700; font-size: .95rem; animation: ticker-scroll 34s linear infinite; }
.ticker__dot { color: var(--navy); font-weight: 800; }
@keyframes ticker-scroll { from { transform: translateX(0); } to { transform: translateX(-100%); } }

/* ============ Coverage ============ */
.coverage__in { display: grid; grid-template-columns: .85fr 1.15fr; gap: 3rem; align-items: center; }
.coverage__media { position: relative; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.coverage__media img { width: 100%; height: 100%; object-fit: cover; }
.coverage__tag { position: absolute; top: 14px; left: 14px; background: rgba(15,35,66,.8); color: #fff; backdrop-filter: blur(4px); border-radius: 999px; padding: .42rem .9rem; font-size: .78rem; font-weight: 700; display: flex; align-items: center; gap: .45rem; }
.coverage h2 { margin-bottom: .9rem; }
.coverage__copy > p { color: var(--muted); max-width: 36rem; }
.lanes { list-style: none; margin: 1.6rem 0 1.2rem; display: grid; gap: .7rem; }
.lane { display: flex; align-items: center; gap: .8rem; flex-wrap: wrap; background: var(--navy-soft); border: 1px solid #dbe6f5; border-radius: 12px; padding: .85rem 1.15rem; font-size: .92rem; }
.lane__from { font-weight: 600; color: var(--muted); }
.lane__arrow { color: var(--orange); display: inline-flex; }
.lane__to { font-weight: 800; font-family: var(--head); color: var(--navy); }
.coverage__note { font-size: .85rem; color: var(--muted); margin-bottom: 1.2rem; }

/* ============ Reviews ============ */
.reviews { background: var(--paper); max-width: none; }
.reviews > * { max-width: 1200px; margin-left: auto; margin-right: auto; }
.rev-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.rev { position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.7rem 1.6rem 1.4rem; box-shadow: 0 10px 30px rgba(15,35,66,.05); }
.rev__q { position: absolute; top: -.2rem; left: 1rem; font: 800 3.4rem var(--head); color: var(--orange-soft); line-height: 1; }
.rev blockquote { position: relative; font-size: .99rem; color: var(--ink); }
.rev figcaption { margin-top: 1rem; font-size: .85rem; color: var(--muted); }
.rev figcaption b { display: block; color: var(--navy); font-size: .96rem; font-family: var(--head); }

/* ============ Contact ============ */
.contact-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 2.5rem; align-items: stretch; }
.contact__photo { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.contact__photo img { width: 100%; height: 100%; object-fit: cover; min-height: 300px; }
.contact__info { display: flex; flex-direction: column; justify-content: center; }
.contact h2 { margin-bottom: .8rem; }
.contact__info > p { color: var(--muted); max-width: 34rem; }
.contact__rows { margin: 1.6rem 0; display: grid; gap: .9rem; }
.contact__row { display: grid; grid-template-columns: 90px 1fr; gap: 1rem; align-items: baseline; font-size: .94rem; }
.contact__lbl { font: 800 .72rem var(--head); letter-spacing: .1em; text-transform: uppercase; color: var(--orange-dark); }
.contact__row a:hover { color: var(--navy); text-decoration: underline; }
.contact__cta { display: flex; gap: .8rem; flex-wrap: wrap; }

/* ============ CTA band ============ */
.band { background: linear-gradient(135deg, var(--navy) 0%, var(--navy-deep) 100%); color: #fff; position: relative; overflow: hidden; isolation: isolate; }
.band::before { content: ""; position: absolute; inset: 0; z-index: -1; background: radial-gradient(50% 80% at 80% 20%, rgba(247,148,29,.22), transparent 60%); }
.band__in { max-width: 920px; margin: 0 auto; text-align: center; padding: clamp(3.2rem, 7vw, 4.8rem) 1.25rem; }
.band h2 { margin-bottom: .6rem; }
.band h2 em { font-style: normal; color: var(--orange); }
.band p { opacity: .92; margin-bottom: 1.8rem; color: #d4dff0; }

/* ============ Footer ============ */
.footer { background: var(--navy-deep); color: #aebfd4; font-size: .9rem; }
.footer__in { max-width: 1200px; margin: 0 auto; padding: 3.2rem 1.25rem 2rem; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; }
.footer__logo { height: 38px; width: auto; margin-bottom: .8rem; }
.footer__brand p { max-width: 26rem; }
.footer h4 { color: #fff; font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; margin-bottom: .7rem; }
.footer a:hover { color: #fff; text-decoration: underline; }
.footer__legal { border-top: 1px solid rgba(255,255,255,.12); max-width: 1200px; margin: 0 auto; padding: 1.1rem 1.25rem 1.4rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; font-size: .78rem; color: #7e8da3; }
.footer__demo { font-style: italic; }

/* ============ FAB ============ */
.wa-fab { position: fixed; right: 1.1rem; bottom: 1.1rem; z-index: 60; width: 56px; height: 56px; border-radius: 50%; background: var(--wa); color: #fff; display: none; align-items: center; justify-content: center; box-shadow: 0 10px 26px rgba(0,0,0,.3); }

/* ===== WOW EFFECTS ===== */
.progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 70; background: linear-gradient(90deg, var(--orange), var(--navy)); transition: width .1s linear; }
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; } .reveal.d2 { transition-delay: .16s; } .reveal.d3 { transition-delay: .24s; }
.hero__title em { background: linear-gradient(100deg, var(--orange) 30%, #ffe0b0 50%, var(--orange) 70%); background-size: 220% 100%; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; animation: shimmer 5.5s linear infinite; }
@keyframes shimmer { to { background-position: -220% 0; } }
.stats.in .metric__n { animation: pop .6s ease; }
@keyframes pop { 0%{transform:scale(.7);opacity:0} 60%{transform:scale(1.08)} 100%{transform:scale(1);opacity:1} }

/* ============ Responsive ============ */
@media (max-width: 980px) {
  .svc-grid, .why__grid, .rev-grid { grid-template-columns: repeat(2, 1fr); }
  .metrics__in { grid-template-columns: repeat(2, 1fr); gap: 1.6rem 1rem; }
  .metric:nth-child(3)::before { display: none; }
  .hero__in, .coverage__in, .contact-grid { grid-template-columns: 1fr; gap: 2rem; }
  .steps { grid-template-columns: 1fr; gap: 1rem; }
  .step__line { display: none; }
}
@media (max-width: 760px) {
  .nav { display: none; position: absolute; top: 100%; left: 0; right: 0; background: #fff; border-bottom: 1px solid var(--line); flex-direction: column; gap: 0; padding: .5rem 0; }
  .nav.is-open { display: flex; }
  .nav a { padding: .85rem 1.5rem; border-top: 1px solid var(--line); border-bottom: 0; }
  .nav-toggle { display: block; }
  .header__actions .btn--wa { display: none; }
  .partners__grid { grid-template-columns: 1fr; }
  .footer__in { grid-template-columns: 1fr 1fr; }
  .wa-fab { display: flex; }
  .topbar { justify-content: center; font-size: .74rem; }
  .topbar p span:not(.topbar__live) { display: none; }
  .topbar p::after { content: "Your Global Trade Partner"; }
  /* MOBILE: flight map is a static, fully-drawn fallback (no sticky scrub) */
  .route__track { min-height: 0 !important; }
  .route__stage { position: static; min-height: 0; }
  .route__scrollhint { display: none; }
  .stop-label { font-size: 15px; }
}
@media (max-width: 480px) {
  .svc-grid, .why__grid, .rev-grid { grid-template-columns: 1fr; }
  .footer__in { grid-template-columns: 1fr; }
  .contact__row { grid-template-columns: 1fr; gap: .15rem; }
  .pass__grid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .btn, .card, .svc { transition: none; }
  .ticker__track, .topbar__live, .stop-pulse.lit { animation: none; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero__title em { animation: none; -webkit-text-fill-color: var(--orange); }
  .stats.in .metric__n { animation: none; }
  .hero__bg img { transform: none; }
  .route__scrollhint svg { animation: none; }
  /* reduced-motion: collapse the tall scrub track to a normal static block */
  .route__track { height: auto; }
  .route__stage { position: static; height: auto; min-height: 0; padding: 1.5rem 0 2rem; }
  .route__scrollhint { display: none; }
}
@media (prefers-reduced-data: reduce) {
  .ticker__track { animation: none; }
  .ticker__track[aria-hidden="true"] { display: none; }
  .hero__bg img { opacity: .3; }
}
