/* ==========================================================================
   VANLOG — Global Logistics, Freight & Warehousing
   Main stylesheet — "Liquid Glass" futuristic premium edition
   (mobile-first, fully responsive)
   --------------------------------------------------------------------------
   Design language: frosted glass surfaces, hairline borders, deep navy
   gradients, ambient accent glow, sharp (low-radius) geometry, technical
   grotesk display type. All class names preserved from the base build.
   ========================================================================== */

/* 1. DESIGN TOKENS ========================================================= */
:root {
  /* Brand palette */
  --navy-950: #060d1a;
  --navy-900: #0a1426;
  --navy-800: #0f1d36;
  --navy-700: #15294b;
  --navy-600: #1c3760;
  --navy-500: #294f87;

  --orange-600: #e2640f;
  --orange-500: #f97316;
  --orange-400: #fb923c;
  --orange-100: #ffedd5;

  --green-600: #16a34a;
  --green-500: #22c55e;
  --green-100: #dcfce7;

  --red-500: #ef4444;
  --amber-500: #f59e0b;
  --blue-500: #3b82f6;

  /* Neutrals (cool-tinted for a technical feel) */
  --ink: #0b1220;
  --slate-700: #334155;
  --slate-600: #475569;
  --slate-500: #64748b;
  --slate-400: #94a3b8;
  --slate-300: #cbd5e1;
  --slate-200: #e2e8f0;
  --slate-100: #eef2f7;
  --slate-50:  #f6f8fb;
  --white: #ffffff;

  /* Semantic */
  --bg: #f4f7fb;
  --bg-muted: #eef2f8;
  --text: var(--ink);
  --text-muted: var(--slate-500);
  --primary: var(--navy-800);
  --accent: var(--orange-500);
  --border: rgba(15, 23, 42, .09);

  /* Glass — more frosted, more translucent */
  --glass-bg: rgba(255, 255, 255, .52);
  --glass-bg-solid: rgba(255, 255, 255, .8);
  --glass-border: rgba(255, 255, 255, .9);
  --glass-dark: rgba(255, 255, 255, .04);
  --glass-dark-2: rgba(255, 255, 255, .07);
  --glass-dark-border: rgba(255, 255, 255, .12);
  --hairline: rgba(15, 23, 42, .08);
  --blur: blur(26px) saturate(185%);
  --blur-sm: blur(12px) saturate(160%);

  /* Typography */
  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-display: 'Space Grotesk', 'Inter', system-ui, sans-serif;

  /* Radii — crisp, near-square */
  --r-sm: 2px;
  --r-md: 4px;
  --r-lg: 6px;
  --r-xl: 8px;
  --r-2xl: 10px;
  --r-full: 999px;

  /* Shadows — layered & premium */
  --shadow-sm: 0 1px 2px rgba(11, 18, 32, .05), 0 2px 8px rgba(11, 18, 32, .04);
  --shadow-md: 0 4px 14px rgba(11, 18, 32, .07), 0 12px 32px rgba(11, 18, 32, .06);
  --shadow-lg: 0 12px 34px rgba(11, 18, 32, .12), 0 30px 64px rgba(11, 18, 32, .14);
  --shadow-orange: 0 10px 30px rgba(249, 115, 22, .35);
  --glow-accent: 0 0 0 1px rgba(249,115,22,.4), 0 8px 30px rgba(249, 115, 22, .35);
  --ring-top: inset 0 1px 0 rgba(255, 255, 255, .65);
  --ring-top-dark: inset 0 1px 0 rgba(255, 255, 255, .12);

  /* Layout */
  --container: 1220px;
  --gutter: 20px;
  --header-h: 76px;
  --ease: cubic-bezier(.16, 1, .3, 1);
}

/* 2. RESET & BASE ========================================================== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  color: var(--text);
  background-color: var(--bg);
  /* faint technical mesh + ambient color wash */
  background-image:
    radial-gradient(900px 500px at 85% -8%, rgba(249, 115, 22, .10), transparent 60%),
    radial-gradient(900px 600px at 0% 0%, rgba(41, 79, 135, .10), transparent 55%),
    linear-gradient(rgba(15, 23, 42, .025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15, 23, 42, .025) 1px, transparent 1px);
  background-size: auto, auto, 46px 46px, 46px 46px;
  background-attachment: fixed, fixed, scroll, scroll;
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; }
input, select, textarea { font-family: inherit; font-size: inherit; }
svg { display: block; }
::selection { background: rgba(249,115,22,.25); }

/* 3. TYPOGRAPHY & UTILITIES ================================================ */
h1, h2, h3, h4 { font-family: var(--font-display); line-height: 1.1; font-weight: 600; color: var(--ink); letter-spacing: -.025em; }
h1 { font-size: clamp(2.1rem, 6vw, 3.65rem); font-weight: 700; }
h2 { font-size: clamp(1.65rem, 4vw, 2.7rem); }
h3 { font-size: clamp(1.2rem, 2.6vw, 1.55rem); }
p { color: var(--slate-600); }

.text-muted { color: var(--text-muted); }
.text-accent { color: var(--accent); }
.text-center { text-align: center; }
.text-white { color: #fff; }
.mono { font-family: 'Space Grotesk', 'SFMono-Regular', ui-monospace, Menlo, monospace; font-feature-settings: "tnum"; letter-spacing: .01em; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--font-sans);
  font-weight: 600; font-size: .74rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--accent);
}
.eyebrow::before { content: ""; width: 22px; height: 1px; background: linear-gradient(90deg, transparent, var(--accent)); display: inline-block; }
.eyebrow.center { justify-content: center; }

/* 4. LAYOUT HELPERS ======================================================== */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding: 70px 0; position: relative; }
.section-lg { padding: 96px 0; }
.section-head { max-width: 680px; margin: 0 auto 48px; text-align: center; }
.section-head p { margin-top: 14px; }
.bg-muted { background: linear-gradient(180deg, rgba(238,242,248,.5), rgba(244,247,251,.9)); }
.bg-navy { background: var(--navy-950); color: #fff; position: relative; overflow: hidden; }
.bg-navy::before { content:""; position:absolute; inset:0; background:
  radial-gradient(700px 360px at 15% 0%, rgba(41,79,135,.5), transparent 60%),
  radial-gradient(700px 400px at 90% 100%, rgba(249,115,22,.18), transparent 60%); }
.bg-navy > * { position: relative; z-index: 1; }
.bg-navy h2, .bg-navy h3 { color: #fff; }
.bg-navy p { color: var(--slate-300); }

.grid { display: grid; gap: 24px; }
.flex { display: flex; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-sm { gap: 10px; }
.gap-md { gap: 18px; }
.wrap { flex-wrap: wrap; }
.hidden { display: none !important; }

/* 5. BUTTONS — sharp geometry, glow on primary action ====================== */
.btn {
  --btn-bg: var(--primary);
  --btn-fg: #fff;
  position: relative;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 13px 22px;
  font-weight: 600; font-size: .94rem; line-height: 1; letter-spacing: -.01em;
  border: 1px solid transparent; border-radius: var(--r-md);
  background: var(--btn-bg); color: var(--btn-fg);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), background .25s, color .2s, border-color .25s;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
.btn:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(249,115,22,.4); }
.btn i { font-size: .9em; }

.btn-accent { --btn-bg: linear-gradient(135deg, var(--orange-500), var(--orange-600)); --btn-fg: #fff; box-shadow: var(--glow-accent); }
.btn-accent:hover { box-shadow: 0 0 0 1px rgba(249,115,22,.6), 0 12px 36px rgba(249,115,22,.5); }
.btn-primary { --btn-bg: linear-gradient(135deg, var(--navy-700), var(--navy-900)); box-shadow: var(--shadow-md), var(--ring-top-dark); }
.btn-primary:hover { --btn-bg: linear-gradient(135deg, var(--navy-600), var(--navy-800)); }
.btn-light { --btn-bg: rgba(255,255,255,.9); --btn-fg: var(--navy-900); box-shadow: var(--shadow-sm); backdrop-filter: var(--blur-sm); border-color: var(--glass-border); }
.btn-light:hover { --btn-bg: #fff; }
.btn-outline { --btn-bg: rgba(255,255,255,.5); --btn-fg: var(--navy-800); border-color: var(--hairline); backdrop-filter: var(--blur-sm); }
.btn-outline:hover { --btn-bg: rgba(255,255,255,.9); border-color: var(--slate-300); }
.btn-outline-light { --btn-bg: rgba(255,255,255,.06); --btn-fg: #fff; border-color: rgba(255,255,255,.22); backdrop-filter: var(--blur-sm); }
.btn-outline-light:hover { --btn-bg: rgba(255,255,255,.14); border-color: rgba(255,255,255,.4); }
.btn-ghost { --btn-bg: transparent; --btn-fg: var(--slate-600); }
.btn-ghost:hover { --btn-bg: rgba(15,23,42,.05); }
.btn-sm { padding: 9px 15px; font-size: .85rem; }
.btn-lg { padding: 16px 28px; font-size: 1rem; }
.btn-block { width: 100%; }

/* 6. BADGES ================================================================ */
.badge {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 13px; border-radius: var(--r-sm);
  font-size: .76rem; font-weight: 600; letter-spacing: .02em;
  background: rgba(15,23,42,.05); color: var(--slate-600);
  border: 1px solid var(--hairline);
}
.badge i { font-size: .85em; }
.badge-success { background: rgba(34,197,94,.12); color: var(--green-600); border-color: rgba(34,197,94,.25); }
.badge-warning { background: rgba(249,115,22,.12); color: var(--orange-600); border-color: rgba(249,115,22,.28); }
.badge-danger  { background: rgba(239,68,68,.12); color: var(--red-500); border-color: rgba(239,68,68,.25); }
.badge-info    { background: rgba(59,130,246,.12); color: var(--blue-500); border-color: rgba(59,130,246,.25); }
.badge-dot::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; box-shadow: 0 0 8px currentColor; }
.badge-lg { padding: 9px 16px; font-size: .88rem; }

/* 7. CARDS — glass surfaces with top-edge highlight ======================== */
.card {
  position: relative;
  background: var(--glass-bg);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-sm), var(--ring-top);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .3s;
}
.card-pad { padding: 26px; }
.card-hover:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg), var(--ring-top); border-color: rgba(255,255,255,.95); }

.icon-box {
  width: 56px; height: 56px; border-radius: var(--r-md);
  display: grid; place-items: center; font-size: 1.35rem;
  background: linear-gradient(140deg, var(--navy-700), var(--navy-500));
  color: #fff; flex-shrink: 0;
  box-shadow: var(--ring-top-dark), 0 6px 18px rgba(15,41,75,.3);
}
.icon-box.accent { background: linear-gradient(140deg, var(--orange-500), var(--orange-600)); box-shadow: var(--ring-top-dark), 0 6px 18px rgba(249,115,22,.4); }
.icon-box.soft { background: rgba(249,115,22,.12); color: var(--orange-600); box-shadow: none; border: 1px solid rgba(249,115,22,.22); }
.icon-box.soft-navy { background: rgba(41,79,135,.1); color: var(--navy-700); box-shadow: none; border: 1px solid rgba(41,79,135,.16); }

/* 8. FORMS ================================================================= */
.field { margin-bottom: 18px; }
.field label, .form-label {
  display: block; font-size: .82rem; font-weight: 600;
  color: var(--slate-700); margin-bottom: 8px; letter-spacing: -.01em;
}
.input, .select, .textarea {
  width: 100%; padding: 13px 15px;
  border: 1px solid var(--slate-300); border-radius: var(--r-md);
  background: rgba(255,255,255,.7); color: var(--ink);
  transition: border-color .2s, box-shadow .2s, background .2s;
}
.input:focus, .select:focus, .textarea:focus {
  outline: none; border-color: var(--accent); background: #fff;
  box-shadow: 0 0 0 4px rgba(249, 115, 22, .14);
}
.textarea { resize: vertical; min-height: 120px; }
.input-group { display: flex; gap: 10px; }
.input-group .input { flex: 1; }
.field-row { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 640px) { .field-row.cols-2 { grid-template-columns: 1fr 1fr; } }

/* 9. TABLES ================================================================ */
.table-wrap { overflow-x: auto; border: 1px solid var(--glass-border); border-radius: var(--r-xl); background: var(--glass-bg-solid); -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur); box-shadow: var(--shadow-sm), var(--ring-top); }
table.data { width: 100%; border-collapse: collapse; min-width: 640px; }
table.data th, table.data td { padding: 14px 18px; text-align: left; font-size: .9rem; }
table.data thead th {
  background: rgba(15,23,42,.03); color: var(--slate-500);
  font-weight: 600; font-size: .72rem; letter-spacing: .07em; text-transform: uppercase;
  border-bottom: 1px solid var(--border);
}
table.data tbody tr { border-bottom: 1px solid var(--hairline); transition: background .15s; }
table.data tbody tr:last-child { border-bottom: none; }
table.data tbody tr:hover { background: rgba(249,115,22,.04); }
table.data td .mono { font-size: .85rem; }

/* 10. HEADER / NAVIGATION — frosted glass bar ============================== */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(244, 247, 251, .65);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border-bottom: 1px solid var(--hairline);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: var(--header-h); gap: 16px; }

.logo { display: inline-flex; align-items: center; gap: 11px; font-family: var(--font-display); font-weight: 700; font-size: 1.3rem; color: var(--navy-900); letter-spacing: -.04em; }
.logo .logo-mark {
  width: 40px; height: 40px; border-radius: 10px;
  background: linear-gradient(140deg, var(--orange-500), var(--orange-600));
  display: grid; place-items: center; color: #fff; font-size: 1.1rem;
  box-shadow: var(--glow-accent), var(--ring-top-dark);
}
.logo small { display: block; font-family: var(--font-sans); font-weight: 500; font-size: .58rem; letter-spacing: .26em; color: var(--slate-400); text-transform: uppercase; }

.nav-menu { display: flex; align-items: center; gap: 2px; }
.nav-menu a {
  padding: 9px 14px; border-radius: var(--r-sm);
  font-weight: 500; font-size: .92rem; color: var(--slate-600);
  transition: color .2s, background .2s;
}
.nav-menu a:hover, .nav-menu a.active { color: var(--navy-900); background: rgba(15,23,42,.05); }

.nav-actions { display: flex; align-items: center; gap: 10px; }
.icon-btn {
  width: 42px; height: 42px; border-radius: var(--r-md);
  display: grid; place-items: center;
  background: rgba(255,255,255,.5); border: 1px solid var(--hairline); color: var(--slate-600);
  transition: background .2s, color .2s, border-color .2s;
}
.icon-btn:hover { background: #fff; color: var(--navy-900); border-color: var(--slate-300); }
.lang-select {
  border: 1px solid var(--hairline); border-radius: var(--r-md);
  padding: 9px 12px; background: rgba(255,255,255,.5); color: var(--slate-700); font-weight: 500; font-size: .85rem;
}
.translate-widget { min-width: 0; }
.translate-widget .goog-te-gadget { font-family: var(--font-sans) !important; font-size: 0 !important; color: transparent !important; }
.translate-widget .goog-te-gadget > span, .translate-widget .goog-logo-link { display: none !important; }
.translate-widget select.goog-te-combo {
  margin: 0 !important; max-width: 150px;
  border: 1px solid var(--hairline); border-radius: var(--r-md);
  padding: 9px 10px; background: rgba(255,255,255,.62);
  color: var(--slate-700); font-size: .84rem; font-weight: 600; font-family: var(--font-sans);
  cursor: pointer;
}
.translate-widget select.goog-te-combo:hover { background: #fff; border-color: var(--slate-300); }
/* Hide only Google's top banner bar — never the language menu itself. */
iframe.goog-te-banner-frame, .goog-te-banner-frame.skiptranslate { display: none !important; }
body { top: 0 !important; }
@media (max-width: 991px) {
  .translate-widget select.goog-te-combo { max-width: 104px; padding: 8px 6px; font-size: .8rem; }
}
.nav-toggle { display: none; }

/* Mobile nav */
@media (max-width: 991px) {
  .nav-menu {
    position: fixed; inset: var(--header-h) 0 auto 0;
    flex-direction: column; align-items: stretch; gap: 2px;
    background: rgba(244,247,251,.92); -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
    padding: 16px var(--gutter) 24px;
    border-bottom: 1px solid var(--hairline); box-shadow: var(--shadow-lg);
    transform: translateY(-130%); transition: transform .4s var(--ease);
    max-height: calc(100vh - var(--header-h)); overflow-y: auto;
  }
  .nav-menu.open { transform: translateY(0); }
  .nav-menu a { padding: 13px 14px; font-size: 1rem; }
  .nav-toggle { display: grid; }
  .desktop-only { display: none !important; }
}
@media (min-width: 992px) { .mobile-only { display: none !important; } }

/* 11. HERO — cinematic, ambient glow ====================================== */
.hero {
  position: relative; color: #fff; overflow: hidden;
  background: linear-gradient(135deg, var(--navy-950) 0%, var(--navy-800) 55%, var(--navy-700) 100%);
}
.hero::before {
  content: ""; position: absolute; inset: 0;
  background-image: var(--hero-img, url('../images/hero-warehouse.jpg'));
  background-size: cover; background-position: center;
  opacity: .22; mix-blend-mode: luminosity;
}
.hero::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(820px 480px at 82% -12%, rgba(249,115,22,.34), transparent 58%),
    radial-gradient(640px 480px at 6% 110%, rgba(41,79,135,.6), transparent 60%),
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: auto, auto, 48px 48px, 48px 48px;
}
/* animated ambient blobs */
.hero .blob { position: absolute; border-radius: 50%; filter: blur(70px); opacity: .5; z-index: 1; pointer-events: none; }
.hero .blob.b1 { width: 380px; height: 380px; background: rgba(249,115,22,.32); top: -90px; right: -40px; animation: drift 16s ease-in-out infinite; }
.hero .blob.b2 { width: 320px; height: 320px; background: rgba(41,79,135,.55); bottom: -120px; left: 8%; animation: drift 20s ease-in-out infinite reverse; }
/* padding-block only — keeps .container's horizontal gutter on mobile */
.hero-inner { position: relative; z-index: 2; padding-block: 80px 128px; max-width: 760px; }
.hero h1 { color: #fff; }
.hero h1 .grad { background: linear-gradient(120deg, #fff, var(--orange-400)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero p.lead { color: var(--slate-300); font-size: 1.12rem; font-weight: 300; margin-top: 20px; max-width: 580px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 22px; margin-top: 44px; color: var(--slate-300); font-size: .9rem; }
.hero-trust span { display: inline-flex; align-items: center; gap: 8px; }
.hero-trust i { color: var(--orange-400); }

/* 11b. HERO SLIDER — auto-advancing background slides ===================== */
.hero.hero-slider::before { content: none; }
.hero-slides { position: absolute; inset: 0; }
.hero-slide {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0; transform: scale(1.08);
  transition: opacity 1.4s var(--ease);
}
.hero-slide.is-active { opacity: 1; transform: scale(1); transition: opacity 1.4s var(--ease), transform 7s linear; }
/* Navy wash keeps headline text readable over full-color photos. */
.hero-slides::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(6,13,26,.93) 0%, rgba(10,20,38,.82) 45%, rgba(21,41,75,.55) 100%);
}
.hero-dots { display: flex; gap: 10px; margin-top: 32px; position: relative; z-index: 2; }
.hero-dots button {
  width: 26px; height: 4px; border-radius: var(--r-full); border: 0; padding: 0; cursor: pointer;
  background: rgba(255,255,255,.28); transition: background .3s, width .3s var(--ease);
}
.hero-dots button.is-active { background: var(--accent); width: 40px; }

/* 12. TRACKING WIDGET — floating glass panel ============================== */
.track-widget { position: relative; z-index: 5; margin-top: -72px; }
.track-card {
  background: rgba(255,255,255,.72);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border-radius: var(--r-2xl); padding: 28px;
  box-shadow: var(--shadow-lg), var(--ring-top); border: 1px solid var(--glass-border);
}
.track-card h3 { display: flex; align-items: center; gap: 10px; }
.track-card h3 i { color: var(--accent); }
.track-form { display: grid; grid-template-columns: 1fr; gap: 12px; margin-top: 18px; }
@media (min-width: 720px) { .track-form { grid-template-columns: 1fr auto; align-items: end; } }
.track-hint { margin-top: 14px; font-size: .85rem; color: var(--slate-500); }
.track-hint code { background: rgba(15,23,42,.06); padding: 2px 8px; border-radius: var(--r-sm); color: var(--navy-700); font-weight: 600; cursor: pointer; font-family: var(--font-display); }

/* 13. STATS — glass over gradient ========================================= */
.stats {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--orange-500), var(--orange-600));
  border-radius: var(--r-2xl); padding: 42px 30px; color: #fff;
  box-shadow: var(--shadow-lg), var(--ring-top-dark);
}
.stats::before { content:""; position:absolute; inset:0; background:
  radial-gradient(500px 240px at 100% 0%, rgba(255,255,255,.25), transparent 60%),
  linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px) 0 0 / 100% 33.33%; }
.stats-grid { position: relative; display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px 18px; text-align: center; }
@media (min-width: 880px) { .stats-grid { grid-template-columns: repeat(5, 1fr); } }
.stat .num { font-family: var(--font-display); font-size: clamp(1.9rem, 4vw, 2.7rem); font-weight: 700; line-height: 1; letter-spacing: -.03em; }
.stat .label { margin-top: 8px; font-size: .84rem; color: rgba(255,255,255,.92); font-weight: 500; }

/* 14. SERVICES ============================================================= */
.services-grid { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 560px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 920px) { .services-grid { grid-template-columns: repeat(4, 1fr); } }
.service-card { padding: 26px; display: flex; flex-direction: column; gap: 14px; overflow: hidden; }
.service-card-img {
  /* Bleeds across the card's 26px padding; max-width must beat the global img cap. */
  width: calc(100% + 52px); max-width: calc(100% + 52px); height: 148px; object-fit: cover;
  margin: -26px -26px 4px; border-radius: var(--r-xl) var(--r-xl) 0 0;
  filter: saturate(1.03); transition: transform .5s var(--ease), filter .5s var(--ease);
}
.service-card:hover .service-card-img { transform: scale(1.04); filter: saturate(1.12); }
.service-card::after { content:""; position:absolute; top:0; left:0; right:0; height:2px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity:0; transition: opacity .4s var(--ease); }
.service-card.card-hover:hover::after, .card-hover.service-card:hover::after { opacity: 1; }
.service-card h3 { font-size: 1.12rem; }
.service-card p { font-size: .92rem; flex: 1; }
.service-card .link { color: var(--accent); font-weight: 600; font-size: .86rem; display: inline-flex; gap: 7px; align-items: center; transition: gap .25s var(--ease); }
.service-card:hover .link { gap: 12px; }
.service-card ul.bullets { display: grid; gap: 8px; }
.service-card ul.bullets li { font-size: .88rem; color: var(--slate-600); display: flex; gap: 9px; align-items: flex-start; }
.service-card ul.bullets li i { color: var(--green-500); margin-top: 3px; }

/* 15. GENERIC SECTIONS ===================================================== */
.split { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: center; }
@media (min-width: 900px) { .split { grid-template-columns: 1fr 1fr; gap: 58px; } }
.split.reverse > :first-child { order: 0; }
@media (min-width: 900px) { .split.reverse > :first-child { order: 1; } }

.media-frame {
  position: relative; border-radius: var(--r-2xl); overflow: hidden;
  box-shadow: var(--shadow-lg), var(--ring-top); aspect-ratio: 4/3; background: var(--slate-100);
  border: 1px solid var(--glass-border);
}
.media-frame img { width: 100%; height: 100%; object-fit: cover; }
.media-badge {
  position: absolute; bottom: 18px; left: 18px;
  background: rgba(255,255,255,.75); -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border-radius: var(--r-lg); padding: 14px 18px;
  box-shadow: var(--shadow-md), var(--ring-top); display: flex; align-items: center; gap: 12px;
  border: 1px solid var(--glass-border);
}
.media-badge .icon-box { width: 44px; height: 44px; font-size: 1.1rem; }
.media-badge strong { display: block; font-family: var(--font-display); }
.media-badge span { font-size: .8rem; color: var(--slate-500); }

.feature-list { display: grid; gap: 20px; margin-top: 28px; }
.feature-item { display: flex; gap: 16px; }
.feature-item .icon-box { width: 48px; height: 48px; font-size: 1.15rem; }
.feature-item h4 { font-size: 1.05rem; font-family: var(--font-display); }
.feature-item p { font-size: .92rem; margin-top: 4px; }

.values-grid { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 640px) { .values-grid { grid-template-columns: repeat(3, 1fr); } }

.steps { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 760px) { .steps { grid-template-columns: repeat(4, 1fr); } }
.step { position: relative; padding: 26px; }
.step .num-badge {
  width: 46px; height: 46px; border-radius: var(--r-md); display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 1.1rem;
  background: linear-gradient(140deg, var(--navy-800), var(--navy-950)); color: #fff; margin-bottom: 16px;
  box-shadow: var(--ring-top-dark), 0 6px 16px rgba(10,20,38,.4);
}
.step h4 { font-family: var(--font-display); font-size: 1.1rem; }

.logos { display: flex; flex-wrap: wrap; gap: 30px 50px; align-items: center; justify-content: center; opacity: .65; }
.logos span { font-family: var(--font-display); font-weight: 600; font-size: 1.2rem; color: var(--slate-400); letter-spacing: -.03em; }

.cta-band {
  background:
    linear-gradient(120deg, rgba(10,20,38,.92) 30%, rgba(21,41,75,.78)),
    url('../images/cta.jpg') center/cover;
  border-radius: var(--r-2xl); padding: 60px 34px; text-align: center; color: #fff;
  position: relative; overflow: hidden; box-shadow: var(--shadow-lg), var(--ring-top-dark);
}
.cta-band::before { content:""; position:absolute; inset:0; background:
  url('../images/cta.jpg') center/cover; opacity:.22; mix-blend-mode: luminosity;
  transform: scale(1.05); animation: kenburns 20s ease-in-out infinite alternate; }
.cta-band::after { content:""; position:absolute; inset:0; background:
  radial-gradient(620px 300px at 88% 0%, rgba(249,115,22,.42), transparent 60%),
  linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px) 0 0 / 100% 44px; }
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 { color: #fff; }
.cta-band p { color: var(--slate-300); max-width: 580px; margin: 14px auto 0; }
.cta-band .hero-cta { justify-content: center; }

.testimonial-grid { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 768px) { .testimonial-grid { grid-template-columns: repeat(3, 1fr); } }
.quote { padding: 28px; display: flex; flex-direction: column; gap: 16px; }
.quote .stars { color: var(--amber-500); }
.quote p { font-size: .95rem; color: var(--slate-700); }
.quote .who { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.avatar { width: 44px; height: 44px; border-radius: var(--r-md); background: linear-gradient(140deg, var(--navy-600), var(--navy-800)); display: grid; place-items: center; font-weight: 700; color: #fff; box-shadow: var(--ring-top-dark); }

/* Page hero (interior pages) — now with cinematic photo backdrop */
.page-hero {
  --ph-img: url('../images/breadcrumb.jpg');
  background: linear-gradient(135deg, rgba(6,13,26,.92), rgba(21,41,75,.82));
  color: #fff; padding: 72px 0; position: relative; overflow: hidden;
}
.page-hero::before {
  content:""; position:absolute; inset:0;
  background-image: var(--ph-img);
  background-size: cover; background-position: center;
  opacity: .35; mix-blend-mode: luminosity;
  transform: scale(1.08); animation: kenburns 22s ease-in-out infinite alternate;
}
.page-hero::after { content:""; position:absolute; inset:0; background:
  radial-gradient(700px 360px at 85% -20%, rgba(249,115,22,.32), transparent 60%),
  linear-gradient(120deg, rgba(6,13,26,.55), transparent 55%),
  linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px) 0 0 / 100% 46px,
  linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px) 0 0 / 46px 100%; }
.page-hero .container { position: relative; z-index: 1; }
.page-hero h1 { color: #fff; }
.page-hero p { color: var(--slate-300); max-width: 580px; margin-top: 12px; font-weight: 300; }
.crumbs { display: flex; gap: 8px; align-items: center; font-size: .85rem; color: var(--slate-400); margin-bottom: 16px; }
.crumbs a:hover { color: #fff; }
.crumbs i { font-size: .65rem; }

/* 16. TRACKING RESULTS ===================================================== */
.tracking-layout { display: grid; grid-template-columns: 1fr; gap: 24px; align-items: start; }
@media (min-width: 980px) { .tracking-layout { grid-template-columns: 330px 1fr; } }

.progress-tracker { display: flex; justify-content: space-between; position: relative; margin: 10px 0 6px; }
.progress-tracker::before {
  content: ""; position: absolute; top: 19px; left: 8%; right: 8%; height: 2px;
  background: var(--slate-200); z-index: 0;
}
.progress-tracker .line-fill {
  position: absolute; top: 19px; left: 8%; height: 2px; z-index: 1;
  background: linear-gradient(90deg, var(--orange-500), var(--orange-400));
  box-shadow: 0 0 10px rgba(249,115,22,.6);
  transition: width .9s var(--ease);
}
.p-step { position: relative; z-index: 2; text-align: center; flex: 1; }
@media (max-width: 780px) {
  .progress-tracker { overflow-x: auto; justify-content: flex-start; padding-bottom: 8px; }
  .progress-tracker::before, .progress-tracker .line-fill { display: none; }
  .p-step { min-width: 94px; }
}
.p-step .dot {
  width: 40px; height: 40px; border-radius: var(--r-md); margin: 0 auto 10px;
  display: grid; place-items: center; background: #fff; border: 2px solid var(--slate-200);
  color: var(--slate-400); font-size: .9rem; transition: all .3s var(--ease);
}
.p-step.done .dot { background: linear-gradient(140deg, var(--orange-500), var(--orange-600)); border-color: transparent; color: #fff; box-shadow: 0 6px 16px rgba(249,115,22,.4); }
.p-step.current .dot { border-color: var(--accent); color: var(--accent); box-shadow: 0 0 0 5px rgba(249,115,22,.16); }
.p-step .p-label { font-size: .74rem; font-weight: 600; color: var(--slate-500); }
.p-step.done .p-label, .p-step.current .p-label { color: var(--navy-900); }

.timeline { position: relative; padding-left: 6px; }
.tl-item { position: relative; padding: 0 0 26px 30px; border-left: 2px solid var(--slate-200); }
.tl-item:last-child { border-left-color: transparent; padding-bottom: 0; }
.tl-item::before {
  content: ""; position: absolute; left: -8px; top: 2px; width: 14px; height: 14px;
  border-radius: var(--r-sm); background: #fff; border: 2px solid var(--slate-300);
}
.tl-item.done::before { background: var(--accent); border-color: var(--accent); box-shadow: 0 0 10px rgba(249,115,22,.5); }
.tl-item.current::before { background: var(--orange-100); border-color: var(--accent); box-shadow: 0 0 0 4px rgba(249,115,22,.16); }
.tl-item .tl-time { font-size: .73rem; color: var(--slate-400); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; }
.tl-item .tl-title { font-weight: 600; color: var(--navy-900); margin: 2px 0; font-size: .95rem; }
.tl-item .tl-place { font-size: .85rem; color: var(--slate-500); }

.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--border); border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border); }
.info-grid .cell { background: rgba(255,255,255,.6); padding: 16px; }
.info-grid .cell .k { font-size: .7rem; text-transform: uppercase; letter-spacing: .06em; color: var(--slate-400); font-weight: 600; }
.info-grid .cell .v { font-weight: 600; color: var(--navy-900); margin-top: 4px; font-size: .95rem; }
@media (min-width: 560px) { .info-grid { grid-template-columns: repeat(2, 1fr); } }

.parcel-party { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 560px) { .parcel-party { grid-template-columns: 1fr 1fr; } }
.party-card { padding: 18px; border: 1px solid var(--border); border-radius: var(--r-lg); background: rgba(255,255,255,.5); }
.party-card .head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; font-weight: 600; color: var(--navy-900); }
.party-card .head i { color: var(--accent); }
.party-card .line { font-size: .9rem; color: var(--slate-600); margin-bottom: 4px; }
.party-card .line strong { color: var(--navy-900); }

.map-frame {
  position: relative; border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border);
  aspect-ratio: 16/8; background: #dce6f2;
}
.map-frame img { width: 100%; height: 100%; object-fit: cover; }
.leaflet-map { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; background: #e8eef5; }
.map-frame .leaflet-control-attribution { font-size: .62rem; background: rgba(255,255,255,.7); }
.map-frame .leaflet-bar a { color: var(--navy-800); }
.map-legend {
  position: absolute; top: 14px; left: 14px; z-index: 500; pointer-events: none; background: rgba(255,255,255,.85);
  -webkit-backdrop-filter: var(--blur-sm); backdrop-filter: var(--blur-sm);
  border-radius: var(--r-md); padding: 10px 14px; box-shadow: var(--shadow-md); font-size: .82rem; border: 1px solid var(--glass-border);
}
.map-legend div { display: flex; align-items: center; gap: 8px; }
.map-legend .pin { width: 10px; height: 10px; border-radius: 50%; box-shadow: 0 0 8px currentColor; }
.action-row { display: flex; flex-wrap: wrap; gap: 12px; }

/* 17. PAYMENT (dark glass) ================================================ */
.pay-page { background: var(--navy-950); min-height: 100vh; color: #e2e8f0; position: relative; }
.pay-page::before { content:""; position: fixed; inset: 0; pointer-events: none; z-index: 0; background:
  radial-gradient(900px 520px at 78% -8%, rgba(249,115,22,.2), transparent 58%),
  radial-gradient(720px 520px at 0% 100%, rgba(41,79,135,.4), transparent 60%),
  linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
  linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: auto, auto, 48px 48px, 48px 48px; }
.pay-page .site-header, .pay-page .container { position: relative; z-index: 1; }
.pay-page .container { padding-top: 36px; padding-bottom: 56px; }
.pay-layout { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 980px) { .pay-layout { grid-template-columns: 1.6fr 1fr; align-items: start; } }
.pay-card { background: var(--glass-dark); border: 1px solid var(--glass-dark-border); border-radius: var(--r-xl); padding: 26px; -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur); box-shadow: var(--ring-top-dark); }
.pay-card h2, .pay-card h3 { color: #fff; }
.pay-card p { color: var(--slate-400); }
.pay-amount { position: relative; overflow: hidden; background: linear-gradient(135deg, var(--orange-500), var(--orange-600)); border-radius: var(--r-xl); padding: 28px; color: #fff; box-shadow: var(--glow-accent), var(--ring-top-dark); }
.pay-amount::before { content:""; position:absolute; inset:0; background: radial-gradient(400px 200px at 100% 0%, rgba(255,255,255,.22), transparent 60%); }
.pay-amount > * { position: relative; }
.pay-amount .small { font-size: .85rem; opacity: .92; }
.pay-amount .big { font-family: var(--font-display); font-size: 2.7rem; font-weight: 700; line-height: 1; margin: 6px 0; letter-spacing: -.03em; }
.method-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.method {
  border: 1px solid var(--glass-dark-border); border-radius: var(--r-md); padding: 16px;
  display: flex; flex-direction: column; gap: 8px; cursor: pointer; transition: border-color .25s, background .25s, box-shadow .25s; position: relative;
  background: var(--glass-dark);
}
.method:hover { border-color: rgba(255,255,255,.2); }
.method i { font-size: 1.4rem; color: var(--orange-400); }
.method strong { color: #fff; font-size: .95rem; }
.method span { font-size: .78rem; color: var(--slate-400); }
.method.active { border-color: var(--orange-500); background: rgba(249,115,22,.12); box-shadow: 0 0 0 1px rgba(249,115,22,.4), 0 8px 24px rgba(249,115,22,.2); }
.method.active::after { content: "\f058"; font-family: "Font Awesome 6 Free"; font-weight: 900; position: absolute; top: 12px; right: 12px; color: var(--orange-400); }
.pay-page .input, .pay-page .select, .pay-page .textarea { background: rgba(255,255,255,.05); border-color: var(--glass-dark-border); color: #fff; }
.pay-page .input::placeholder { color: var(--slate-500); }
.pay-page .input:focus, .pay-page .select:focus, .pay-page .textarea:focus { background: rgba(255,255,255,.08); border-color: var(--orange-500); }
.pay-page .form-label { color: var(--slate-300); }
.method-panel { display: none; }
.method-panel.active { display: block; }
.instructions li { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--glass-dark-border); font-size: .9rem; color: var(--slate-300); }
.instructions li:last-child { border-bottom: none; }
.instructions li .n { width: 26px; height: 26px; border-radius: var(--r-sm); background: rgba(249,115,22,.18); color: var(--orange-400); display: grid; place-items: center; font-weight: 700; font-size: .8rem; flex-shrink: 0; }
.secure-card { display: flex; gap: 12px; align-items: flex-start; padding: 14px; border-radius: var(--r-md); background: rgba(34,197,94,.08); border: 1px solid rgba(34,197,94,.2); }
.secure-card i { color: var(--green-500); font-size: 1.1rem; margin-top: 2px; }
.secure-card strong { color: #fff; font-size: .9rem; }
.secure-card span { font-size: .8rem; color: var(--slate-400); }
.demo-note { background: rgba(245,158,11,.12); border: 1px solid rgba(245,158,11,.3); color: #fcd34d; padding: 12px 16px; border-radius: var(--r-md); font-size: .85rem; display: flex; gap: 10px; align-items: center; }

/* 18. RECEIPT ============================================================== */
.receipt-page { background: var(--bg); padding: 40px 0; }
.receipt {
  max-width: 760px; margin: 0 auto; background: #fff; border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg), var(--ring-top); overflow: hidden; border: 1px solid var(--glass-border);
}
.receipt-top { background: var(--navy-950); color: #fff; padding: 28px 32px; display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 16px; position: relative; overflow: hidden; }
.receipt-top::after { content:""; position:absolute; inset:0; background: radial-gradient(400px 200px at 100% 0%, rgba(249,115,22,.3), transparent 60%); }
.receipt-top > * { position: relative; z-index: 1; }
.receipt-top .logo { color: #fff; }
.receipt-top .logo small { color: var(--slate-400); }
.receipt-meta { text-align: right; font-size: .85rem; color: var(--slate-300); }
.receipt-meta .big { font-family: var(--font-display); font-size: 1.2rem; color: #fff; letter-spacing: .04em; }
.receipt-body { padding: 32px; }
.receipt-row { display: flex; justify-content: space-between; padding: 13px 0; border-bottom: 1px dashed var(--slate-200); font-size: .95rem; }
.receipt-row .k { color: var(--slate-500); }
.receipt-row .v { font-weight: 600; color: var(--navy-900); text-align: right; }
.receipt-total { display: flex; justify-content: space-between; align-items: center; margin-top: 22px; padding: 22px; background: var(--slate-50); border-radius: var(--r-lg); border: 1px solid var(--hairline); }
.receipt-total .label { font-weight: 600; color: var(--slate-600); }
.receipt-total .amount { font-family: var(--font-display); font-size: 1.85rem; font-weight: 700; color: var(--navy-900); letter-spacing: -.02em; }
.receipt-foot { padding: 22px 32px; background: var(--slate-50); border-top: 1px solid var(--border); font-size: .82rem; color: var(--slate-500); text-align: center; }
.receipt-actions { max-width: 760px; margin: 22px auto 0; display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.stamp { border: 2px solid var(--green-500); color: var(--green-600); border-radius: var(--r-md); padding: 6px 16px; font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: .08em; transform: rotate(-6deg); font-size: 1rem; }

@media print {
  .site-header, .site-footer, .receipt-actions, .float-widgets, .no-print { display: none !important; }
  body, .receipt-page { background: #fff !important; padding: 0; background-image: none !important; }
  .receipt { box-shadow: none; border: 1px solid #ccc; max-width: 100%; }
}

/* 19. CONTACT ============================================================== */
.contact-layout { display: grid; grid-template-columns: 1fr; gap: 30px; align-items: start; }
@media (min-width: 900px) { .contact-layout { grid-template-columns: 1fr 1.1fr; } }
.office-grid { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 560px) { .office-grid { grid-template-columns: 1fr 1fr; } }
.office-card { padding: 22px; overflow: hidden; }
.office-card .icon-box { width: 46px; height: 46px; font-size: 1.1rem; margin-bottom: 14px; }
.office-thumb { width: calc(100% + 44px); height: 120px; object-fit: cover; margin: -22px -22px 16px; }
.office-card h4 { font-family: var(--font-display); margin-bottom: 8px; }
.office-card p { font-size: .9rem; }
.contact-method { display: flex; align-items: center; gap: 14px; padding: 16px; border: 1px solid var(--glass-border); border-radius: var(--r-lg); background: var(--glass-bg); -webkit-backdrop-filter: var(--blur-sm); backdrop-filter: var(--blur-sm); box-shadow: var(--ring-top); }
.contact-method .icon-box { width: 44px; height: 44px; }
.contact-method .k { font-size: .8rem; color: var(--slate-500); }
.contact-method .v { font-weight: 600; color: var(--navy-900); }

/* 20. FOOTER =============================================================== */
.site-footer { background: var(--navy-950); color: var(--slate-300); padding: 66px 0 0; position: relative; overflow: hidden; }
.site-footer::before { content:""; position:absolute; inset:0; background:
  radial-gradient(700px 360px at 12% 0%, rgba(41,79,135,.35), transparent 60%),
  radial-gradient(600px 300px at 95% 10%, rgba(249,115,22,.12), transparent 60%); }
.site-footer .container { position: relative; z-index: 1; }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: 36px; padding-bottom: 44px; }
@media (min-width: 680px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr; } }
@media (min-width: 980px) { .footer-grid { grid-template-columns: 2.2fr 1fr 1fr 1.4fr; } }
.site-footer .logo { color: #fff; }
.site-footer h5 { color: #fff; font-family: var(--font-display); font-size: 1rem; margin-bottom: 16px; letter-spacing: -.02em; }
.footer-links a { display: block; padding: 6px 0; font-size: .92rem; color: var(--slate-400); transition: color .2s, padding-left .2s; }
.footer-links a:hover { color: #fff; padding-left: 5px; }
.footer-about p { font-size: .92rem; margin: 16px 0; max-width: 320px; font-weight: 300; }
.footer-newsletter .input-group { margin-top: 14px; }
.footer-newsletter .input { background: rgba(255,255,255,.06); border-color: var(--glass-dark-border); color: #fff; }
.footer-newsletter .input::placeholder { color: var(--slate-500); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); padding: 22px 0; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; font-size: .85rem; color: var(--slate-500); }
.footer-bottom a:hover { color: #fff; }

/* 21. FLOATING WIDGETS ===================================================== */
.float-widgets { position: fixed; right: 18px; bottom: 18px; z-index: 60; display: flex; flex-direction: column; gap: 12px; align-items: flex-end; }
.fab { width: 56px; height: 56px; border-radius: var(--r-lg); display: grid; place-items: center; color: #fff; font-size: 1.4rem; box-shadow: var(--shadow-lg); border: 1px solid rgba(255,255,255,.12); transition: transform .25s var(--ease); }
.fab:hover { transform: translateY(-3px) scale(1.04); }
.fab-chat { background: linear-gradient(140deg, var(--navy-700), var(--navy-900)); }
.chat-window {
  position: fixed; right: 18px; bottom: 86px; width: min(340px, calc(100vw - 36px)); z-index: 61;
  background: var(--glass-bg-solid); -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border-radius: var(--r-xl); box-shadow: var(--shadow-lg), var(--ring-top); overflow: hidden; border: 1px solid var(--glass-border);
  transform: translateY(20px) scale(.96); opacity: 0; pointer-events: none; transition: all .3s var(--ease);
}
.chat-window.open { transform: translateY(0) scale(1); opacity: 1; pointer-events: auto; }
.chat-head { background: linear-gradient(140deg, var(--navy-800), var(--navy-950)); color: #fff; padding: 16px 18px; display: flex; align-items: center; gap: 12px; }
.chat-head .av { width: 38px; height: 38px; border-radius: var(--r-md); background: var(--accent); display: grid; place-items: center; }
.chat-head .status { font-size: .76rem; color: #86efac; display: flex; align-items: center; gap: 6px; }
.chat-body { padding: 18px; display: flex; flex-direction: column; gap: 12px; max-height: 280px; overflow-y: auto; background: rgba(238,242,247,.6); }
.chat-msg { padding: 10px 14px; border-radius: var(--r-lg); font-size: .88rem; max-width: 80%; }
.chat-msg.bot { background: #fff; border: 1px solid var(--border); border-bottom-left-radius: 3px; }
.chat-msg.user { background: linear-gradient(140deg, var(--navy-700), var(--navy-900)); color: #fff; align-self: flex-end; border-bottom-right-radius: 3px; }
.chat-foot { padding: 12px; display: flex; gap: 8px; border-top: 1px solid var(--border); background: #fff; }

/* 22. ANIMATIONS =========================================================== */
@keyframes fadeUp { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: translateY(0); } }
[data-reveal] { opacity: 0; }
[data-reveal].in { animation: fadeUp .8s var(--ease) forwards; }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(249,115,22,.5); } 50% { box-shadow: 0 0 0 10px rgba(249,115,22,0); } }
.pulse { animation: pulse 2.2s infinite; }
@keyframes drift { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-30px,24px) scale(1.08); } }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
@keyframes kenburns { from { transform: scale(1.05); } to { transform: scale(1.16) translate(-1.5%, -1.5%); } }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }
@keyframes dash-move { to { stroke-dashoffset: -100; } }
@keyframes spin-slow { to { transform: rotate(360deg); } }
@keyframes glowpulse { 0%,100% { opacity: .5; } 50% { opacity: 1; } }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; } }

/* Animated partner marquee (moving part) */
.marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee-track { display: flex; width: max-content; gap: 56px; align-items: center; animation: marquee 28s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-track span { font-family: var(--font-display); font-weight: 600; font-size: 1.3rem; color: var(--slate-400); letter-spacing: -.03em; white-space: nowrap; opacity: .7; transition: opacity .2s, color .2s; }
.marquee-track span:hover { opacity: 1; color: var(--navy-700); }

/* Animated route dash on the live map */
.leaflet-map .vl-route { animation: dash-move 2.2s linear infinite; }

/* Section divider shimmer accent */
.shimmer-line { height: 2px; background: linear-gradient(90deg, transparent, var(--accent), transparent); background-size: 200% 100%; animation: shimmer 3.5s linear infinite; border-radius: 2px; }

/* small helpers */
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}
.maxw-prose{max-width:64ch}
.divider-soft{height:1px;background:var(--border);margin:0}

/* 23. FAQ ACCORDION ======================================================== */
.faq-list { max-width: 880px; margin: 0 auto; display: grid; gap: 12px; }
details.faq-item { background: var(--glass-bg-solid); border: 1px solid var(--hairline); border-radius: var(--r-lg); box-shadow: var(--shadow-sm); }
details.faq-item summary { cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 14px; padding: 16px 20px; font-weight: 600; color: var(--navy-900); }
details.faq-item summary::-webkit-details-marker { display: none; }
details.faq-item summary i { color: var(--accent); transition: transform .25s var(--ease); flex-shrink: 0; }
details.faq-item[open] summary i { transform: rotate(45deg); }
details.faq-item .faq-body { padding: 0 20px 18px; color: var(--slate-600); font-size: .95rem; }

/* 24. INDUSTRY / COVERAGE CHIP GRID ======================================== */
.chip-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 12px; }
.chip-card { display: flex; align-items: center; gap: 10px; padding: 14px 16px; background: var(--glass-bg-solid); border: 1px solid var(--hairline); border-radius: var(--r-md); font-weight: 600; font-size: .9rem; color: var(--slate-700); box-shadow: var(--shadow-sm); }
.chip-card i { color: var(--accent); }
.bg-navy .chip-card { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.14); color: #e6ecf5; }
