/* ═══════════════════════════════════════════════════════════
   PIONEER EXPRESS — Global Stylesheet
   Brand: #e67825 (Amber Orange) · #1c437e (Navy Blue)
   Font: Archivo (headings + body — bold geometric sans)
   ═══════════════════════════════════════════════════════════ */

/* ── GOOGLE FONTS ─────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,700&display=swap');

/* ── CSS CUSTOM PROPERTIES ────────────────────────────── */
:root {
    /* Brand Palette */
    --amber: #e67825;
    --amber-dk: #c45f10;
    --amber-lt: #f5a05c;
    --amber-pale: #fff4ec;
    --navy: #1c437e;
    --navy-dk: #122d57;
    --navy-lt: #2558a8;
    --navy-pale: #eef2f9;
    --navy-dark: #122c54;
    --paper: #f7f4ee;
    --line: #e4e7ee;
    /* Neutrals */
    --white: #ffffff;
    --snow: #f8f9fb;
    --fog: #f0f2f5;
    --border: #e3e6ec;
    --ink: #111827;
    --slate: #374151;
    --muted: #6b7280;
    --ghost: #9ca3af;
    /* Typography */
    --ff-display: 'Archivo', Helvetica, Arial, sans-serif;
    --ff-body: 'Archivo', Helvetica, Arial, sans-serif;
    /* Type scale */
    --text-xs: 0.72rem;
    --text-sm: 0.85rem;
    --text-base: 1rem;
    --text-lg: 1.125rem;
    --text-xl: 1.3rem;
    --text-2xl: 1.6rem;
    --text-3xl: 2rem;
    --text-4xl: 2.6rem;
    --text-5xl: 3.4rem;
    /* Spacing */
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
    --space-7: 32px;
    --space-8: 32px;
    --space-10: 40px;
    --space-12: 48px;
    --space-16: 64px;
    --space-20: 40px;
    --space-24: 96px;
    /* Shape */
    --r-sm: 8px;
    --r-md: 14px;
    --r-lg: 24px;
    --r-xl: 48px;
    --r-pill: 999px;

    /* Shadow */
    --shadow-xs: 0 1px 3px rgba(0,0,0,.08);
    --shadow-sm: 0 4px 12px rgba(17,24,39,.07);
    --shadow-md: 0 8px 28px rgba(17,24,39,.10);
    --shadow-lg: 0 16px 48px rgba(17,24,39,.14);
    --shadow-amber: 0 8px 28px rgba(230,120,37,.30);
    --shadow-navy: 0 8px 28px rgba(28,67,126,.25);
    /* Motion */
    --ease: cubic-bezier(.22,.68,0,1.2);
    --dur: 240ms;
}

/* ── RESET ────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--ff-body);
  font-weight: 400;
  color: var(--slate);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img  { max-width: 100%; display: block; }
a    { text-decoration: none; color: inherit; }
ul, ol { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: inherit; }
.px-skip-link{position:absolute;top:-100px;left:16px;z-index:9999;background:var(--amber);color:#fff;padding:10px 20px;border-radius:0 0 8px 8px;font-weight:700;font-size:.9rem;transition:top .2s}
.px-skip-link:focus{top:0}

/* ── LAYOUT ───────────────────────────────────────────── */
.px-container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}
.px-section { padding: var(--space-20) 0; }
.px-section-sm { padding: var(--space-12) 0; }
.px-section-lg { padding: var(--space-24) 0; }

/* ── TYPOGRAPHY UTILITIES ─────────────────────────────── */
.px-eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-family: var(--ff-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--amber);
  background: var(--amber-pale);
  padding: 5px 14px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(230,120,37,.2);
  margin-bottom: var(--space-4);
}
.px-eyebrow-navy {
  color: var(--navy-lt);
  background: var(--navy-pale);
  border-color: rgba(28,67,126,.15);
}
.px-eyebrow-white {
  color: rgba(255,255,255,.9);
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.2);
}

.px-heading {
  font-family: var(--ff-display);
  font-weight: 800; letter-spacing: -.02em;
  line-height: 1.15;
  color: var(--ink);
}
.px-heading-xl { font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl)); }
.px-heading-lg { font-size: clamp(var(--text-2xl), 3.5vw, var(--text-4xl)); }
.px-heading-md { font-size: clamp(var(--text-xl), 2.5vw, var(--text-3xl)); }
.px-heading-sm { font-size: var(--text-xl); }
.px-heading em { color: var(--amber);font-style: normal;}
.px-heading-white { color: var(--white); }
.px-heading-white em { color: var(--amber-lt); font-style: normal; }

.px-lead {
  font-size: var(--text-lg);
  line-height: 1.75;
  color: var(--muted);
  max-width: 560px;
}
.px-body {
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--muted);
}
.px-caption {
  font-size: var(--text-sm);
  color: var(--ghost);
  line-height: 1.5;
}

/* ── BUTTONS ──────────────────────────────────────────── */
.px-btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: 13px 26px;
  border-radius: var(--r-md);
  font-family: var(--ff-body);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: .01em;
  line-height: 1;
  transition: all var(--dur) var(--ease);
  cursor: pointer;
  white-space: nowrap;
  border: 2px solid transparent;
}
.px-btn-amber {
  background: var(--amber);
  color: var(--white);
  border-color: var(--amber);
}
.px-btn-amber:hover {
  background: var(--amber-dk);
  border-color: var(--amber-dk);
  box-shadow: var(--shadow-amber);
  transform: translateY(-2px);
}
.px-btn-navy {
  background: var(--navy);
  color: var(--white);
  border-color: var(--navy);
}
.px-btn-navy:hover {
  background: var(--navy-dk);
  box-shadow: var(--shadow-navy);
  transform: translateY(-2px);
}
.px-btn-outline-white {
  background: transparent;
  color: var(--white);
  border-color: rgba(255,255,255,.5);
}
.px-btn-outline-white:hover {
  background: rgba(255,255,255,.12);
  border-color: var(--white);
}
.px-btn-outline-amber {
  background: transparent;
  color: var(--amber);
  border-color: var(--amber);
}
.px-btn-outline-amber:hover {
  background: var(--amber-pale);
}
.px-btn-ghost {
  background: transparent;
  color: var(--amber);
  border-color: transparent;
  padding-left: 0; padding-right: 0;
}
.px-btn-ghost:hover { color: var(--amber-dk); gap: var(--space-3); }
.px-btn-sm { padding: 9px 18px; font-size: var(--text-xs); }
.px-btn-lg { padding: 16px 34px; font-size: var(--text-base); }

/* ── BADGE / PILL ─────────────────────────────────────── */
.px-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--r-pill);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: .05em;
}
.px-badge-amber { background: var(--amber-pale); color: var(--amber-dk); }
.px-badge-navy  { background: var(--navy-pale); color: var(--navy); }

/* ── DIVIDER ──────────────────────────────────────────── */
.px-divider {
  width: 40px; height: 3px;
  background: var(--amber);
  border-radius: var(--r-pill);
  margin: var(--space-4) 0;
}
.px-divider-center { margin-left: auto; margin-right: auto; }

/* ── CARD BASE ────────────────────────────────────────── */
.px-card {
  background: var(--white);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  overflow: hidden;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.px-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
  border-color: rgba(230,120,37,.25);
}

/* ── ICON BOX ─────────────────────────────────────────── */
.px-icon-box {
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--r-md);
  flex-shrink: 0;
  transition: all var(--dur) var(--ease);
}
.px-icon-box-md { width: 52px; height: 52px; font-size: 1.3rem; }
.px-icon-box-lg { width: 64px; height: 64px; font-size: 1.6rem; }
.px-icon-box-amber { background: var(--amber-pale); color: var(--amber); }
.px-icon-box-navy  { background: var(--navy-pale);  color: var(--navy); }
.px-icon-box-white { background: rgba(255,255,255,.12); color: var(--white); }

/* ── SECTION HEADER BLOCK ─────────────────────────────── */
.px-section-head { margin-bottom: var(--space-12); }
.px-section-head-center { text-align: center; }
.px-section-head-center .px-lead { margin-left: auto; margin-right: auto; }

/* ── TOPBAR ───────────────────────────────────────────── */
.px-topbar {
  background: var(--navy-dk);
  padding: 8px 0;
  font-size: var(--text-xs);
  color: rgba(255,255,255,.6);
}
.px-topbar-inner {
  display: flex; justify-content: space-between; align-items: center; gap: var(--space-4);
}
.px-topbar-left,
.px-topbar-right { display: flex; align-items: center; gap: var(--space-5); }
.px-topbar a {
  color: rgba(255,255,255,.6);
  display: flex; align-items: center; gap: 6px;
  transition: color var(--dur);
}
.px-topbar a:hover { color: var(--amber-lt); }
.px-topbar i { color: var(--amber); font-size: .7rem; }

/* ── NAVBAR ───────────────────────────────────────────── */
.px-nav {
  position: sticky; top: 0; z-index: 900;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  transition: box-shadow var(--dur);
}
.px-nav.scrolled { box-shadow: var(--shadow-sm); }
.px-nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 70px;
}
.px-logo img {
  height: 52px; width: auto;
}
.px-logo-text {
  font-family: var(--ff-display);
  font-size: var(--text-xl);
  color: var(--navy);
  letter-spacing: -.01em;
}
.px-logo-text span { color: var(--amber); }

/* Nav links */
.px-nav-links {
  display: flex; align-items: center; gap: 2px;
}
.px-nav-links a {
  padding: 7px 13px;
  border-radius: var(--r-sm);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--slate);
  transition: all var(--dur);
}
.px-nav-links a:hover,
.px-nav-links a.active {
  color: var(--amber);
  background: var(--amber-pale);
}

/* Dropdown */
.px-dropdown { position: relative; }
.px-dropdown > a::after {
  content: ''; display: inline-block;
  width: 5px; height: 5px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  margin-left: 5px;
  transition: transform var(--dur);
}
.px-dropdown:hover > a::after { transform: rotate(225deg) translateY(2px); }
.px-dropdown-menu {
  position: absolute; top: calc(100% + 8px); left: 50%;
  transform: translateX(-50%) translateY(6px);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-md);
  padding: var(--space-2) 0;
  min-width: 200px;
  opacity: 0; pointer-events: none;
  transition: all var(--dur) var(--ease);
}
.px-dropdown:hover .px-dropdown-menu {
  opacity: 1; pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.px-dropdown-menu a {
  display: block; padding: 9px 18px;
  font-size: var(--text-sm); font-weight: 500;
  color: var(--slate); border-radius: 0;
}
.px-dropdown-menu a:hover {
  background: var(--amber-pale); color: var(--amber);
}

/* Nav CTA */
.px-nav-cta {
  display: flex; align-items: center; gap: var(--space-3);
}
.px-nav-track {
  background: var(--amber); color: var(--white) !important;
  padding: 9px 18px !important;
  border-radius: var(--r-md) !important;
  font-weight: 600 !important;
  font-size: var(--text-sm) !important;
}
.px-nav-track:hover {
  background: var(--amber-dk) !important;
  color: var(--white) !important;
  box-shadow: var(--shadow-amber);
}

/* Hamburger */
.px-hamburger {
  display: none; flex-direction: column; gap: 5px;
  padding: 4px; cursor: pointer;
}
.px-hamburger span {
  display: block; width: 22px; height: 2px;
  background: var(--navy); border-radius: 2px;
  transition: all var(--dur);
}
.px-hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.px-hamburger.open span:nth-child(2) { opacity: 0; }
.px-hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* Mobile Menu */
.px-mobile-nav {
  display: none;
  position: fixed; inset: 0; z-index: 850;
  background: var(--white);
  padding: 88px var(--space-6) var(--space-8);
  overflow-y: auto;
  flex-direction: column; gap: var(--space-1);
}
.px-mobile-nav.open { display: flex; }
.px-mobile-nav a {
  display: block; padding: 13px var(--space-4);
  font-size: var(--text-base); font-weight: 500;
  color: var(--slate); border-radius: var(--r-md);
  border-bottom: 1px solid var(--fog);
}
.px-mobile-nav a:hover { background: var(--fog); color: var(--amber); }
.px-mobile-nav-track {
  background: var(--amber) !important;
  color: var(--white) !important;
  text-align: center;
  margin-top: var(--space-4);
  font-weight: 700 !important;
}

/* ── PAGE HERO (inner pages) ──────────────────────────── */
.px-page-hero {
  background: linear-gradient(135deg, var(--navy-dk) 0%, var(--navy) 60%, rgba(230,120,37,.3) 100%);
  padding: var(--space-20) 0 var(--space-16);
  position: relative; overflow: hidden;
}
.px-page-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.px-page-hero-content { position: relative; z-index: 1; }
.px-page-hero h1 { margin-bottom: var(--space-3); }
.px-breadcrumb {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-sm); color: rgba(255,255,255,.5);
  margin-top: var(--space-5);
}
.px-breadcrumb a { color: rgba(255,255,255,.6); transition: color var(--dur); }
.px-breadcrumb a:hover { color: var(--amber-lt); }
.px-breadcrumb i { font-size: .6rem; }

/* ── STAT PILL ────────────────────────────────────────── */
.px-stat-pill {
  display: inline-flex; align-items: baseline; gap: 5px;
}
.px-stat-pill .num {
  font-family: var(--ff-display);
  font-size: var(--text-4xl);
  color: var(--white);
  line-height: 1;
}
.px-stat-pill .sup {
  font-family: var(--ff-display);
  font-size: var(--text-2xl);
  color: var(--amber-lt);
}
.px-stat-pill .lbl {
  font-size: var(--text-xs);
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
  letter-spacing: .09em;
  margin-top: 4px;
}

/* ── FEATURE CARD ─────────────────────────────────────── */
.px-feature-card {
  padding: var(--space-8) var(--space-6);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  background: var(--white);
  position: relative; overflow: hidden;
  transition: all var(--dur) var(--ease);
}
.px-feature-card::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--amber), var(--amber-lt));
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur) var(--ease);
}
.px-feature-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
  border-color: rgba(230,120,37,.2);
}
.px-feature-card:hover::after { transform: scaleX(1); }
.px-feature-card:hover .px-icon-box-amber {
  background: var(--amber);
  color: var(--white);
}

/* ── SPLIT SECTION ────────────────────────────────────── */
.px-split {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--space-16); align-items: center;
}
.px-split-reverse { }
@media (min-width: 961px) {
  .px-split-reverse .px-split-visual { order: -1; }
}

/* ── VISUAL STACK (overlapping images) ───────────────── */
.px-visual-stack { position: relative; padding: var(--space-6); }
.px-visual-main {
  border-radius: var(--r-xl); overflow: hidden;
  box-shadow: var(--shadow-lg);
  aspect-ratio: 4 / 3;
}
.px-visual-main img { width: 100%; height: 100%; object-fit: cover; }
.px-visual-accent {
  position: absolute; bottom: -10px; right: -10px;
  width: 42%; aspect-ratio: 1;
  border-radius: var(--r-lg); overflow: hidden;
  border: 4px solid var(--white);
  box-shadow: var(--shadow-md);
}
.px-visual-accent img { width: 100%; height: 100%; object-fit: cover; }
.px-visual-tag {
  position: absolute; top: var(--space-4); left: var(--space-4);
  z-index: 2;
  background: var(--amber);
  color: var(--white);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--r-md);
  font-weight: 700; font-size: var(--text-sm);
  box-shadow: var(--shadow-md);
  display: flex; align-items: center; gap: 6px;
  max-width: calc(100% - var(--space-8));
  flex-wrap: wrap;
}
@media (max-width: 480px) {
  .px-visual-tag { font-size: var(--text-xs); letter-spacing: -.01em; }
}
.px-visual-tag-navy {
  background: var(--navy);
}

/* ── INLINE CHECKLIST ─────────────────────────────────── */
.px-checklist { display: flex; flex-direction: column; gap: var(--space-3); }
.px-check-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    font-size: var(--text-base);
    color: var(--slate);
    font-style: normal;
}
.px-check-item i { color: var(--amber); font-size: .85rem; margin-top: 4px; flex-shrink: 0; }

/* ── TICKER / MARQUEE ─────────────────────────────────── */
.px-ticker-wrap {
  overflow: hidden;
  background: var(--fog);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 14px 0;
}
.px-ticker {
  display: flex; align-items: center; gap: var(--space-10);
  animation: ticker 30s linear infinite;
  width: max-content;
}
.px-ticker-item {
  display: flex; align-items: center; gap: var(--space-3);
  font-size: var(--text-sm); font-weight: 600;
  color: var(--navy); white-space: nowrap;
}
.px-ticker-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--amber); flex-shrink: 0;
}
@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.px-ticker-wrap:hover .px-ticker { animation-play-state: paused; }

/* ── MEMBER LOGO CARD ─────────────────────────────────── */
.px-member-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-8) var(--space-6);
  display: flex; flex-direction: column; align-items: center; gap: var(--space-4);
  transition: all var(--dur) var(--ease);
  text-align: center;
}
.px-member-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--amber);
  transform: translateY(-4px);
}
.px-member-card img {
  height: 60px; width: auto; object-fit: contain;
  filter: saturate(.6) opacity(.8);
  transition: filter var(--dur);
}
.px-member-card:hover img { filter: saturate(1) opacity(1); }
.px-member-name {
  font-size: var(--text-xs); font-weight: 600;
  color: var(--muted); text-transform: uppercase; letter-spacing: .07em;
}
.px-member-desc {
  font-size: var(--text-xs); color: var(--ghost); line-height: 1.5; margin-top: -4px;
}

/* ── TRACKING WIDGET ──────────────────────────────────── */
.px-track-band {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-lt) 100%);
  padding: var(--space-16) 0;
  position: relative; overflow: hidden;
}
.px-track-band::before {
  content: '';
  position: absolute; width: 400px; height: 400px; border-radius: 50%;
  background: rgba(230,120,37,.1);
  top: -150px; right: -80px; pointer-events: none;
}
.px-track-inner {
  display: grid; grid-template-columns: 1fr 1.2fr;
  gap: var(--space-12); align-items: center;
  position: relative; z-index: 1;
}
.px-track-form {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--r-xl);
  padding: var(--space-8) var(--space-8);
  backdrop-filter: blur(10px);
}
.px-track-form-row { display: flex; gap: var(--space-3); margin-top: var(--space-5); }
.px-track-input-wrap { flex: 1; position: relative; }
.px-track-input-icon {
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  color: rgba(255,255,255,.35); font-size: .9rem;
}
.px-track-input {
  width: 100%; padding: 14px 14px 14px 40px;
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.18);
  border-radius: var(--r-md);
  color: var(--white); font-family: var(--ff-body);
  font-size: var(--text-sm);
  transition: border-color var(--dur), background var(--dur);
}
.px-track-input::placeholder { color: rgba(255,255,255,.35); }
.px-track-input:focus {
  outline: none;
  border-color: var(--amber-lt);
  background: rgba(255,255,255,.15);
}
.px-track-tabs { display: flex; gap: var(--space-2); }
.px-track-tab {
  flex: 1; padding: 9px;
  text-align: center; border-radius: var(--r-sm);
  font-size: var(--text-xs); font-weight: 600;
  color: rgba(255,255,255,.5);
  border: 1px solid rgba(255,255,255,.15);
  cursor: pointer;
  transition: all var(--dur);
}
.px-track-tab.active,
.px-track-tab:hover {
  background: var(--amber); color: var(--white); border-color: var(--amber);
}
.px-track-hint {
  margin-top: var(--space-3);
  font-size: var(--text-xs); color: rgba(255,255,255,.35);
  display: flex; align-items: center; gap: 5px;
}

/* ── TESTIMONIAL CARD ─────────────────────────────────── */
.px-testi-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-8) var(--space-6);
  position: relative; overflow: hidden;
  transition: all var(--dur) var(--ease);
}
.px-testi-card::before {
  content: '\201C';
  position: absolute; top: 12px; right: 20px;
  font-family: Georgia, serif;
  font-size: 5rem; line-height: 1;
  color: var(--amber-pale);
}
.px-testi-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.px-testi-stars { display: flex; gap: 3px; color: #f59e0b; font-size: .8rem; margin-bottom: var(--space-4); }
.px-testi-text {
  font-size: var(--text-sm); line-height: 1.8;
  color: var(--slate);
  margin-bottom: var(--space-6);
}
.px-testi-author { display: flex; align-items: center; gap: var(--space-3); }
.px-testi-avatar {
  width: 40px; height: 40px; border-radius: var(--r-md);
  background: var(--amber); color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-size: var(--text-base);
  flex-shrink: 0;
}
.px-testi-author strong { display: block; font-size: var(--text-sm); color: var(--ink); }
.px-testi-author span  { font-size: var(--text-xs); color: var(--ghost); }

/* ── AIRLINE PARTNER LOGO ─────────────────────────────── */
.px-partner-logo {
  padding: var(--space-4) var(--space-6);
  border-radius: var(--r-md);
  background: var(--white);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: var(--text-sm); font-weight: 600; color: var(--muted);
  transition: all var(--dur);
  min-height: 56px;
}
.px-partner-logo:hover {
  border-color: var(--amber);
  color: var(--amber);
  box-shadow: var(--shadow-xs);
}

/* ── CTA BAND ─────────────────────────────────────────── */
.px-cta-band {
  background: linear-gradient(100deg, var(--amber) 0%, var(--amber-dk) 100%);
  padding: var(--space-16) 0;
  position: relative; overflow: hidden;
}
.px-cta-band::before {
  content: '';
  position: absolute; top: -60px; right: -40px;
  width: 260px; height: 260px; border-radius: 50%;
  background: rgba(255,255,255,.08); pointer-events: none;
}
.px-cta-inner {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: var(--space-8);
  position: relative; z-index: 1;
}
.px-cta-text h2 {
  font-family: var(--ff-display);
  font-size: clamp(var(--text-xl), 3vw, var(--text-3xl));
  color: var(--white); margin-bottom: var(--space-2);
}
.px-cta-text p { color: rgba(255,255,255,.8); font-size: var(--text-base); }
.px-cta-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.px-btn-white {
  background: var(--white); color: var(--amber);
  border-color: var(--white); font-weight: 700;
}
.px-btn-white:hover {
  background: var(--snow); transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
}
.px-btn-ghost-white {
  background: transparent;
  color: var(--white);
  border: 2px solid rgba(255,255,255,.5);
}
.px-btn-ghost-white:hover { background: rgba(255,255,255,.12); border-color: var(--white); }

/* ── FOOTER ───────────────────────────────────────────── */
.px-footer {
  background: var(--navy-dk);
  padding: var(--space-16) 0 0;
  color: rgba(255,255,255,.6);
}
.px-footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.6fr;
  gap: var(--space-10);
  margin-bottom: var(--space-12);
}
.px-footer-brand-logo {
  font-family: var(--ff-display);
  font-size: var(--text-2xl);
  color: var(--white); margin-bottom: var(--space-4);
}
.px-footer-brand-logo span { color: var(--amber); }
.px-footer-desc { font-size: var(--text-sm); line-height: 1.8; margin-bottom: var(--space-6); }
.px-footer-socials { display: flex; gap: var(--space-2); }
.px-social-btn {
  width: 36px; height: 36px; border-radius: var(--r-sm);
  background: rgba(255,255,255,.07);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.6); font-size: .85rem;
  transition: all var(--dur);
}
.px-social-btn:hover { background: var(--amber); color: var(--white); }
.px-footer-heading {
  font-family: var(--ff-body);
  font-size: var(--text-xs); font-weight: 700;
  color: var(--white);
  text-transform: uppercase; letter-spacing: .1em;
  margin-bottom: var(--space-5);
}
.px-footer-links { display: flex; flex-direction: column; gap: var(--space-3); }
.px-footer-links a {
  font-size: var(--text-sm); color: rgba(255,255,255,.55);
  display: flex; align-items: center; gap: var(--space-2);
  transition: color var(--dur);
}
.px-footer-links a i { font-size: .6rem; color: var(--amber); }
.px-footer-links a:hover { color: var(--amber-lt); }
.px-footer-contact { display: flex; flex-direction: column; gap: var(--space-4); }
.px-fc-row { display: flex; gap: var(--space-3); font-size: var(--text-sm); align-items: flex-start; }
.px-fc-icon {
  width: 30px; height: 30px; border-radius: var(--r-sm);
  background: rgba(230,120,37,.15); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.px-fc-icon i { color: var(--amber); font-size: .75rem; }
.px-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.07);
  padding: var(--space-5) 0;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: var(--space-3);
  font-size: var(--text-xs); color: rgba(255,255,255,.35);
}

/* ── SCROLL TO TOP ────────────────────────────────────── */
#px-scroll-top {
  position: fixed; bottom: 28px; right: 28px;
  width: 44px; height: 44px; border-radius: var(--r-md);
  background: var(--amber); color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-size: .9rem; box-shadow: var(--shadow-amber);
  opacity: 0; pointer-events: none;
  transition: all var(--dur) var(--ease); z-index: 800;
  cursor: pointer;
}
#px-scroll-top.visible { opacity: 1; pointer-events: auto; }
#px-scroll-top:hover { background: var(--amber-dk); transform: translateY(-3px); }

/* ── ANIMATIONS 2.0 — MOTION SYSTEM ──────────────────────
   Direction-aware scroll reveals, true grid stagger via
   --stagger-i, magnetic card tilt, count-up numbers, and
   scroll parallax. Transform/opacity only — GPU-cheap.
   ───────────────────────────────────────────────────── */
:root {
  --ease-out:    cubic-bezier(.16,1,.3,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --reveal-dur:  850ms;
  --reveal-dist: 48px;
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.px-animate-up { animation: fadeUp .65s var(--ease) both; }
.px-animate-up.d1 { animation-delay: .1s; }
.px-animate-up.d2 { animation-delay: .22s; }
.px-animate-up.d3 { animation-delay: .34s; }
.px-animate-up.d4 { animation-delay: .46s; }

/* ── Scroll-triggered reveal (JS adds .visible on intersect) ──
   Base direction = rise from below with a soft scale-in.
   Add a direction modifier class to vary the entrance. */
.px-reveal {
  --stagger-i: 0;
  opacity: 0;
  transform: translateY(var(--reveal-dist)) scale(.94);
  filter: blur(10px);
  transition:
    opacity var(--reveal-dur) var(--ease-out),
    transform var(--reveal-dur) var(--ease-out),
    filter var(--reveal-dur) var(--ease-out);
  transition-delay: calc(var(--stagger-i) * 120ms);
  will-change: transform, opacity, filter;
}
.px-reveal.visible {
  opacity: 1;
  transform: none;
  filter: blur(0);
  will-change: auto;
}

/* Direction variants — apply alongside .px-reveal */
.px-reveal-left  { transform: translate3d(calc(var(--reveal-dist) * -1.6), 20px, 0) scale(.94); }
.px-reveal-right { transform: translate3d(calc(var(--reveal-dist) * 1.6), 20px, 0) scale(.94); }
.px-reveal-left.visible,
.px-reveal-right.visible { transform: none; }

.px-reveal-scale {
  transform: scale(.82);
  filter: blur(14px);
}
.px-reveal-scale.visible { transform: scale(1); filter: blur(0); }

/* Reduced-distance variant for small/inline elements (badges, stat labels) */
.px-reveal-fade {
  transform: translateY(16px);
  filter: blur(5px);
  transition-duration: 1100ms;
}

/* ── MAGNETIC TILT CARDS ──────────────────────────────────
   Applied directly to the card itself (.px-feature-card,
   .why-card, .va-card, .px-bento-box already have, or now
   get, position:relative). JS sets --rx / --ry / --mx / --my
   per pointer position; CSS composes the tilt rotation with
   each card's existing hover-lift transform so neither
   clobbers the other.

   IMPORTANT — CSS cascade note: `transition` / `transition-*`
   properties do NOT merge across separate rules; whichever
   rule wins the cascade replaces the full property list. Since
   most tilt cards also carry .px-reveal (for the scroll-in
   entrance), the combined selector below declares every
   transition both features need in one place so neither
   overwrites the other on elements that use both classes. */
.px-tilt {
  --rx: 0deg; --ry: 0deg; --mx: 50%; --my: 50%;
  transform: perspective(1000px) rotateX(var(--rx)) rotateY(var(--ry));
  transition: transform 420ms var(--ease-out), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.px-tilt:hover {
  transform: perspective(1000px) rotateX(var(--rx)) rotateY(var(--ry)) translateY(-4px);
}
.px-tilt:not(:hover) { transition-duration: 600ms, var(--dur), var(--dur); }

/* Elements using BOTH .px-reveal and .px-tilt need every
   transition declared together so the cascade doesn't drop
   one feature's transitions in favour of the other's. The
   `transform` property is shared between the entrance
   (translate+scale) and the live hover-tilt (rotateX/rotateY)
   — so its duration is capped at --reveal-dur (not slower)
   so the entrance still finishes promptly; once revealed, the
   :not(:hover)/​:hover rules below snap it back to a quick,
   responsive speed for cursor-tracked tilt. */
.px-reveal.px-tilt {
  transition:
    opacity var(--reveal-dur) var(--ease-out),
    filter var(--reveal-dur) var(--ease-out),
    transform var(--reveal-dur) var(--ease-out),
    box-shadow var(--dur) var(--ease),
    border-color var(--dur) var(--ease);
  transition-delay: calc(var(--stagger-i) * 120ms), calc(var(--stagger-i) * 120ms), calc(var(--stagger-i) * 120ms), 0s, 0s;
}
.px-reveal.px-tilt:not(.visible) {
  transform: translateY(var(--reveal-dist)) scale(.94) perspective(1000px) rotateX(var(--rx)) rotateY(var(--ry));
}
.px-reveal.px-tilt.visible {
  transform: perspective(1000px) rotateX(var(--rx)) rotateY(var(--ry));
}
.px-reveal.px-tilt.visible:hover {
  transform: perspective(1000px) rotateX(var(--rx)) rotateY(var(--ry)) translateY(-4px);
}
/* Once revealed and not hovered, snap the transform transition
   back down to a quick, responsive speed for cursor tilt. */
.px-reveal.px-tilt.visible:not(:hover) {
  transition-duration: var(--reveal-dur), var(--reveal-dur), 600ms, var(--dur), var(--dur);
  transition-delay: 0s, 0s, 0s, 0s, 0s;
}
.px-reveal.px-tilt.visible:hover {
  transition-duration: var(--reveal-dur), var(--reveal-dur), 420ms, var(--dur), var(--dur);
  transition-delay: 0s, 0s, 0s, 0s, 0s;
}

.px-tilt::before {
  content: '';
  position: absolute; inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle 220px at var(--mx) var(--my), rgba(255,255,255,.16), transparent 70%);
  opacity: 0;
  transition: opacity 280ms var(--ease-out);
  pointer-events: none;
  z-index: 0;
}
.px-tilt:hover::before { opacity: 1; }
.px-tilt > * { position: relative; z-index: 1; }

/* Amber/light-background tilt cards want a warm glow instead
   of a white one (white-on-white is invisible). */
.px-tilt.px-tilt-warm::before {
  background: radial-gradient(circle 220px at var(--mx) var(--my), rgba(230,120,37,.16), transparent 70%);
}

/* ── COUNT-UP STAT NUMBERS ───────────────────────────────── */
.hero-stat-num,
.reach-stat .num,
.px-bento-num { font-variant-numeric: tabular-nums; }
.px-counting { color: var(--amber-lt); }

/* ── SCROLL PARALLAX LAYERS ──────────────────────────────
   JS updates --py (translateY) on scroll via rAF. */
.px-parallax {
  --py: 0px;
  transform: translate3d(0, var(--py), 0);
  will-change: transform;
}

/* ── HERO BACKGROUND DEPTH DRIFT ─────────────────────────── */
/* Handled directly on .hero-slide / .hero-slide.active via a
   transition-based scale (see HERO block above) so it replays
   cleanly on every slide change, not just once via @keyframes. */

/* ── PERFORMANCE / ACCESSIBILITY GUARDS ──────────────────── */
@media (prefers-reduced-motion: reduce) {
  .px-reveal, .px-reveal-left, .px-reveal-right, .px-reveal-scale, .px-reveal-fade {
    opacity: 1 !important; transform: none !important; filter: none !important;
    transition: none !important;
  }
  .px-tilt { transform: none !important; transition: none !important; }
  .px-tilt::before { display: none !important; }
  .hero-slide, .hero-slide.active, .hero-slide.active:first-child { transition: none !important; transform: none !important; animation: none !important; }
  .hero-eyebrow, .hero-line, .hero-p, .hero-cta,
  .hero-content.hero-out .hero-eyebrow,
  .hero-content.hero-out .hero-line,
  .hero-content.hero-out .hero-p,
  .hero-content.hero-out .hero-cta {
    transition: none !important; transform: none !important; opacity: 1 !important;
  }
  .px-parallax { transform: none !important; }
}

/* Disable tilt + parallax below tablet width — keeps budget
   Android devices smooth; reveals still play. */
@media (max-width: 820px), (hover: none) {
  .px-tilt { transform: none !important; }
  .px-tilt::before { display: none !important; }
  .px-parallax { transform: none !important; }
}

/* ── GRIDS ────────────────────────────────────────────── */
.px-grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: var(--space-6); }
.px-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-6); }
.px-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-6); }
.px-grid-auto { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); gap: var(--space-6); }

/* ── UTILS ────────────────────────────────────────────── */
.text-center { text-align: center; }
.text-white  { color: var(--white) !important; }
.text-amber  { color: var(--amber) !important; }
.text-navy   { color: var(--navy) !important; }
.text-muted  { color: var(--muted) !important; }
.mt-2 { margin-top: var(--space-2); }
.mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }
.mb-2 { margin-bottom: var(--space-2); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-8 { margin-bottom: var(--space-8); }
.gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); }
.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.flex-wrap { flex-wrap: wrap; }
.bg-snow { background: var(--snow); }
.bg-fog  { background: var(--fog); }
.bg-navy { background: var(--navy); }
.bg-navy-dk { background: var(--navy-dk); }

/* ── RESPONSIVE ───────────────────────────────────────── */
@media (max-width: 1024px) {
  .px-grid-4 { grid-template-columns: repeat(2,1fr); }
  .px-footer-grid { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
  .px-track-inner { grid-template-columns: 1fr; }
}

@media (max-width: 960px) {
  .px-nav-links, .px-nav-cta { display: none; }
  .px-hamburger { display: flex; }
  .px-split { grid-template-columns: 1fr; gap: var(--space-10); }
  .px-grid-3 { grid-template-columns: repeat(2,1fr); }
  .px-topbar-left { display: none; }
  .px-cta-inner { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 640px) {
  .px-grid-2,
  .px-grid-3 { grid-template-columns: 1fr; }
  .px-grid-4 { grid-template-columns: 1fr; }
  .px-section { padding: var(--space-12) 0; }
  .px-section-lg { padding: var(--space-16) 0; }
  .px-footer-grid { grid-template-columns: 1fr; }
  .px-visual-accent { display: none; }
  .px-track-form-row { flex-direction: column; }
  .px-footer-bottom { flex-direction: column; text-align: center; }
}

/* ── PRINT ────────────────────────────────────────────── */
@media print {
  .px-topbar, .px-nav, .px-hamburger, #px-scroll-top, .px-mobile-nav { display: none !important; }
}

/* ═══════════════════════════════════════════════════════════
   CONTACT PAGE — ;
  backgrou
   ═══════════════════════════════════════════════════════════ */

/* ── PAGE HERO ────────────────────────────────────────── */
.contact-hero {
  position: relative;
  background: linear-gradient(108deg, var(--navy-dk) 0%, var(--navy) 55%, rgba(230,120,37,.28) 100%);
  padding: 28px 0 24px;
  overflow: hidden;
}
.contact-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.contact-hero::after {
  content: '';
  position: absolute; right: -80px; top: -80px;
  width: 420px; height: 420px; border-radius: 50%;
  background: rgba(230,120,37,.1); pointer-events: none;
}
.contact-hero-inner {
  position: relative; z-index: 1;
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap;
  gap: var(--space-4);
}
.contact-hero h1 {
  font-family: var(--ff-display);
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  color: var(--white); line-height: 1.1;
  margin-bottom: var(--space-4);
}
    .contact-hero h1 em {
        color: var(--amber-lt);
        font-style: normal;
    }
.contact-hero p { display: none; }

/* Breadcrumb */
.px-breadcrumb {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-xs); color: rgba(255,255,255,.45);
  margin-bottom: var(--space-5);
  text-transform: uppercase; letter-spacing: .07em;
}
.px-breadcrumb a { color: rgba(255,255,255,.5); transition: color var(--dur); }
.px-breadcrumb a:hover { color: var(--amber-lt); }
.px-breadcrumb i { font-size: .5rem; }

/* Hero quick contacts */
.hero-quick-contacts {
  display: flex; flex-wrap: wrap; gap: var(--space-4);
  margin-top: 0;
}
.hero-quick-item {
  display: flex; align-items: center; gap: var(--space-3);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--r-md);
  padding: 7px 14px;
  backdrop-filter: blur(8px);
  transition: all var(--dur);
}
.hero-quick-item:hover { background: rgba(230,120,37,.2); border-color: var(--amber); }
.hero-quick-item i { color: var(--amber-lt); font-size: .75rem; }
.hero-quick-item span { font-size: var(--text-xs); color: rgba(255,255,255,.8); font-weight: 500; }

/* ── MAIN CONTACT LAYOUT ─────────────────────────────── */
.contact-body { padding: var(--space-10) 0 var(--space-16); background: var(--snow); }
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: var(--space-10);
  align-items: start;
}

/* ── CONTACT FORM ────────────────────────────────────── */
.contact-form-card {
  background: var(--white);
  border-radius: var(--r-xl);
  border: 1px solid var(--border);
  padding: var(--space-10) var(--space-10);
  box-shadow: var(--shadow-sm);
  position: sticky; top: 90px;
}
.form-title {
  font-family: var(--ff-display);
  font-size: var(--text-2xl); color: var(--ink);
  margin-bottom: var(--space-2);
}
.form-sub { font-size: var(--text-sm); color: var(--muted); margin-bottom: var(--space-8); line-height: 1.6; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.form-group { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-5); }
.form-group label {
  font-size: var(--text-xs); font-weight: 700;
  color: var(--navy); text-transform: uppercase; letter-spacing: .07em;
}
.form-group label .req { color: var(--amber); margin-left: 2px; }
.form-control {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  font-family: var(--ff-body); font-size: var(--text-sm);
  color: var(--ink); background: var(--white);
  transition: border-color var(--dur), box-shadow var(--dur);
  outline: none;
}
.form-control:focus {
  border-color: var(--amber);
  box-shadow: 0 0 0 3px rgba(230,120,37,.1);
}
.form-control::placeholder { color: var(--ghost); }
textarea.form-control { resize: vertical; min-height: 130px; line-height: 1.6; }
select.form-control { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
.form-submit {
  width: 100%; padding: 14px;
  background: var(--amber); color: var(--white);
  border: none; border-radius: var(--r-md);
  font-family: var(--ff-body); font-size: var(--text-base);
  font-weight: 600; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: var(--space-2);
  transition: all var(--dur) var(--ease);
  letter-spacing: .02em;
}
.form-submit:hover {
  background: var(--amber-dk);
  box-shadow: var(--shadow-amber);
  transform: translateY(-2px);
}
.form-note {
  text-align: center; margin-top: var(--space-4);
  font-size: var(--text-xs); color: var(--ghost);
  display: flex; align-items: center; justify-content: center; gap: 5px;
}
.form-note i { color: var(--amber); }

/* Success state */
.form-success {
  display: none; text-align: center; padding: var(--space-10) var(--space-6);
}
.form-success i { font-size: 3rem; color: #22c55e; margin-bottom: var(--space-4); }
.form-success h3 { font-family: var(--ff-display); font-size: var(--text-2xl); color: var(--ink); margin-bottom: var(--space-3); }
.form-success p { color: var(--muted); font-size: var(--text-sm); }

/* ── OFFICES PANEL ───────────────────────────────────── */
.offices-panel { display: flex; flex-direction: column; gap: var(--space-6); }

/* Section divider label */
.offices-group-label {
  display: flex; align-items: center; gap: var(--space-3);
  margin-bottom: var(--space-2);
}
.offices-group-label span {
  font-size: var(--text-xs); font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--muted); white-space: nowrap;
}
.offices-group-label::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}

/* Office card */
.office-card {
  background: var(--white);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  overflow: hidden;
  transition: all var(--dur) var(--ease);
}
.office-card:hover {
  box-shadow: var(--shadow-md);
  border-color: rgba(230,120,37,.3);
  transform: translateY(-3px);
}
.office-card-head {
  display: flex; align-items: center; gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--border);
  background: linear-gradient(90deg, var(--navy-pale) 0%, var(--white) 100%);
}
.office-card-head .office-icon {
  width: 44px; height: 44px; border-radius: var(--r-md);
  background: var(--amber); color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; flex-shrink: 0;
}
.office-card-head .office-icon.icon-navy { background: var(--navy); }
.office-card-head .office-title {
  font-family: var(--ff-display);
  font-size: var(--text-lg); color: var(--navy);
}
.office-card-head .office-badge {
  margin-left: auto;
  font-size: var(--text-xs); font-weight: 700;
  color: var(--amber-dk); background: var(--amber-pale);
  padding: 3px 10px; border-radius: var(--r-pill);
  border: 1px solid rgba(230,120,37,.2);
  text-transform: uppercase; letter-spacing: .06em;
  white-space: nowrap;
}
.office-card-head .office-badge.badge-navy {
  color: var(--navy); background: var(--navy-pale);
  border-color: rgba(28,67,126,.15);
}

.office-card-body { padding: var(--space-5) var(--space-6); }
.office-details { display: flex; flex-direction: column; gap: var(--space-3); }
.office-detail-row {
  display: flex; align-items: flex-start; gap: var(--space-3);
  font-size: var(--text-sm); color: var(--slate);
}
.office-detail-row i {
  width: 18px; text-align: center;
  color: var(--amber); font-size: .8rem; margin-top: 3px;
  flex-shrink: 0;
}
.office-detail-row a { color: var(--slate); transition: color var(--dur); }
.office-detail-row a:hover { color: var(--amber); }

.office-card-foot {
  padding: var(--space-3) var(--space-6) var(--space-5);
  display: flex; gap: var(--space-3); flex-wrap: wrap;
}
.office-action {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--text-xs); font-weight: 600;
  padding: 7px 14px; border-radius: var(--r-sm);
  transition: all var(--dur);
}
.office-action-primary { background: var(--amber-pale); color: var(--amber-dk); border: 1px solid rgba(230,120,37,.2); }
.office-action-primary:hover { background: var(--amber); color: var(--white); }
.office-action-ghost { color: var(--navy); border: 1px solid var(--border); }
.office-action-ghost:hover { background: var(--navy-pale); border-color: var(--navy); }

/* Branch cards — compact 2-col grid */
.branches-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
.branch-card {
  background: var(--white);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  padding: var(--space-5);
  transition: all var(--dur) var(--ease);
  position: relative; overflow: hidden;
}
.branch-card::before {
  content: '';
  position: absolute; top: 0; left: 0; bottom: 0; width: 3px;
  background: var(--amber); transform: scaleY(0); transform-origin: bottom;
  transition: transform var(--dur) var(--ease);
}
.branch-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-color: rgba(230,120,37,.2); }
.branch-card:hover::before { transform: scaleY(1); }
.branch-city {
  font-family: var(--ff-display);
  font-size: var(--text-base); color: var(--navy);
  margin-bottom: var(--space-4);
  display: flex; align-items: center; gap: var(--space-2);
}
.branch-city i { color: var(--amber); font-size: .85rem; }
.branch-details { display: flex; flex-direction: column; gap: var(--space-2); }
.branch-detail-row {
  display: flex; align-items: flex-start; gap: var(--space-2);
  font-size: var(--text-xs); color: var(--muted); line-height: 1.55;
}
.branch-detail-row i { color: var(--amber); font-size: .65rem; margin-top: 4px; flex-shrink: 0; }
.branch-detail-row a { color: var(--muted); transition: color var(--dur); }
.branch-detail-row a:hover { color: var(--amber); }

/* ── MAP SECTION ─────────────────────────────────────── */
.map-section { padding: var(--space-20) 0; background: var(--white); }
.map-tabs {
  display: flex; gap: var(--space-2); flex-wrap: wrap;
  margin-bottom: var(--space-8);
}
.map-tab {
  padding: 9px 20px; border-radius: var(--r-pill);
  font-size: var(--text-sm); font-weight: 600; cursor: pointer;
  border: 1.5px solid var(--border); color: var(--muted);
  transition: all var(--dur) var(--ease);
  display: flex; align-items: center; gap: var(--space-2);
}
.map-tab:hover { border-color: var(--amber); color: var(--amber); background: var(--amber-pale); }
.map-tab.active { background: var(--amber); color: var(--white); border-color: var(--amber); }
.map-tab i { font-size: .8rem; }

.map-frame-wrap {
  border-radius: var(--r-xl); overflow: hidden;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border);
  height: 480px;
}
.map-frame-wrap iframe {
  width: 100%; height: 100%; border: none;
}
.map-info-strip {
  margin-top: var(--space-6);
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: var(--space-4);
}
.map-info-item {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--snow); border-radius: var(--r-md);
  padding: var(--space-4) var(--space-5);
  border: 1px solid var(--border);
}
.map-info-item i { color: var(--amber); font-size: 1rem; width: 20px; text-align: center; }
.map-info-item div strong { display: block; font-size: var(--text-sm); color: var(--ink); }
.map-info-item div span { font-size: var(--text-xs); color: var(--muted); }

/* ── WHY CONTACT BAND ────────────────────────────────── */
.contact-why {
  background: linear-gradient(135deg, var(--navy-dk) 0%, var(--navy) 100%);
  padding: var(--space-16) 0;
  position: relative; overflow: hidden;
}
.contact-why::before {
  content: '';
  position: absolute; right: -60px; bottom: -60px;
  width: 300px; height: 300px; border-radius: 50%;
  background: rgba(230,120,37,.1);
}
.contact-why-grid {
  display: grid; grid-template-columns: repeat(4,1fr);
  gap: var(--space-6); position: relative; z-index: 1;
}
.contact-why-item { text-align: center; }
.contact-why-icon {
  width: 56px; height: 56px; border-radius: var(--r-md);
  background: rgba(230,120,37,.15);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--space-4);
  font-size: 1.3rem; color: var(--amber-lt);
  transition: all var(--dur);
}
.contact-why-item:hover .contact-why-icon { background: var(--amber); color: var(--white); }
.contact-why-item h4 {
  font-family: var(--ff-display);
  font-size: var(--text-base); color: var(--white);
  margin-bottom: var(--space-2);
}
.contact-why-item p { font-size: var(--text-xs); color: rgba(255,255,255,.5); line-height: 1.6; }

/* ── RESPONSIVE ──────────────────────────────────────── */
@media (max-width: 1024px) {

  .map-info-strip { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 960px) {
  .contact-grid { grid-template-columns: 1fr; }
  .contact-form-card { position: static; }
}
@media (max-width: 640px) {
  .branches-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }

  .map-info-strip { grid-template-columns: 1fr; }
  .contact-form-card { padding: var(--space-6) var(--space-5); }
  .hero-quick-contacts { flex-direction: column; }
}

/* ═══════════════════════════════════════════════════════════
   INNER PAGES — Shared styles for About, Mission, WhyUs,
   Services, Air, Sea, Land pages
   ═══════════════════════════════════════════════════════════ */

/* ── COMPACT PAGE HERO (all inner pages) ────────────────── */
.page-hero {
  position: relative;
  background: linear-gradient(108deg, var(--navy-dk) 0%, var(--navy) 60%, rgba(230,120,37,.22) 100%);
  padding: 28px 0 24px;
  overflow: hidden;
}
.page-hero::after {
  content: '';
  position: absolute; right: -60px; top: -60px;
  width: 300px; height: 300px; border-radius: 50%;
  background: rgba(230,120,37,.08); pointer-events: none;
}
.page-hero-inner {
  position: relative; z-index: 1;
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap;
  gap: var(--space-4);
}
.page-hero h1 {
  font-family: var(--ff-display);
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  color: var(--white); line-height: 1.2;
  margin-top: var(--space-2);
}

/* ── BLOG: list grid + cards ─────────────────────────────── */
.px-blog-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6);
}
@media (max-width: 900px) { .px-blog-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .px-blog-grid { grid-template-columns: 1fr; } }
.px-blog-card {
  display: flex; flex-direction: column;
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden;
  transition: all var(--dur) var(--ease);
}
.px-blog-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.px-blog-img { aspect-ratio: 16/10; overflow: hidden; background: var(--fog); }
.px-blog-img img { width: 100%; height: 100%; object-fit: cover; }
.px-blog-body { padding: var(--space-6); display: flex; flex-direction: column; flex: 1; }
.px-blog-cat {
  font-size: var(--text-xs); font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: var(--amber-dk); background: rgba(230,120,37,.1);
  padding: 5px 12px; border-radius: var(--r-pill); display: inline-block; margin-bottom: var(--space-4); width: fit-content;
}
.px-blog-title {
  font-family: var(--ff-display); font-weight: 700; font-size: var(--text-lg);
  color: var(--ink); line-height: 1.35; margin-bottom: var(--space-3);
}
.px-blog-excerpt { font-size: var(--text-sm); color: var(--muted); line-height: 1.65; margin-bottom: var(--space-5); flex: 1; }
.px-blog-meta { font-size: var(--text-xs); color: var(--ghost); display: flex; align-items: center; gap: 10px; margin-bottom: var(--space-4); }
.px-blog-link { font-size: var(--text-sm); font-weight: 700; color: var(--navy); display: inline-flex; align-items: center; gap: 7px; }
.px-blog-card:hover .px-blog-link { color: var(--amber-dk); }
.px-blog-empty { text-align: center; padding: var(--space-10) 0; color: var(--muted); }

/* ── BLOG: single post ───────────────────────────────────── */
.px-blog-post { max-width: 760px; margin: 0 auto; }
.px-blog-post-img { border-radius: var(--r-lg); overflow: hidden; margin-bottom: var(--space-7); box-shadow: var(--shadow-md); }
.px-blog-post-img img { width: 100%; display: block; }
.px-blog-post-title { font-family: var(--ff-display); font-weight: 800; font-size: clamp(1.7rem, 3.5vw, 2.5rem); color: var(--ink); line-height: 1.2; margin-bottom: var(--space-4); }
.px-blog-post-meta { display: flex; align-items: center; gap: 16px; color: var(--muted); font-size: var(--text-sm); margin-bottom: var(--space-7); padding-bottom: var(--space-6); border-bottom: 1px solid var(--border); }
.px-blog-post-body { font-size: var(--text-base); color: var(--slate); line-height: 1.8; }
.px-blog-post-body p { margin-bottom: var(--space-5); }
.px-blog-post-body h2, .px-blog-post-body h3 { font-family: var(--ff-display); color: var(--navy-dk); margin: var(--space-7) 0 var(--space-4); }
.px-blog-post-body img { max-width: 100%; border-radius: var(--r-md); margin: var(--space-5) 0; }
.px-blog-post-body ul, .px-blog-post-body ol { margin: 0 0 var(--space-5) var(--space-6); }
.px-blog-back { display: inline-flex; align-items: center; gap: 8px; font-weight: 600; color: var(--navy); margin-bottom: var(--space-6); }

    .page-hero h1 em {
        color: var(--amber-lt);
        font-style: normal;
    }
.page-hero-badge {
  display: flex; align-items: center; gap: var(--space-2);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--r-md);
  padding: 9px 18px;
  font-size: var(--text-xs); font-weight: 600;
  color: rgba(255,255,255,.8);
}
.page-hero-badge i { color: var(--amber-lt); }

/* ── NUMBER / STAT CARDS (WhyUs, About) ─────────────────── */
.stat-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-8) var(--space-6);
  text-align: center;
  transition: all var(--dur) var(--ease);
  position: relative; overflow: hidden;
}
.stat-card::before {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--amber), var(--amber-lt));
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur) var(--ease);
}
.stat-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.stat-card:hover::before { transform: scaleX(1); }
.stat-card .stat-num {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 4vw, 2.8rem);
  color: var(--navy); line-height: 1;
  margin-bottom: var(--space-2);
}
.stat-card .stat-num span { color: var(--amber); }
.stat-card .stat-lbl {
  font-size: var(--text-sm); color: var(--muted);
  font-weight: 500; line-height: 1.4;
}

/* ── TEAM CARD (About / Leadership) ─────────────────────── */
.team-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-6);
  display: flex; align-items: center; gap: var(--space-4);
  transition: all var(--dur) var(--ease);
}
.team-card:hover {
  box-shadow: var(--shadow-md);
  border-color: rgba(230,120,37,.25);
  transform: translateY(-3px);
}
.team-avatar {
  width: 52px; height: 52px; border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-lt) 100%);
  color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-size: var(--text-lg);
  flex-shrink: 0;
}
.team-info strong {
  display: block; font-size: var(--text-sm);
  font-weight: 700; color: var(--ink);
  margin-bottom: 3px;
}
.team-info span {
  font-size: var(--text-xs); color: var(--muted);
}
.team-info .team-role-badge {
  display: inline-block;
  margin-top: 5px;
  font-size: 10px; font-weight: 700;
  color: var(--amber-dk); background: var(--amber-pale);
  padding: 2px 8px; border-radius: var(--r-pill);
  border: 1px solid rgba(230,120,37,.2);
  text-transform: uppercase; letter-spacing: .05em;
}

/* ── GROUP COMPANY CARD (About) ─────────────────────────── */
.group-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-6) var(--space-6);
  transition: all var(--dur) var(--ease);
  position: relative; overflow: hidden;
}
.group-card::after {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--amber);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur) var(--ease);
}
.group-card:hover {
  box-shadow: var(--shadow-md);
  border-color: rgba(230,120,37,.2);
  transform: translateY(-4px);
}
.group-card:hover::after { transform: scaleX(1); }
.group-card .gc-icon {
  width: 48px; height: 48px; border-radius: var(--r-md);
  background: var(--navy-pale); color: var(--navy);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; margin-bottom: var(--space-4);
  transition: all var(--dur);
}
.group-card:hover .gc-icon { background: var(--amber); color: var(--white); }
.group-card h4 {
  font-family: var(--ff-display);
  font-size: var(--text-base); color: var(--ink);
  margin-bottom: var(--space-2);
}
.group-card p { font-size: var(--text-sm); color: var(--muted); line-height: 1.65; }

/* ── SERVICE FEATURE LIST (service pages) ───────────────── */
.svc-feature-list {
  display: flex; flex-direction: column; gap: var(--space-3);
  margin: var(--space-6) 0;
}
.svc-feature-item {
  display: flex; align-items: flex-start; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--snow);
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  font-size: var(--text-sm); color: var(--slate);
  transition: all var(--dur);
}
.svc-feature-item:hover {
  border-color: var(--amber);
  background: var(--amber-pale);
}
.svc-feature-item i { color: var(--amber); font-size: .8rem; margin-top: 3px; flex-shrink: 0; }

/* ── SERVICE HERO IMAGE ─────────────────────────────────── */
.svc-hero-img {
  border-radius: var(--r-xl); overflow: hidden;
  box-shadow: var(--shadow-lg);
  aspect-ratio: 16/9;
  position: relative;
}
.svc-hero-img img { width: 100%; height: 100%; object-fit: cover; }
.svc-hero-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(18,45,87,.7) 0%, transparent 60%);
  display: flex; align-items: flex-end;
  padding: var(--space-6);
}
.svc-hero-img-overlay .svc-tag {
  display: inline-flex; align-items: center; gap: var(--space-2);
  background: var(--amber); color: var(--white);
  padding: 8px 18px; border-radius: var(--r-pill);
  font-size: var(--text-sm); font-weight: 700;
}

/* ── MISSION PILLAR CARD ────────────────────────────────── */
.pillar-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-8) var(--space-6);
  text-align: center;
  transition: all var(--dur) var(--ease);
}
.pillar-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-5px);
  border-color: rgba(230,120,37,.2);
}
.pillar-card:hover .px-icon-box-amber { background: var(--amber); color: var(--white); }
.pillar-icon-wrap { display: flex; justify-content: center; margin-bottom: var(--space-5); }
.pillar-card h3 {
  font-family: var(--ff-display);
  font-size: var(--text-xl); color: var(--navy);
  margin-bottom: var(--space-3);
}
.pillar-card p { font-size: var(--text-sm); color: var(--muted); line-height: 1.75; }

/* ── TIMELINE (WhyUs / About history) ──────────────────── */
.timeline { display: flex; flex-direction: column; gap: 0; }
.timeline-item {
  display: flex; gap: var(--space-5);
  padding-bottom: var(--space-8);
  position: relative;
}
.timeline-item:last-child { padding-bottom: 0; }
.timeline-left {
  display: flex; flex-direction: column; align-items: center;
  flex-shrink: 0; width: 44px;
}
.timeline-dot {
  width: 44px; height: 44px; border-radius: var(--r-md);
  background: var(--amber); color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-size: var(--text-sm);
  font-weight: 700; flex-shrink: 0; z-index: 1;
  box-shadow: 0 0 0 4px var(--amber-pale);
}
.timeline-line {
  width: 2px; flex: 1; background: var(--border);
  margin-top: var(--space-2);
}
.timeline-item:last-child .timeline-line { display: none; }
.timeline-body {
  padding-top: var(--space-2);
  padding-bottom: var(--space-4);
}
.timeline-body strong {
  display: block; font-size: var(--text-base);
  font-weight: 700; color: var(--ink);
  margin-bottom: var(--space-2);
}
.timeline-body p { font-size: var(--text-sm); color: var(--muted); line-height: 1.7; }

/* ── AIRLINE PARTNER GRID ───────────────────────────────── */
.airline-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: var(--space-3);
}
.airline-pill {
  display: flex; align-items: center; justify-content: center; gap: var(--space-2);
  padding: 10px 14px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: var(--white);
  font-size: var(--text-xs); font-weight: 600; color: var(--slate);
  transition: all var(--dur) var(--ease);
  text-align: center;
}
.airline-pill i { color: var(--amber); font-size: .75rem; }
.airline-pill:hover { border-color: var(--amber); color: var(--amber); background: var(--amber-pale); box-shadow: var(--shadow-xs); }
.airline-pill.award { border-color: rgba(230,120,37,.3); background: var(--amber-pale); color: var(--amber-dk); }

/* ── RESPONSIVE INNER PAGES ─────────────────────────────── */
@media (max-width: 960px) {
  .page-hero-inner { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 640px) {
  .airline-grid { grid-template-columns: repeat(3, 1fr); }
  .team-card { flex-direction: column; text-align: center; }
}

/* ═══════════════════════════════════════════════════════════
   RATE INQUIRY PAGE — 


   ═══════════════════════════════════════════════════════════ */

/* Rate type tabs */
.rate-tabs {
  display: flex; gap: var(--space-2);
}
.rate-tab {
  flex: 1; padding: 11px var(--space-5);
  border-radius: var(--r-md);
  font-family: var(--ff-body); font-size: var(--text-sm); font-weight: 600;
  border: 2px solid var(--border); color: var(--muted);
  background: var(--white); cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: var(--space-2);
  transition: all var(--dur) var(--ease);
}
.rate-tab:hover { border-color: var(--amber); color: var(--amber); }
.rate-tab.active { background: var(--amber); color: var(--white); border-color: var(--amber); box-shadow: var(--shadow-amber); }

/* Form card */
.rate-form-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--space-8) var(--space-8);
  box-shadow: var(--shadow-sm);
}
.rate-form-title {
  font-family: var(--ff-display);
  font-size: var(--text-xl); color: var(--ink);
  margin-bottom: var(--space-2);
  display: flex; align-items: center; gap: var(--space-3);
}
.rate-form-title i { color: var(--amber); }
.rate-form-sub { font-size: var(--text-sm); color: var(--muted); margin-bottom: var(--space-6); }
.rate-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4);
}

.form-note {
  text-align: center; font-size: var(--text-xs); color: var(--ghost);
  display: flex; align-items: center; justify-content: center; gap: 5px; flex-wrap: wrap;
}
.form-success {
  display: none; text-align: center;
  padding: var(--space-12) var(--space-6);
}
.form-success i { font-size: 3rem; color: #22c55e; margin-bottom: var(--space-4); display: block; }
.form-success h3 { font-family: var(--ff-display); font-size: var(--text-2xl); color: var(--ink); margin-bottom: var(--space-3); }
.form-success p { color: var(--muted); font-size: var(--text-sm); }

/* Quick contact strip */
.rate-contact-strip {
  display: flex; flex-direction: column; gap: var(--space-4);
  background: var(--navy-pale); border-radius: var(--r-lg);
  padding: var(--space-6); border: 1px solid rgba(28,67,126,.1);
}
.rate-contact-item {
  display: flex; align-items: flex-start; gap: var(--space-3);
  font-size: var(--text-sm);
}
.rate-contact-item i {
  color: var(--amber); font-size: 1rem; margin-top: 2px; width: 20px;
  flex-shrink: 0; text-align: center;
}
.rate-contact-item strong { display: block; color: var(--navy); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 2px; }
.rate-contact-item a, .rate-contact-item span { color: var(--slate); }
.rate-contact-item a:hover { color: var(--amber); }

/* Why cards (reused) */
.why-card {
  display: flex; align-items: flex-start; gap: var(--space-4);
  padding: var(--space-5) var(--space-5);
  background: var(--white); border-radius: var(--r-md);
  border: 1px solid var(--border);
  transition: all var(--dur) var(--ease);
}
.why-card:hover { box-shadow: var(--shadow-sm); border-color: rgba(230,120,37,.2); }
.why-card:hover .px-icon-box-amber { background: var(--amber); color: var(--white); }
.why-card h4 { font-family: var(--ff-display); font-size: var(--text-base); color: var(--ink); margin-bottom: var(--space-2); }
.why-card p { font-size: var(--text-sm); color: var(--muted); line-height: 1.65; }

/* FAQ accordion */
.faq-list { max-width: 780px; margin: 0 auto; display: flex; flex-direction: column; gap: var(--space-3); }
.faq-item { border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; transition: box-shadow var(--dur); }
.faq-item:hover { box-shadow: var(--shadow-sm); }
.faq-q {
  width: 100%; text-align: left;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  font-family: var(--ff-body); font-size: var(--text-base); font-weight: 600;
  color: var(--ink); background: var(--white); cursor: pointer;
  border: none; transition: background var(--dur), color var(--dur);
}
.faq-q:hover, .faq-q[aria-expanded="true"] { background: var(--amber-pale); color: var(--amber-dk); }
.faq-icon { transition: transform var(--dur) var(--ease); flex-shrink: 0; font-size: .8rem; color: var(--amber); }
.faq-q[aria-expanded="true"] .faq-icon { transform: rotate(180deg); }
.faq-a {
  padding: 0 var(--space-6);
  font-size: var(--text-sm); color: var(--muted); line-height: 1.75;
  max-height: 0; overflow: hidden;
  transition: max-height .35s ease, padding .35s ease;
}
.faq-a.open { max-height: 400px; padding: var(--space-4) var(--space-6) var(--space-5); }

/* ═══════════════════════════════════════════════════════════
   TRACKING PAGE — tracking.aspx
   ═══════════════════════════════════════════════════════════ */

/* Main tracking input */
.track-tool-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
}
.track-tool-input-wrap { position: relative; }
.track-tool-icon {
  position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
  color: var(--muted); font-size: 1rem;
}
.track-tool-input {
  width: 100%; padding: 15px 16px 15px 46px;
  border: 2px solid var(--border); border-radius: var(--r-md);
  font-family: var(--ff-body); font-size: var(--text-base); color: var(--ink);
  background: var(--snow); outline: none;
  transition: border-color var(--dur), background var(--dur), box-shadow var(--dur);
}
.track-tool-input:focus {
  border-color: var(--amber); background: var(--white);
  box-shadow: 0 0 0 3px rgba(230,120,37,.1);
}
.track-tool-input::placeholder { color: var(--ghost); }

/* Result card */
.track-result {
  margin-top: var(--space-6);
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}
.track-result-header {
  display: flex; align-items: center; gap: var(--space-3);
  margin-bottom: var(--space-5); padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border);
}
.track-result-header strong { display: block; font-size: var(--text-base); color: var(--ink); }
.track-result-header span { font-size: var(--text-xs); color: var(--muted); }

/* Status steps */
.track-status-steps { display: flex; flex-direction: column; gap: var(--space-3); }
.track-step {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--r-md); font-size: var(--text-sm);
}
.track-step.done { background: rgba(34,197,94,.08); color: #15803d; }
.track-step.active { background: var(--amber-pale); color: var(--amber-dk); font-weight: 600; }
.track-step.pending { background: var(--fog); color: var(--ghost); }
.track-step i { width: 18px; text-align: center; }

/* Status legend */
.track-status-legend { display: flex; flex-direction: column; gap: var(--space-4); }
.status-legend-item {
  display: flex; align-items: flex-start; gap: var(--space-3);
  font-size: var(--text-sm);
}
.status-dot {
  width: 12px; height: 12px; border-radius: 50%;
  flex-shrink: 0; margin-top: 4px;
}
.status-legend-item strong { display: block; color: var(--ink); font-weight: 600; margin-bottom: 2px; }
.status-legend-item span { color: var(--muted); line-height: 1.5; }

/* Responsive */
@media (max-width: 640px) {
  .rate-grid { grid-template-columns: 1fr; }
  .rate-form-card { padding: var(--space-6) var(--space-4); }
  .track-tool-card { padding: var(--space-5); }
  .rate-tabs { flex-direction: column; }
}

/* ═══════════════════════════════════════════════════════════
   FIX: Value-Added Service Cards — equal height, clean layout
   ═══════════════════════════════════════════════════════════ */

/* Make all grid rows in a px-grid-3 equal height */
.px-grid-3 {
  align-items: stretch;
}

/* Feature card — flex column so content fills height evenly */
.px-feature-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Push any trailing button/link to the bottom */
.px-feature-card > .px-btn,
.px-feature-card > a.px-btn {
  margin-top: auto;
}

/* Bottom accent line — always visible, not just on hover */
.px-feature-card::after {
  transform: scaleX(1);
  opacity: .35;
}
.px-feature-card:hover::after {
  opacity: 1;
}

/* Value-added card icon — fixed size, no shrink */
.px-feature-card .px-icon-box {
  flex-shrink: 0;
}

/* Value-added card title — consistent spacing */
.px-feature-card h4.px-heading {
  margin-top: 0;
  line-height: 1.25;
}

/* Body text — fill remaining space, then button sits at bottom */
.px-feature-card .px-body {
  flex: 1;
}

/* Tighten icon top spacing when no image above */
.px-feature-card .px-icon-box-amber + .px-heading,
.px-feature-card .px-icon-box-amber + h3,
.px-feature-card .px-icon-box-amber + h4 {
  margin-top: 0;
}

/* Cards with image on top — image fixed height so all cards align */
.px-feature-card .svc-hero-img {
  flex-shrink: 0;
  height: 190px;
  overflow: hidden;
  border-radius: var(--r-md);
}
.px-feature-card .svc-hero-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}


/* ═══════════════════════════════════════════════════════════
   VALUE-ADDED SERVICE CARDS (Services.html)
   Clean 3-column grid, equal height, icon left-aligned
   ═══════════════════════════════════════════════════════════ */

.va-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.va-svc-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  overflow: hidden;
  transition: transform 240ms cubic-bezier(.22,.68,0,1.2),
              box-shadow 240ms ease,
              border-color 240ms ease;
}

/* Amber left accent line — always visible */
.va-svc-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 3px;
  background: var(--amber);
  border-radius: 14px 0 0 14px;
  opacity: 0;
  transition: opacity 240ms ease;
}

.va-svc-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(17,24,39,.10);
  border-color: rgba(230,120,37,.3);
}

.va-svc-card:hover::before {
  opacity: 1;
}

/* Icon circle */
.va-svc-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: var(--amber-pale);
  color: var(--amber);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
  transition: background 240ms ease, color 240ms ease;
}

.va-svc-card:hover .va-svc-icon {
  background: var(--amber);
  color: var(--white);
}

/* Text body */
.va-svc-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.va-svc-body h4 {
  font-family: var(--ff-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.25;
  margin: 0;
}

.va-svc-body p {
  font-size: 0.875rem;
  color: var(--muted);
  line-height: 1.72;
  margin: 0;
}

/* Responsive */
@media (max-width: 960px) {
  .va-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .va-grid { grid-template-columns: 1fr; }
}


/* ── SERVICE TEASER LINK CARDS (explore other services) ── */
.va-teaser-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 36px 28px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  text-decoration: none;
  color: inherit;
  transition: transform 240ms cubic-bezier(.22,.68,0,1.2),
              box-shadow 240ms ease,
              border-color 240ms ease;
  position: relative;
  overflow: hidden;
}
.va-teaser-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--amber), var(--amber-lt));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 240ms ease;
}
.va-teaser-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(17,24,39,.10);
  border-color: rgba(230,120,37,.3);
}
.va-teaser-card:hover::before { transform: scaleX(1); }
.va-teaser-card:hover .px-icon-box-amber {
  background: var(--amber);
  color: var(--white);
}
.va-teaser-card .px-heading { margin-top: 16px; margin-bottom: 8px; }
.va-teaser-card .px-body { font-size: 0.875rem; color: var(--muted); }

/* ═══════════════════════════════════════════════════════════
   ASPX SERVER STATUS MESSAGES
   Used by RateInquiry.aspx.vb and Tracking.aspx.vb
   ═══════════════════════════════════════════════════════════ */

.ri-status-success {
  display: block;
  margin-top: 16px;
  padding: 14px 18px;
  background: rgba(34,197,94,.08);
  border: 1px solid rgba(34,197,94,.25);
  border-radius: 10px;
  color: #15803d;
  font-size: .875rem;
  font-weight: 500;
  line-height: 1.6;
}

.ri-status-error {
  display: block;
  margin-top: 16px;
  padding: 14px 18px;
  background: rgba(220,38,38,.06);
  border: 1px solid rgba(220,38,38,.2);
  border-radius: 10px;
  color: #dc2626;
  font-size: .875rem;
  font-weight: 500;
  line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════
   RATEINQUIRY.ASPX — Additional styles for ported HTML detail
   ═══════════════════════════════════════════════════════════ */

.ri-intro-block { margin-bottom: 24px; }

.ri-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

@media (max-width: 960px) {
  .ri-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .ri-grid-4 { grid-template-columns: 1fr; }
}



  /* HERO */
    .hero {
      position: relative;
      min-height: 94vh;
      display: flex; align-items: center;
      overflow: hidden;
    }
    .hero-slide {
      position: absolute; inset: 0;
      opacity: 0;
      background-size: cover; background-position: center;
      transform: scale(1.1);
      transition-property: opacity, transform;
      transition-duration: 1.1s, 8.5s;
      transition-timing-function: var(--ease-out), linear;
    }
    .hero-slide.active {
      opacity: 1;
      transform: scale(1);
    }
    /* The very first slide is marked .active directly in the
       static HTML (so there's no flash-of-unstyled-content
       before JS runs) — but that means there's no property
       *change* for the transition above to animate from on
       first paint. A transition only plays when a value
       changes after the initial render, never on the first
       frame itself. A @keyframes animation, by contrast, does
       play from its `from` state immediately, so it covers
       that first-load case; every later slide change goes
       through the transition above as normal. */
    .hero-slide.active:first-child {
      animation: heroFirstDrift 8.5s var(--ease-out) forwards;
    }
    @keyframes heroFirstDrift {
      from { transform: scale(1.1); }
      to   { transform: scale(1); }
    }
    .hero-slide::after {
      content: '';
      position: absolute; inset: 0;
      background: linear-gradient(
        108deg,
        rgba(18,45,87,.92) 0%,
        rgba(28,67,126,.78) 50%,
        rgba(230,120,37,.22) 100%
      );
    }
    .hero-slides-bg {
      position: absolute; inset: 0; z-index: 0;
    }

    .hero-content {
      position: relative; z-index: 2;
      padding-bottom: 100px;
      max-width: 680px;
    }
    .hero-eyebrow {
      display: inline-flex; align-items: center; gap: 8px;
      background: rgba(255,255,255,.1);
      border: 1px solid rgba(255,255,255,.2);
      backdrop-filter: blur(8px);
      color: var(--amber-lt);
      padding: 6px 16px; border-radius: var(--r-pill);
      font-size: var(--text-xs); font-weight: 600;
      letter-spacing: .1em; text-transform: uppercase;
      margin-bottom: var(--space-5);
    }
    .hero-eyebrow::before {
      content: ''; width: 6px; height: 6px;
      border-radius: 50%; background: var(--amber-lt); flex-shrink: 0;
    }
    .hero-h1 {
      font-family: var(--ff-display);
      font-size: clamp(2.4rem, 5.5vw, 4rem);
      font-weight: 800; line-height: 1.08; letter-spacing: -.02em;
      color: var(--white);
      margin-bottom: var(--space-5);
    }
        .hero-h1 em {
            color: var(--amber-lt);
            font-style: normal;
        }
    .hero-p {
      font-size: var(--text-lg); line-height: 1.7;
      color: rgba(255,255,255,.8);
      margin-bottom: var(--space-8);
      max-width: 540px;
    }
    .hero-cta { display: flex; flex-wrap: wrap; gap: var(--space-3); }

    /* ── CINEMATIC HERO TEXT — masked line reveal ──────────
       Each text block sits inside an overflow-hidden mask
       (.hero-mask). JS toggles .hero-out (exit) on the parent
       .hero-content, swaps the slide's content once the exit
       transition ends, then removes .hero-out — re-triggering
       the entrance on every slide change, not just on page
       load. Elements are <span>s (for inline mask nesting in
       the <h1>) but laid out as blocks. */
    .hero-mask {
      overflow: hidden;
      display: block;
    }
    .hero-h1 .hero-mask { display: block; }

    .hero-eyebrow {
      display: inline-flex;
      transition: transform 1.3s var(--ease-out), opacity 1.3s var(--ease-out);
      will-change: transform;
    }
    .hero-line,
    .hero-p {
      display: block;
      transition: transform 1.3s var(--ease-out), opacity 1.3s var(--ease-out);
      will-change: transform;
    }
    .hero-cta {
      display: flex; flex-wrap: wrap; gap: var(--space-3);
      transition: transform 1.3s var(--ease-out), opacity 1.3s var(--ease-out);
      will-change: transform;
    }

    .hero-eyebrow { transition-delay: .08s; }
    .hero-h1 .hero-mask:nth-of-type(1) .hero-line { transition-delay: .22s; }
    .hero-h1 .hero-mask:nth-of-type(2) .hero-line { transition-delay: .4s; }
    .hero-p { transition-delay: .62s; }
    .hero-cta { transition-delay: .82s; }

    /* Entrance state (default) */
    .hero-eyebrow, .hero-line, .hero-p, .hero-cta {
      transform: translateY(0%);
      opacity: 1;
    }
    /* Exit-and-reset state: text is pushed below its mask and
       faded, ready to rise back in once content is swapped. */
    .hero-content.hero-out .hero-eyebrow,
    .hero-content.hero-out .hero-line,
    .hero-content.hero-out .hero-p,
    .hero-content.hero-out .hero-cta {
      transform: translateY(115%);
      opacity: 0;
      transition-delay: 0s;
      transition-duration: .55s;
    }

    /* Stats bar */
    .hero-stats {
      position: absolute; bottom: 0; left: 0; right: 0;
      z-index: 3; background: rgba(18,45,87,.88);
      backdrop-filter: blur(16px);
      border-top: 1px solid rgba(255,255,255,.08);
    }
    .hero-stats-inner {
      display: grid; grid-template-columns: repeat(4,1fr);
    }
    .hero-stat {
      padding: var(--space-5) var(--space-6);
      border-right: 1px solid rgba(255,255,255,.08);
      text-align: center;
    }
    .hero-stat:last-child { border-right: none; }
    .hero-stat-num {
      font-family: var(--ff-display);
      font-size: 1.9rem; color: var(--white); line-height: 1;
    }
    .hero-stat-num span { color: var(--amber-lt); }
    .hero-stat-label {
      font-size: var(--text-xs); color: rgba(255,255,255,.5);
      text-transform: uppercase; letter-spacing: .08em;
      margin-top: 5px;
    }
    /* Slider dots */
    .hero-dots {
      position: absolute; bottom: 78px; left: 50%;
      transform: translateX(-50%);
      z-index: 4; display: flex; gap: 7px;
    }
    .hero-dot {
      width: 7px; height: 7px; border-radius: 50%;
      background: rgba(255,255,255,.3); cursor: pointer;
      transition: all var(--dur) var(--ease);
    }
    .hero-dot.active { background: var(--amber); width: 22px; border-radius: 4px; }

    /* ── INTRO ────────────────────────────────────────── */
    .intro-gul-tag {
      display: inline-flex; align-items: center; gap: 7px;
      background: var(--navy-pale); color: var(--navy);
      font-size: var(--text-xs); font-weight: 700;
      padding: 6px 14px; border-radius: var(--r-pill);
      border: 1px solid rgba(28,67,126,.15);
      margin-top: var(--space-6);
    }
    .intro-gul-tag i { color: var(--amber); }

    /* ── WHY US (homepage stacked layout) ───────────────── */
    .why-card-stack {
      display: flex; flex-direction: column; gap: var(--space-4);
      padding: var(--space-8) var(--space-6);
      background: var(--white); border-radius: var(--r-lg);
      border: 1px solid var(--border);
      position: relative; overflow: hidden;
      transition: all var(--dur) var(--ease);
    }
    .why-card-stack:hover {
      box-shadow: var(--shadow-md);
      transform: translateY(-4px);
      border-color: rgba(230,120,37,.25);
    }
    .why-card-stack:hover .px-icon-box-amber { background: var(--amber); color: var(--white); }
    .why-card-stack h4 {
      font-family: var(--ff-display);
      font-weight: 700;
      font-size: var(--text-lg); color: var(--ink);
    }
    .why-card-stack p { font-size: var(--text-sm); color: var(--muted); line-height: 1.7; }

    /* ── AWARD BAND ───────────────────────────────────── */
    .award-band {
      background: linear-gradient(135deg, var(--navy-dk) 0%, var(--navy) 100%);
      padding: var(--space-16) 0;
      position: relative; overflow: hidden;
    }
    .award-band::after {
      content: '';
      position: absolute; inset: 0;
      background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.025' fill-rule='evenodd'%3E%3Cpath d='M0 40L40 0H20L0 20M40 40V20L20 40'/%3E%3C/g%3E%3C/svg%3E");
    }
    .award-inner { position: relative; z-index: 1; }
    .award-grid {
      display: grid; grid-template-columns: 1fr 1fr;
      gap: var(--space-12); align-items: start;
      margin-top: var(--space-10);
    }
    .award-carrier-grid {
      display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-3);
    }
    .award-carrier {
      background: rgba(255,255,255,.07);
      border: 1px solid rgba(255,255,255,.1);
      border-radius: var(--r-md);
      padding: var(--space-4) var(--space-3);
      text-align: center;
      font-size: var(--text-xs); font-weight: 600;
      color: rgba(255,255,255,.65);
      transition: all var(--dur);
    }
    .award-carrier:hover { background: rgba(230,120,37,.15); border-color: var(--amber); color: var(--amber-lt); }
    .award-carrier i { display: block; font-size: 1.4rem; margin-bottom: 5px; color: var(--amber); }
    .award-highlights { display: flex; flex-direction: column; gap: var(--space-4); }
    .award-highlight-item {
      display: flex; align-items: center; gap: var(--space-4);
      background: rgba(255,255,255,.05); border-radius: var(--r-md);
      padding: var(--space-4) var(--space-5);
      border: 1px solid rgba(255,255,255,.08);
    }
    .award-highlight-item i { font-size: 1.5rem; color: var(--amber); flex-shrink: 0; }
    .award-highlight-item strong { display: block; color: var(--white); font-size: var(--text-sm); }
    .award-highlight-item span { color: rgba(255,255,255,.5); font-size: var(--text-xs); }

    /* ── GLOBAL REACH ─────────────────────────────────── */
    .reach-band {
      background: var(--snow);
      padding: var(--space-20) 0;
    }
    .reach-img {
      position: relative;
      border-radius: var(--r-xl); overflow: hidden;
      box-shadow: var(--shadow-lg);
    }
    .reach-img img { width: 100%; display: block; }
    .reach-overlay {
      position: absolute; bottom: 0; left: 0; right: 0;
      background: linear-gradient(0deg, rgba(18,45,87,.9) 0%, transparent 100%);
      padding: var(--space-8) var(--space-6) var(--space-6);
      display: flex; gap: var(--space-6);
    }
    .reach-stat {
      text-align: center;
    }
    .reach-stat .num {
      font-family: var(--ff-display);
      font-size: var(--text-3xl); color: var(--white); line-height: 1;
    }
    .reach-stat .num span { color: var(--amber-lt); }
    .reach-stat .lbl {
      font-size: var(--text-xs); color: rgba(255,255,255,.55);
      text-transform: uppercase; letter-spacing: .07em; margin-top: 4px;
    }

    /* ── VALUE-ADDED ──────────────────────────────────── */
    .va-card {
      padding: var(--space-6); border-radius: var(--r-lg);
      background: var(--white); border: 1px solid var(--border);
      display: flex; gap: var(--space-4);
      position: relative; overflow: hidden;
      transition: all var(--dur) var(--ease);
    }
    .va-card:hover {
      box-shadow: var(--shadow-md);
      transform: translateY(-3px);
      border-color: rgba(230,120,37,.2);
    }
    .va-card:hover .px-icon-box-amber { background: var(--amber); color: var(--white); }
    .va-card h4 {
      font-family: var(--ff-display);
      font-size: var(--text-base); color: var(--ink);
      margin-bottom: var(--space-2);
    }
    .va-card p { font-size: var(--text-sm); color: var(--muted); line-height: 1.7; }

    @media (max-width: 960px) {
      .hero-stats-inner { grid-template-columns: repeat(2,1fr); }
      .award-grid { grid-template-columns: 1fr; }
      .award-carrier-grid { grid-template-columns: repeat(3,1fr); }
    }
    @media (max-width: 640px) {
      .hero-stats-inner { grid-template-columns: repeat(2,1fr); }
      .award-carrier-grid { grid-template-columns: repeat(2,1fr); }
      .reach-overlay { flex-wrap: wrap; gap: var(--space-4); }
    }




.px-bento-grid {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    grid-auto-rows: 148px;
    gap: 18px;
    grid-template-areas:
        "s1 s2 img img"
        "cta cta img img"
        "g1 g2 g3 g4";
}

.px-bento-box {
    border-radius: 0;
    padding: var(--space-6);
    position: relative;
    overflow: hidden;
    border: 1.5px solid transparent;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition: transform .25s ease, box-shadow .25s ease;
}

    .px-bento-box:hover {
        transform: translateY(-4px);
    }

.px-bento-kicker {
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    opacity: .85;
    border-radius: var(--r-md);
}

.px-bento-num {
    font-family: var(--ff-display);
    font-size: clamp(34px,4vw,46px);
    line-height: 1;
}

.px-bento-label {
    font-size: 13.5px;
    font-weight: 600;
    opacity: .85;
    margin-top: 6px;
}

.px-bento-title {
    font-family: var(--ff-body);
    font-weight: 700;
    font-size: 17px;
}

.px-bento-desc {
    font-size: 13px;
    opacity: .8;
    line-height: 1.5;
    margin-top: 4px;
}

.px-bento-arrow {
    position: absolute;
    right: 18px;
    bottom: 18px;
    width: 34px;
    height: 34px;
    border-radius: var(--r-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
}

.pb-s1 {
    grid-area: s1;
    background: var(--amber);
    color: #fff;
    border-color: var(--amber-dk);
}

    .pb-s1 .px-bento-arrow {
        background: rgba(255,255,255,.22);
        color: #fff;
    }

.pb-s2 {
    grid-area: s2;
    background: var(--navy);
    color: #fff;
    border-color: var(--navy-dark);
}

    .pb-s2 .px-bento-arrow {
        background: rgba(255,255,255,.16);
        color: #fff;
    }

.pb-img {
    grid-area: img;
    padding: 0;
    border-radius: 0;
    border-color: var(--line);
}

    .pb-img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

.pb-img-tag {
    position: absolute;
    left: 16px;
    bottom: 16px;
    background: rgba(13,26,51,.78);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    padding: 7px 14px;
    border-radius: var(--r-md);
    backdrop-filter: blur(4px);
}

.pb-cta {
    grid-area: cta;
    background: var(--navy-dark);
    color: #fff;
    cursor: pointer;
    border-color: #000;
}

    .pb-cta .px-bento-arrow {
        background: var(--amber);
        color: #fff;
    }

.pb-g1 {
    grid-area: g1;
    background: var(--paper);
    color: var(--navy-dark);
    border-color: var(--line);
}

.pb-g2 {
    grid-area: g2;
    background: #fff;
    color: var(--navy-dark);
    border-color: var(--navy-dark);
}

.pb-g3 {
    grid-area: g3;
    background: var(--navy);
    color: #fff;
    border-color: var(--navy-dark);
}

    .pb-g3 .px-bento-arrow {
        background: rgba(255,255,255,.16);
        color: #fff;
    }

.pb-g4 {
    grid-area: g4;
    background: var(--amber);
    color: #fff;
    cursor: pointer;
    border-color: var(--amber-dk);
}

    .pb-g4 .px-bento-arrow {
        background: rgba(255,255,255,.22);
        color: #fff;
    }

@media (max-width:900px) {
    .px-bento-grid {
        grid-template-columns: repeat(2,1fr);
        grid-auto-rows: 140px;
        grid-template-areas:
            "s1 s2"
            "img img"
            "img img"
            "cta cta"
            "g1 g2"
            "g3 g4";
    }
}

@media (max-width:560px) {
    .px-bento-grid {
        grid-template-columns: 1fr;
        grid-auto-rows: 130px;
        grid-template-areas: "s1" "s2" "img" "img" "cta" "g1" "g2" "g3" "g4";
    }

    .px-bento-box {
        padding: var(--space-5);
    }
}
