/* =========================================================
   AVIO — Redesign · Shared Design System
   Brand: #0802A3 (blue) · #62FF2A (neon green) · #F8FAF8
   ========================================================= */

:root{
  --blue:       #0802A3;
  --blue-700:   #1d18ba;
  --blue-50:    #efeefb;
  --green:      #62FF2A;
  --green-700:  #4ed81a;
  --green-50:   #e8ffdc;
  --yellow:     #E8FF00;
  --yellow-700: #c7db00;
  /* Tweakable accents (overridable live via the Tweaks panel) */
  --pill-bg:    #E8FF00;
  --pill-ink:   #0a0a14;
  --pill-border:#c7db00;
  --slab-bg:    #62FF2A;
  --slab-ink:   #0a0a14;
  --ink:        #0a0a14;
  --ink-70:     rgba(10,10,20,0.72);
  --ink-50:     rgba(10,10,20,0.5);
  --ink-30:     rgba(10,10,20,0.18);
  --ink-10:     rgba(10,10,20,0.08);
  --line:       rgba(10,10,20,0.16);
  --line-strong:rgba(10,10,20,0.32);
  /* Palette: dark blue + neon green + black + white (no grey).
     White base broken up by black & blue blocks for contrast. */
  --bg:         #ffffff;
  --bg-tint:    #ffffff;
  --bg-dark:    #0a0a0f;   /* black band */
  --bg-deep:    #0A0A12;
  --bg-card:    #ffffff;

  --radius-xs: 6px;
  --radius-sm: 10px;
  --radius:    14px;
  --radius-lg: 22px;
  --radius-pill: 999px;

  --shadow-1: 0 1px 0 rgba(10,10,20,0.05), 0 10px 28px -14px rgba(10,10,20,0.18);
  --shadow-2: 0 2px 0 rgba(10,10,20,0.06), 0 30px 70px -26px rgba(10,10,20,0.30);

  --font-sans: 'Geist','Inter Tight',ui-sans-serif,system-ui,sans-serif;
  --font-mono: 'Geist Mono','JetBrains Mono',ui-monospace,monospace;

  --container: 1280px;
  --gutter: clamp(20px, 4vw, 56px);
}

/* Reset */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'ss01','cv11';
}
img,svg{ display:block; max-width:100%; }
button{ font: inherit; color: inherit; background: none; border:0; cursor:pointer; }
a{ color: inherit; text-decoration:none; }
input,select,textarea{ font: inherit; color: inherit; }
::selection{ background: var(--green); color: var(--blue); }

/* Typography utilities */
.eyebrow{
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-70);
  display: inline-flex; align-items:center; gap:8px;
}
.eyebrow::before{
  content:""; width:6px; height:6px; background: var(--green);
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(98,255,42,0.18);
}
.eyebrow.is-light{ color: rgba(255,255,255,0.72); }

h1,h2,h3,h4,h5{ margin:0; font-weight: 600; letter-spacing:-0.02em; line-height:1.05; }
.h-display{ font-size: clamp(48px, 7.2vw, 116px); letter-spacing:-0.035em; line-height:0.96; font-weight: 600; }
.h1{ font-size: clamp(40px, 5.4vw, 84px); letter-spacing:-0.03em; line-height:1.0; font-weight: 600; }
.h2{ font-size: clamp(30px, 3.6vw, 56px); letter-spacing:-0.025em; line-height:1.05; font-weight: 600; }
.h3{ font-size: clamp(22px, 2.2vw, 32px); letter-spacing:-0.02em; line-height:1.15; font-weight: 600; }
.h4{ font-size: clamp(18px, 1.4vw, 22px); letter-spacing:-0.015em; line-height:1.25; font-weight: 600; }
.lead{ font-size: clamp(17px, 1.25vw, 20px); line-height:1.55; color: var(--ink-70); }
.small{ font-size: 13px; color: var(--ink-70); }
.mono{ font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; }
.text-blue{ color: var(--blue); }
.text-green{ color: var(--green-700); }
.text-mute{ color: var(--ink-70); }

/* Layout */
.container{
  width:100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* NAVBAR */
.nav{
  position: sticky; top:0; left:0; right:0; z-index: 80;
  background: var(--blue);
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.nav-inner{
  display:flex; align-items:center; justify-content: space-between;
  height: 72px;
}
.nav-logo{ display:flex; align-items:center; gap:10px; }
.nav-logo svg{ height: 34px; width:auto; }
.nav-logo .dot{
  width:7px; height:7px; border-radius:50%; background: var(--green);
  box-shadow: 0 0 0 4px rgba(98,255,42,0.18);
}
.nav-links{ display:flex; align-items:center; gap: 6px; }
.nav-link{
  position: relative;
  padding: 8px 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-70);
  border-radius: var(--radius-pill);
  transition: color .2s ease, background .2s ease;
}
.nav-link:hover{ color: var(--ink); background: var(--ink-10); }
.nav-link.active{ color: var(--blue); background: var(--blue-50); }
.nav-cta-wrap{ display:flex; align-items:center; gap: 10px; }
.nav-burger{ display:none; }

@media (max-width: 900px){
  .nav-links{
    display: none;
    position: absolute;
    top: 72px; left: 0; right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 16px var(--gutter) 24px;
    background: var(--bg);
    border-bottom: 1px solid var(--line);
    box-shadow: var(--shadow-2);
  }
  .nav-links.is-open{ display: flex; }
  .nav-link{
    padding: 16px 18px;
    font-size: 16px;
    border-radius: var(--radius);
    text-align: left;
  }
  .nav-burger{
    display:inline-flex; align-items:center; justify-content:center;
    width:42px; height:42px; border-radius: 12px;
    border: 1px solid var(--line-strong);
    color: var(--ink);
  }
  .nav-burger[aria-expanded="true"]{
    background: var(--blue); color: #fff; border-color: var(--blue);
  }
}

/* BUTTONS */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  height: 48px; padding: 0 22px;
  border-radius: var(--radius-pill);
  font-size: 14px; font-weight: 600; letter-spacing: -0.005em;
  border: 1px solid transparent;
  transition: transform .2s cubic-bezier(.2,.7,.2,1), background .2s ease, color .2s ease, border-color .2s ease;
  white-space: nowrap;
}
.btn:hover{ transform: translateY(-1px); }
.btn-primary{ background: var(--blue); color: #fff; }
.btn-primary:hover{ background: var(--blue-700); }
.btn-accent{ background: var(--green); color: var(--blue); border-color: var(--green-700); }
.btn-accent:hover{ background: var(--green-700); color:#fff; }
.btn-ghost{ background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn-ghost:hover{ background: var(--ink); color: #fff; border-color: var(--ink); }
.btn-inverse{ background: #fff; color: var(--blue); }
.btn-inverse:hover{ background: var(--green); color: var(--blue); }
.btn-sm{ height: 40px; padding: 0 16px; font-size: 13px; }
.btn-lg{ height: 56px; padding: 0 28px; font-size: 15px; }
.btn .arrow{ width: 16px; height: 16px; }

/* PILLS / CHIPS */
.chip{
  display:inline-flex; align-items:center; gap:8px;
  padding: 6px 12px; border-radius: var(--radius-pill);
  background: var(--bg-card); border:1px solid var(--line);
  font-size: 12px; font-weight: 500;
  font-family: var(--font-mono); letter-spacing: 0.04em;
}
.chip.is-green{ background: var(--pill-bg); border-color: var(--pill-border); color: var(--pill-ink); font-weight: 600; }
.chip.is-blue{ background: var(--blue-50); border-color: rgba(8,2,163,0.16); color: var(--blue); }

/* SECTION */
.section{ padding: clamp(80px, 9vw, 140px) 0; }
.section-tight{ padding: clamp(60px, 6vw, 96px) 0; }
.section-header{ display:flex; flex-direction: column; gap: 16px; max-width: 760px; margin-bottom: clamp(36px, 4vw, 64px); }
.section-header.center{ text-align: center; margin-left:auto; margin-right:auto; align-items:center; }

/* CARDS */
.card{
  background: var(--bg-card);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  padding: 28px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.card:hover{ box-shadow: var(--shadow-1); border-color: var(--blue); }

/* GLOBAL DECOR */
.grid-bg{
  background-image:
    linear-gradient(var(--ink-10) 1px, transparent 1px),
    linear-gradient(90deg, var(--ink-10) 1px, transparent 1px);
  background-size: 56px 56px;
}

/* FOOTER */
.footer{
  background: var(--blue);
  color: #fff;
  padding: clamp(72px, 8vw, 120px) 0 32px;
  position: relative;
  overflow: hidden;
}
.footer .container{ position: relative; z-index:2; }
.footer-grid{
  display:grid; grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 48px 32px;
}
.footer-brand h2{ font-size: clamp(40px, 5vw, 72px); line-height:0.95; letter-spacing:-0.035em; color:#fff; }
.footer-brand p{ color: rgba(255,255,255,0.6); max-width: 420px; margin-top: 16px; }
.footer-col h4{
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: 18px;
  font-weight: 500;
}
.footer-col ul{ list-style: none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.footer-col a{ color: rgba(255,255,255,0.8); font-size:14px; transition: color .2s; }
.footer-col a:hover{ color: var(--green); }
.footer-bottom{
  margin-top: 56px; padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.12);
  display:flex; justify-content: space-between; align-items: center;
  font-size: 12px; color: rgba(255,255,255,0.5);
  font-family: var(--font-mono); letter-spacing: 0.04em;
}
.footer-bottom a:hover{ color: var(--green); }
.footer-watermark{
  position: absolute; left: 0; right: 0; bottom: -8%;
  text-align: center;
  font-size: clamp(120px, 22vw, 360px);
  font-weight: 600;
  letter-spacing: -0.06em;
  line-height: 1;
  color: rgba(255,255,255,0.04);
  pointer-events: none;
  user-select: none;
  z-index: 1;
}
@media (max-width: 900px){
  .footer-grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px){
  .footer-grid{ grid-template-columns: 1fr; }
}

/* =========================================================
   INTRO ANIMATION â€” Curtain reveal
   1) Blue panel with AVIO logo (green) fades in
   2) Green curtain rises from bottom to cover the screen
   3) Whole intro slides up off the viewport
   ========================================================= */
.intro{
  position: fixed; inset: 0; z-index: 200;
  background: var(--blue);
  overflow: hidden;
  transform: translateY(0);
  transition: transform 0.8s cubic-bezier(0.77, 0, 0.175, 1);
  will-change: transform;
}
.intro.is-out{ transform: translateY(-100%); }

/* Logo center */
.intro-logo{
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%) translateY(14px);
  width: clamp(220px, 30vw, 460px);
  z-index: 3;
  opacity: 0;
  animation: introLogoIn 0.55s cubic-bezier(.2,.8,.2,1) forwards;
  animation-delay: 0.05s;
}
.intro-logo svg{ width: 100%; height: auto; display: block; }
@keyframes introLogoIn{
  to{ opacity: 1; transform: translate(-50%, -50%) translateY(0); }
}

/* Corner meta */
.intro-meta{
  position: absolute; inset: 0;
  padding: clamp(20px, 3vw, 44px);
  pointer-events: none;
  z-index: 4;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: rgba(255,255,255,0.65);
  opacity: 0;
  animation: introMetaIn 0.6s ease forwards;
  animation-delay: 0.25s;
}
@keyframes introMetaIn{ to{ opacity: 1; } }
.intro-meta > span{ position: absolute; }
.intro-meta-tl{ top: clamp(20px, 3vw, 44px); left: clamp(20px, 3vw, 44px); }
.intro-meta-tr{ top: clamp(20px, 3vw, 44px); right: clamp(20px, 3vw, 44px); }
.intro-meta-bl{ bottom: clamp(20px, 3vw, 44px); left: clamp(20px, 3vw, 44px); }
.intro-meta-br{
  bottom: clamp(20px, 3vw, 44px); right: clamp(20px, 3vw, 44px);
  color: var(--green);
  font-variant-numeric: tabular-nums;
}

/* Green curtain rising from bottom */
.intro-curtain{
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 0;
  background: var(--green);
  z-index: 2;
  animation: introCurtain 0.6s cubic-bezier(.77, 0, .175, 1) forwards;
  animation-delay: 0.5s;
  will-change: height;
}
@keyframes introCurtain{
  0%{ height: 0; }
  100%{ height: 100%; }
}

.no-intro .intro{ display:none; }
.intro-active{ overflow: hidden; }
.intro-active body{ overflow: hidden; }

/* =========================================================
   HOME â€” HERO
   ========================================================= */
.hero{
  position: relative;
  padding: clamp(48px, 6vw, 104px) 0 clamp(60px, 8vw, 120px);
  overflow: hidden;
}
.hero::before{ display: none; }
.hero .container{ position: relative; z-index: 1; }
.hero-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: clamp(28px, 4vw, 64px);
  align-items: end;
}
.hero-head{ display:flex; flex-direction: column; gap: 28px; }
.hero-meta{ display:flex; align-items:center; gap: 16px; flex-wrap: wrap; }
.hero-title{
  font-size: clamp(56px, 9.2vw, 160px);
  line-height: 0.92;
  letter-spacing: -0.04em;
  font-weight: 600;
}
.hero-title em{
  font-style: normal;
  position: relative;
  display: inline-block;
  color: var(--slab-ink);
  background: var(--slab-bg);
  padding: 0.02em 0.16em 0.06em;
  border-radius: 10px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  box-shadow: 0 8px 0 -4px rgba(0,0,0,0.18);
}
.hero-actions{ display:flex; align-items:center; gap: 14px; flex-wrap: wrap; }
.hero-right{ display: flex; flex-direction: column; gap: 20px; align-items: flex-end; }
.hero-stat{
  border: 1px solid var(--line);
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  padding: 22px 24px;
  width: 100%;
  max-width: 320px;
  display:flex; flex-direction: column; gap: 6px;
}
.hero-stat .num{
  font-size: clamp(36px, 4vw, 52px); font-weight: 600; letter-spacing:-0.03em; line-height: 1;
  color: var(--blue);
  font-variant-numeric: tabular-nums;
}
.hero-stat .label{ font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--ink-70); }

.hero-strip{
  margin-top: clamp(40px, 5vw, 72px);
  background: var(--blue);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: 26px clamp(22px, 3vw, 40px);
  display: flex; align-items: center; gap: 36px;
  overflow: hidden;
  position: relative;
}
.hero-strip::after{
  content:""; position:absolute; right:-40px; top:-40px; width:200px; height:200px;
  background: radial-gradient(circle, rgba(98,255,42,0.22), transparent 70%);
  pointer-events:none;
}
.hero-strip .label{ font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--green); white-space: nowrap; position: relative; z-index:1; }
.hero-strip .strip{ flex: 1; display:flex; gap: clamp(28px, 5vw, 64px); align-items:center; overflow: hidden; position: relative; z-index:1; }
.hero-strip .strip .text-mute{ color: rgba(255,255,255,0.55); }
.hero-strip img{ height: 26px; width: auto; opacity: 0.95; }

@media (max-width: 900px){
  .hero-grid{ grid-template-columns: 1fr; }
  .hero-right{ align-items: flex-start; flex-direction: row; gap: 14px; flex-wrap: wrap; }
  .hero-stat{ flex: 1; min-width: 200px; }
}

/* =========================================================
   HERO VISUAL â€” Live route map
   ========================================================= */
.hero-visual{
  width: 100%;
  background: var(--blue);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: 22px;
  overflow: hidden;
  position: relative;
}
.hero-visual::before{
  content:""; position: absolute; inset: 0;
  background:
    radial-gradient(700px 300px at 80% -20%, rgba(98,255,42,0.18), transparent 60%),
    radial-gradient(500px 300px at -10% 110%, rgba(98,255,42,0.10), transparent 60%);
  pointer-events: none;
}
.hv-head{
  position: relative; z-index: 2;
  display:flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em;
  color: rgba(255,255,255,0.7);
  margin-bottom: 14px;
}
.hv-eyebrow{ display:inline-flex; align-items:center; gap: 8px; }
.hv-dot{
  width: 6px; height: 6px; border-radius: 50%; background: var(--green);
  box-shadow: 0 0 0 4px rgba(98,255,42,0.18);
  animation: pulse 1.6s ease infinite;
}
.hv-time{ color: rgba(255,255,255,0.5); }
.hv-map{
  position: relative; z-index: 2;
  width: 100%; height: auto;
  display: block;
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.08);
  margin-bottom: 14px;
}
.hv-quote{
  position: relative; z-index: 2;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius);
  padding: 16px 18px;
}
.hv-quote-row{
  display:flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.14em;
  color: rgba(255,255,255,0.6); text-transform: uppercase;
}
.hv-quote-live{ display:inline-flex; align-items:center; gap: 6px; color: var(--green); }
.hv-quote-price{
  margin: 10px 0 14px;
  font-size: 44px; font-weight: 600; letter-spacing: -0.03em; line-height: 1;
  display:flex; align-items: baseline; gap: 6px;
  font-variant-numeric: tabular-nums;
}
.hv-quote-price .cur{ font-size: 14px; color: rgba(255,255,255,0.55); font-weight: 500; letter-spacing: 0; }
.hv-quote-meta{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.10);
}
.hv-quote-meta .lbl{
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  margin-bottom: 4px;
}
.hv-quote-meta .val{ font-size: 14px; font-weight: 500; }
.hv-quote-meta .text-green-light{ color: var(--green); }
@media (max-width: 900px){
  .hero-visual{ max-width: 540px; }
}

/* =========================================================
   SKETCH STYLE â€” hand-drawn doodle illustrations
   Used across all page heros for an airfreight site vibe.
   ========================================================= */
.sketch{
  stroke: var(--blue);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}
.sketch-fill-green{ fill: var(--green); }
.sketch-fill-white{ fill: #fff; }
.sketch-fill-blue{ fill: var(--blue); }
.sketch-soft{ stroke: var(--ink-30); }
.sketch-accent{ stroke: var(--green-700); }
.sketch-thick{ stroke-width: 2.6; }
.sketch-thin{ stroke-width: 1.4; }
.sketch-dash{ stroke-dasharray: 4 5; }

/* Filter: subtle wobble */
.sketch-wobble{
  filter: url(#wobble);
}

/* Page hero with right-side illustration */
.page-head-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: clamp(28px, 4vw, 64px);
  align-items: center;
}
.page-head-grid .page-head-text > h1{
  font-size: clamp(48px, 6.4vw, 88px);
  line-height: 1.06;
}
.page-head-art{
  width: 100%;
  height: auto;
  display: block;
}
@media (max-width: 900px){
  .page-head-grid{ grid-template-columns: 1fr; }
  .page-head-art{ max-width: 460px; }
}

/* Floating airfreight doodles in section backgrounds */
.section-doodle{
  position: absolute;
  pointer-events: none;
  opacity: 0.6;
}

/* =========================================================
   EXPRESS SOLUTIONS â€” Airfreight visual cards
   ========================================================= */
.solutions-grid{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.solution-card{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.solution-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
  border-color: var(--line-strong);
}
.sol-visual{
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  position: relative;
}
.sol-visual svg{ width: 100%; height: 100%; display: block; }
.sol-body{
  padding: 28px;
  display:flex; flex-direction: column; gap: 14px;
  flex: 1;
}
.sol-meta{
  display:flex; align-items:center; gap: 12px; flex-wrap: wrap;
}
.solution-card .sol-body h3{ font-size: 24px; letter-spacing: -0.02em; line-height: 1.15; }
.sol-bullets{
  margin: 4px 0 0;
  padding: 0; list-style: none;
  display:flex; flex-direction: column; gap: 8px;
}
.sol-bullets li{
  position: relative;
  padding-left: 22px;
  font-size: 14px;
  color: var(--ink-70);
  line-height: 1.5;
}
.sol-bullets li::before{
  content:""; position: absolute;
  left: 0; top: 10px;
  width: 12px; height: 1px; background: var(--green-700);
}
@media (max-width: 900px){ .solutions-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   FEATURE GRID â€” value props
   ========================================================= */
.features{
  background: #0a0a0f;
  color: #fff;
  background-image:
    radial-gradient(620px 360px at 86% -10%, rgba(98,255,42,0.14), transparent 60%),
    radial-gradient(rgba(255,255,255,0.07) 1px, transparent 1px);
  background-size: auto, 24px 24px;
}
.features .h2{ color:#fff; }
.features .lead{ color: rgba(255,255,255,0.7); }
.features .eyebrow{
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.82);
}
.feature-grid{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.feature-card{
  background: var(--bg-card);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  padding: 32px;
  display:flex; flex-direction: column; gap: 18px;
  min-height: 280px;
  transition: transform .25s ease, background .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.feature-card:hover{ transform: translateY(-3px); box-shadow: var(--shadow-1); border-color: var(--blue); }
.feature-card.is-accent{ background: var(--blue); color: #fff; border-color: var(--blue); }
.feature-card.is-accent .feature-num{ color: var(--green); }
.feature-card.is-accent .feature-desc{ color: rgba(255,255,255,0.72); }
.feature-card.is-accent:hover{ border-color: var(--green); }
.feature-card.is-green{ background: var(--green); color: var(--ink); border-color: var(--green-700); }
.feature-card.is-green .feature-num{ color: var(--blue); }
.feature-card.is-green .feature-desc{ color: rgba(8,2,16,0.7); }
.feature-card.is-green:hover{ border-color: var(--blue); }
.feature-card.is-yellow{ background: var(--yellow); color: var(--ink); border-color: var(--yellow-700); }
.feature-card.is-yellow .feature-num{ color: var(--blue); }
.feature-card.is-yellow .feature-desc{ color: rgba(8,2,16,0.72); }
.feature-card.is-yellow:hover{ border-color: var(--blue); }
.feature-num{
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-70);
}
.feature-card .feature-title{ font-size: 26px; font-weight: 600; letter-spacing:-0.02em; line-height:1.1; margin-top: auto; }
.feature-card .feature-desc{ font-size: 14px; color: var(--ink-70); }
@media (max-width: 900px){ .feature-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .feature-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   STATS
   ========================================================= */
.stats{
  background: var(--blue);
  color: #fff;
  padding: clamp(60px, 7vw, 110px) 0;
}
.stats-grid{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
.stat{
  display:flex; flex-direction: column; gap: 8px;
  border-top: 1px solid rgba(255,255,255,0.16);
  padding-top: 22px;
}
.stat .num{
  font-size: clamp(48px, 5.2vw, 84px);
  font-weight: 600; letter-spacing: -0.04em; line-height: 0.95;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.stat .num .green{ color: var(--green); }
.stat .label{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.65);
}
.stat .desc{ font-size: 14px; color: rgba(255,255,255,0.7); max-width: 240px; }
@media (max-width: 900px){ .stats-grid{ grid-template-columns: 1fr 1fr; } }

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.testimonials-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.testimonial{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 32px;
  display:flex; flex-direction:column; gap: 24px;
  min-height: 320px;
}
.testimonial-quote{
  font-size: 20px; line-height: 1.4; letter-spacing: -0.01em;
  font-weight: 500;
}
.testimonial-quote::before{ content: "\201C"; color: var(--green-700); font-weight: 600; margin-right: 2px; }
.testimonial-author{
  margin-top: auto;
  display:flex; align-items:center; gap: 14px;
}
.testimonial-avatar{
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--blue); color: #fff;
  display:flex; align-items:center; justify-content:center;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.02em;
}
.testimonial-name{ font-weight: 600; font-size: 14px; }
.testimonial-role{ font-size: 13px; color: var(--ink-70); }
@media (max-width: 900px){ .testimonials-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   CALCULATOR / RATES
   ========================================================= */
.calc-section{
  background: var(--bg);
  padding: clamp(56px, 6vw, 96px) 0;
}
.calc-shell{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(380px, 460px);
  gap: 24px;
  align-items: start;
}
.calc-form{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 3vw, 40px);
}
.calc-form-head{
  display:flex; align-items:center; justify-content: space-between;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.calc-form-head h3{ font-size: 20px; font-weight: 600; }
.calc-row-2{
  display:grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.calc-row-3{
  display:grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px;
}
.calc-row-qty-wt{
  display:grid; grid-template-columns: 120px 1fr; gap: 12px;
}
.field{
  display:flex; flex-direction: column; gap: 6px;
}
.field label{
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-70);
  display:flex; align-items:center; justify-content: space-between;
}
.field label .unit{ color: var(--ink-50); font-weight: 400; }
.field input, .field select{
  width: 100%;
  height: 50px;
  padding: 0 14px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  transition: border-color .15s ease, background .15s ease;
  -webkit-appearance: none; appearance: none;
}
.field select{
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5L6 6.5L11 1.5' stroke='%230a0a14' stroke-width='1.6' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}
.field input:focus, .field select:focus{
  outline: none;
  border-color: var(--blue);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(8,2,163,0.10);
}
.field input::placeholder{ color: var(--ink-50); }

.pkg-card{
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  margin-top: 12px;
  background: var(--bg);
}
.pkg-card-head{
  display:flex; align-items:center; justify-content: space-between;
  margin-bottom: 14px;
}
.pkg-card-head .lbl{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-70);
  display:flex; align-items:center; gap: 8px;
}
.pkg-card-head .lbl::before{
  content: ""; width: 6px; height: 6px; background: var(--green); border-radius: 50%;
}
.pkg-del{
  width: 32px; height: 32px; border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-70);
  transition: background .15s ease, color .15s ease;
}
.pkg-del:hover{ background: #fee; color: #c00; }
.pkg-del:disabled{ opacity: 0.3; cursor: not-allowed; }
.pkg-row-stack{ display:flex; flex-direction:column; gap: 10px; }

.calc-add-pkg{
  margin-top: 14px;
  width: 100%;
  height: 44px;
  border-radius: var(--radius-sm);
  border: 1px dashed var(--line-strong);
  background: transparent;
  color: var(--ink);
  font-size: 13px;
  font-weight: 500;
  display:flex; align-items:center; justify-content:center; gap:8px;
  transition: background .15s, border-color .15s, color .15s;
}
.calc-add-pkg:hover{
  background: var(--blue-50);
  border-color: var(--blue);
  color: var(--blue);
}

.calc-cta-row{
  display: flex; gap: 10px; margin-top: 20px;
}
.calc-cta-row .btn{ flex: 1; }

/* RESULT PANEL */
.quote-panel{
  background: var(--blue);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: clamp(28px, 3vw, 36px);
  position: sticky;
  top: 96px;
  z-index: 2;
  overflow: hidden;
  border: 1px solid var(--blue);
}
.quote-panel-head{
  display:flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  padding-bottom: 14px; margin-bottom: 20px;
  border-bottom: 1px solid rgba(255,255,255,0.16);
}
.quote-panel-head .live{
  display:flex; align-items:center; gap: 6px; color: var(--green);
}
.quote-panel-head .live::before{
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--green);
  box-shadow: 0 0 0 3px rgba(98,255,42,0.25);
  animation: pulse 1.6s ease infinite;
}
@keyframes pulse{
  0%,100%{ opacity:1; }
  50%{ opacity:0.4; }
}
.quote-route{
  display:flex; align-items:center; gap: 12px;
  margin-bottom: 20px;
  font-size: 13px;
}
.quote-route .iata{
  font-family: var(--font-mono);
  font-size: 28px; font-weight: 500; letter-spacing: -0.02em;
  color: #fff;
}
.quote-route .arrow{
  flex: 1;
  height: 1px; background: rgba(255,255,255,0.2);
  position: relative;
}
.quote-route .arrow::after{
  content: "\2708";
  position: absolute; right: -2px; top: 50%; transform: translateY(-50%);
  color: var(--green); font-size: 14px;
  background: var(--blue); padding-left: 6px;
}
.quote-price-row{
  display:flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 4px;
}
.quote-price{
  font-size: clamp(48px, 5vw, 64px);
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 1;
  color: #fff;
  font-variant-numeric: tabular-nums;
  display:flex; align-items: baseline; gap: 6px;
}
.quote-price .cur{ font-size: 0.45em; color: rgba(255,255,255,0.6); font-weight: 500; }
.quote-retail{
  font-family: var(--font-mono); font-size: 12px; color: rgba(255,255,255,0.55);
  text-decoration: line-through;
}
.quote-savings{
  display:inline-flex; align-items:center; gap: 6px;
  margin-top: 12px;
  padding: 6px 12px;
  background: var(--green);
  color: var(--blue);
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 600;
  font-family: var(--font-mono); letter-spacing: 0.04em;
}
.quote-summary{
  margin-top: 22px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.16);
  display:flex; flex-direction: column; gap: 10px;
}
.quote-summary-row{
  display:flex; justify-content: space-between; align-items: center;
  font-size: 13px;
  color: rgba(255,255,255,0.75);
}
.quote-summary-row strong{ color: #fff; font-weight: 600; font-variant-numeric: tabular-nums; }
.quote-cta{ margin-top: 24px; display:flex; flex-direction: column; gap: 10px; }
.quote-empty{
  color: rgba(255,255,255,0.55);
  font-size: 14px;
  line-height: 1.55;
  padding: 24px 0;
  text-align: center;
}

@media (max-width: 1000px){
  .calc-shell{ grid-template-columns: 1fr; }
  .quote-panel{ position: static; }
}
@media (max-width: 560px){
  .calc-row-3{ grid-template-columns: 1fr 1fr; }
  .calc-row-qty-wt{ grid-template-columns: 1fr 1fr; }
}

/* RATES â€” Carrier comparison cards */
.compare-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
  padding-top: 14px;
}
.compare-card{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  display:flex; flex-direction:column; gap: 12px;
  position: relative;
}
.compare-card.is-best{
  border-color: var(--green-700);
  background: linear-gradient(180deg, #f4ffec, #fff 70%);
}
.compare-card.is-best::after{
  content:"BEST RATE"; position: absolute; top: -10px; right: 12px;
  background: var(--green); color: var(--blue);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em;
  padding: 4px 8px; border-radius: 6px; font-weight: 600;
}
.compare-card .logo{
  height: 40px; display:inline-flex; align-items: center; justify-content: center;
  background: var(--blue); border-radius: var(--radius-sm);
  padding: 0 14px; align-self: flex-start;
}
.compare-card .logo img{ max-height: 22px; max-width: 80px; width: auto; object-fit: contain; }
.compare-card .price{
  font-size: clamp(18px, 2.5vw, 24px); font-weight: 600; letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  color: var(--blue);
}
.compare-card .retail{ font-family: var(--font-mono); font-size: 11px; color: var(--ink-50); text-decoration: line-through; }
.compare-card .eta{ font-size: 12px; color: var(--ink-70); font-family: var(--font-mono); letter-spacing: 0.04em; }
@media (max-width: 900px){ .compare-grid{ grid-template-columns: 1fr 1fr 1fr; } }
@media (max-width: 560px){ .compare-grid{ grid-template-columns: 1fr 1fr; } }

/* TRACKING */
.track-box{
  background: var(--blue);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: clamp(28px, 4vw, 48px);
  position: relative;
  overflow: hidden;
}
.track-form{
  display:flex; gap: 10px; margin-top: 18px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-pill);
  padding: 6px;
}
.track-form input{
  flex: 1; background: transparent; border: 0; padding: 0 18px; color: #fff;
  font-size: 14px;
}
.track-form input:focus{ outline: none; }
.track-form input::placeholder{ color: rgba(255,255,255,0.4); }

/* PAGE HEADERS */
.page-head{
  padding: clamp(48px, 6vw, 96px) 0 clamp(28px, 4vw, 56px);
  border-bottom: 1px solid var(--line);
}
.page-head h1{
  font-size: clamp(48px, 7vw, 96px);
  letter-spacing: -0.04em;
  line-height: 1.08;
  font-weight: 600;
}
.page-head h1 em{
  display: inline-block;
  line-height: 1;
  padding: 0.06em 0.18em 0.1em;
  vertical-align: baseline;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.page-head .lead{ max-width: 640px; margin-top: 20px; }

/* CONTACT */
.contact-grid{
  display:grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}
.contact-form{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 3vw, 40px);
}
.contact-form .field{ margin-bottom: 16px; }
.contact-form textarea{
  width: 100%;
  min-height: 140px;
  padding: 14px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  font-size: 15px;
  resize: vertical;
}
.contact-form textarea:focus{
  outline: none;
  border-color: var(--blue);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(8,2,163,0.10);
}
.contact-side{ display:flex; flex-direction: column; gap: 16px; }
.contact-card{
  background: var(--blue);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: 28px;
}
.contact-card h3{ font-size: 24px; margin-bottom: 8px; }
.contact-card p{ color: rgba(255,255,255,0.7); font-size: 14px; }
.contact-meta{
  display:grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.contact-meta-item{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 20px;
}
.contact-meta-item .lbl{
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-70); margin-bottom: 6px;
}
.contact-meta-item .val{ font-size: 16px; font-weight: 500; color: var(--ink); }
@media (max-width: 900px){
  .contact-grid{ grid-template-columns: 1fr; }
}

/* CTA SECTION */
.cta{
  background: var(--blue);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.cta-inner{
  padding: clamp(80px, 9vw, 140px) 0;
  text-align: center;
  position: relative; z-index: 2;
}
.cta h2{
  font-size: clamp(48px, 6vw, 96px);
  letter-spacing: -0.04em;
  line-height: 1;
  font-weight: 600;
  margin-bottom: 24px;
}
.cta h2 em{ font-style: normal; color: var(--green); }
.cta .lead{ color: rgba(255,255,255,0.7); max-width: 600px; margin: 0 auto 32px; }
.cta-actions{ display:flex; align-items:center; justify-content:center; gap: 12px; flex-wrap: wrap; }

/* MARQUEE */
.marquee{
  background: var(--blue);
  color: #fff;
  padding: 28px 0;
  border-top: 1px solid rgba(255,255,255,0.12);
  border-bottom: 1px solid rgba(255,255,255,0.12);
  overflow: hidden;
}
.marquee-track{
  display:flex; gap: 48px;
  animation: marquee 28s linear infinite;
  white-space: nowrap;
  width: max-content;
}
.marquee span{
  font-size: clamp(40px, 5.6vw, 88px);
  font-weight: 600;
  letter-spacing: -0.03em;
  display:flex; align-items: center; gap: 48px;
}
.marquee span::after{
  content:"\2022"; font-size: 0.4em; color: var(--green); opacity: 0.6;
}
@keyframes marquee{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}

/* REVEAL ON SCROLL */
.reveal{
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
  /* Pure-CSS failsafe: even if JS/IntersectionObserver never fires,
     content is forced visible after ~1.8s so nothing can stay hidden. */
  animation: revealFailsafe 0.01s linear 1.8s forwards;
}
.reveal.in{ opacity: 1 !important; transform: none !important; animation: none; }
@keyframes revealFailsafe{ to{ opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity: 1 !important; transform: none !important; animation: none; }
}

/* RATE PAGE â€” process steps */
.steps{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
}
.step{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
}
.step .n{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; color: var(--green-700);
  margin-bottom: 18px;
}
.step h4{ margin-bottom: 6px; }
.step p{ font-size: 13.5px; color: var(--ink-70); }
@media (max-width: 900px){ .steps{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .steps{ grid-template-columns: 1fr; } }

/* OPTIMIZATION â€” feature blocks */
.opt-grid{
  display:grid; grid-template-columns: repeat(12, 1fr); gap: 16px;
}
.opt-block{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 3vw, 40px);
  display:flex; flex-direction: column; gap: 16px;
  min-height: 280px;
}
.opt-block.span-7{ grid-column: span 7; }
.opt-block.span-5{ grid-column: span 5; }
.opt-block.span-6{ grid-column: span 6; }
.opt-block.span-12{ grid-column: span 12; }
.opt-block.is-blue{ background: var(--blue); color: #fff; border-color: var(--blue); }
.opt-block.is-blue .opt-num{ color: var(--green); }
.opt-block.is-blue p{ color: rgba(255,255,255,0.7); }
.opt-block.is-green{ background: var(--green); color: var(--blue); border-color: var(--green-700); }
.opt-num{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-70);
}
.opt-block h3{ font-size: clamp(26px, 2.4vw, 36px); letter-spacing: -0.02em; line-height: 1.1; }
@media (max-width: 900px){
  .opt-block.span-7, .opt-block.span-5, .opt-block.span-6{ grid-column: span 12; }
}

/* FAQ */
.faq{
  border-top: 1px solid var(--line);
}
.faq-item{
  border-bottom: 1px solid var(--line);
  padding: 24px 0;
}
.faq-q{
  display:flex; justify-content: space-between; align-items: center;
  cursor: pointer;
  width: 100%;
  text-align: left;
  font-size: clamp(18px, 1.6vw, 22px);
  font-weight: 500;
  letter-spacing: -0.01em;
  padding: 0;
}
.faq-q .icon{
  width: 36px; height: 36px; border-radius: 50%;
  background: #fff;
  border: 1px solid var(--line-strong);
  display:inline-flex; align-items:center; justify-content:center;
  transition: background .2s, transform .2s;
  flex-shrink: 0;
  margin-left: 16px;
}
.faq-item.open .faq-q .icon{ background: var(--blue); color: #fff; transform: rotate(45deg); }
.faq-a{
  max-height: 0; overflow: hidden;
  transition: max-height .35s ease, padding-top .25s ease;
  color: var(--ink-70);
  max-width: 720px;
  font-size: 15px;
  line-height: 1.6;
}
.faq-item.open .faq-a{ max-height: 400px; padding-top: 16px; }

/* LEGAL */
.legal-content{
  max-width: 760px;
  font-size: 15px;
  line-height: 1.7;
  color: var(--ink-70);
}
.legal-content h2{ color: var(--ink); margin-top: 40px; margin-bottom: 14px; font-size: 24px; }
.legal-content h3{ color: var(--ink); margin-top: 24px; margin-bottom: 8px; font-size: 18px; }
.legal-content p, .legal-content li{ margin-bottom: 12px; }
.legal-content ul{ padding-left: 22px; }

/* TRACK RESULTS */
.track-timeline{
  display:flex; flex-direction: column; gap: 0;
  margin-top: 28px;
}
.track-step{
  display:flex; gap: 18px; align-items: flex-start;
  padding: 16px 0;
  position: relative;
}
.track-step::before{
  content:""; position: absolute; left: 11px; top: 36px; bottom: -16px;
  width: 1px; background: rgba(255,255,255,0.2);
}
.track-step:last-child::before{ display: none; }
.track-step .dot{
  width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0;
  background: rgba(255,255,255,0.15);
  border: 2px solid rgba(255,255,255,0.25);
}
.track-step.done .dot{ background: var(--green); border-color: var(--green); }
.track-step.current .dot{
  background: #fff; border-color: var(--green);
  box-shadow: 0 0 0 4px rgba(98,255,42,0.3);
}
.track-step .lbl{ font-size: 14px; font-weight: 600; color: #fff; }
.track-step .meta{ font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; color: rgba(255,255,255,0.6); margin-top: 2px; }

/* hide print stuff */
@media print{
  .nav, .footer, .intro{ display: none !important; }
}

/* =========================================================
   TRUSTPILOT INTEGRATION
   ========================================================= */

/* Hero chip â€” Trustpilot */
.chip-trustpilot{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px 5px 8px;
  background: #fff;
  border: 1px solid rgba(0,182,122,0.35);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink);
  text-decoration: none;
  transition: border-color 0.18s, box-shadow 0.18s;
}
.chip-trustpilot:hover{
  border-color: #00B67A;
  box-shadow: 0 0 0 3px rgba(0,182,122,0.12);
}
.chip-trustpilot svg{ flex-shrink: 0; }

/* Trustpilot aggregate bar */
.tp-bar{
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 18px 24px;
  background: #fff;
  border: 1px solid rgba(0,182,122,0.25);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: var(--ink);
  flex-wrap: wrap;
  transition: border-color 0.18s, box-shadow 0.18s;
  margin-bottom: 8px;
}
.tp-bar:hover{
  border-color: #00B67A;
  box-shadow: 0 4px 20px rgba(0,182,122,0.10);
}
.tp-logo{
  width: 96px; height: auto; flex-shrink: 0;
}
.tp-stars{
  display: flex; gap: 3px; align-items: center; flex-shrink: 0;
}
.tp-stars svg{ width: 22px; height: 22px; }
.tp-info{
  display: flex; flex-direction: column; gap: 2px;
}
.tp-score{
  font-size: 20px; font-weight: 700; color: var(--ink); line-height: 1;
  letter-spacing: -0.02em;
}
.tp-label{
  font-size: 13px; font-weight: 400; color: var(--ink-50);
}
.tp-count{
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.08em; color: var(--ink-50);
  text-transform: uppercase;
}
.tp-cta{
  margin-left: auto;
  font-size: 13px; font-weight: 600; color: #00B67A;
  white-space: nowrap;
}
@media(max-width:640px){
  .tp-bar{ gap: 12px; padding: 14px 16px; }
  .tp-cta{ display: none; }
  .tp-logo{ width: 76px; }
}

/* =========================================================
   BOLD-BUT-LIGHT PASS â€” added contrast, color blocks, fixes
   ========================================================= */

/* Page-head heros get a faint blueprint grid so they're not flat white */
.page-head{
  position: relative;
  overflow: hidden;
}
.page-head::before{ display: none; }
.page-head .container{ position: relative; z-index: 1; }

/* Page-head highlight slab â€” match hero treatment (used by rates/contact/shipping) */
.page-head h1 em{
  background: var(--slab-bg) !important;
  color: var(--slab-ink) !important;
  border-radius: 10px !important;
  padding: 0.02em 0.18em 0.08em !important;
  box-shadow: 0 8px 0 -4px rgba(0,0,0,0.18);
}

/* Crisper definition on the main white cards */
.solution-card,
.testimonial,
.calc-form,
.contact-form,
.opt-block,
.step,
.contact-meta-item,
.compare-card{ border-color: var(--line-strong); }

/* Eyebrow chip â€” make it read as a small badge for more presence */
.eyebrow{
  background: var(--bg-card);
  border: 1px solid var(--line-strong);
  padding: 6px 12px;
  border-radius: var(--radius-pill);
}
.eyebrow.is-light{
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
}

/* Section headers: accent rule under the eyebrow row for rhythm */
.h2 + .lead, .section-header .lead{ color: var(--ink-70); }

/* SHIPPING â€” 3-step progress bar (had no styles) */
.ship-step{
  display:flex; align-items:center; gap: 12px;
  padding: 16px 18px;
  background: var(--bg-card);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  transition: border-color .2s ease, background .2s ease;
}
.ship-step-num{
  width: 30px; height: 30px; flex-shrink: 0;
  border-radius: 50%;
  display:inline-flex; align-items:center; justify-content:center;
  font-family: var(--font-mono); font-size: 12px; font-weight: 600;
  background: var(--ink-10); color: var(--ink-70);
}
.ship-step-lbl{ font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }
.ship-step.is-active{
  background: var(--blue); border-color: var(--blue); color: #fff;
}
.ship-step.is-active .ship-step-num{ background: var(--green); color: var(--blue); }

/* Lane table header tweak for stronger contrast already inline; ensure hover band visible */
.lane-row:hover{ background: var(--bg-tint) !important; }

/* Buttons: a touch more weight on the primary so CTAs pop on light */
.btn-primary{ box-shadow: 0 10px 24px -12px rgba(8,2,163,0.55); }
.btn-accent{ box-shadow: 0 10px 24px -12px rgba(98,255,42,0.6); }

/* Selection + focus already branded; strengthen input borders on the now-deeper bg */
.field input, .field select, .contact-form textarea{ border-color: var(--line-strong); }

/* ============================================================
   DARK / HIGH-CONTRAST PASS â€” "live route" visual language
   Deep-blue command surfaces, dotted grid, green glow, motion
   ============================================================ */

/* Deepen + texture the existing blue sections so the whole site
   reads darker and shares the live-map look */
.stats, .cta, .footer, .track-box, .quote-panel, .marquee{
  background-color: #0802A3;
  background-image:
    radial-gradient(620px 360px at 88% -10%, rgba(98,255,42,0.16), transparent 60%),
    radial-gradient(rgba(255,255,255,0.09) 1px, transparent 1px);
  background-size: auto, 26px 26px;
  background-position: 0 0, 0 0;
}
.stats{ position: relative; }
.feature-card.is-accent{
  background-color: #0802A3;
  background-image: radial-gradient(rgba(255,255,255,0.10) 1px, transparent 1px);
  background-size: 22px 22px;
}

/* Reusable deep-blue band */
.is-dark-band{
  position: relative;
  color: #fff;
  overflow: hidden;
  background:
    radial-gradient(760px 460px at 88% -10%, rgba(98,255,42,0.12), transparent 60%),
    #0802A3;
}
.is-dark-band::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image: radial-gradient(rgba(255,255,255,0.10) 1px, transparent 1px);
  background-size: 24px 24px;
  opacity:.6;
}
.is-dark-band > .container{ position: relative; z-index: 1; }
.is-dark-band .chip{
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.18);
  color: #fff;
}
.is-dark-band .chip.is-green{ background: var(--pill-bg); color: var(--pill-ink); border-color: var(--pill-border); font-weight: 600; }

/* RATES â€” dark live hero */
.rate-hero{ padding: clamp(56px, 7vw, 116px) 0 clamp(48px, 6vw, 92px); }
.rate-hero-grid{
  display:grid; grid-template-columns: minmax(0,1fr) minmax(0,1.04fr);
  gap: clamp(28px,4vw,60px); align-items:center;
}
.rate-hero h1{
  font-size: clamp(46px,6.4vw,88px); line-height:1.0; letter-spacing:-0.04em;
  color:#fff; font-weight:600;
}
.rate-hero h1 em{
  font-style:normal; display:inline-block;
  background: var(--green); color: var(--ink);
  padding: 0.02em 0.18em 0.08em; border-radius: 10px;
  box-shadow: 0 8px 0 -4px var(--green-700);
}
.rate-hero h1 .text-blue{ color: var(--green); }
.rate-hero .lead{ color: rgba(255,255,255,0.72); max-width: 520px; margin-top: 22px; }
.rate-hero-chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top: 28px; }
@media (max-width: 900px){ .rate-hero-grid{ grid-template-columns: 1fr; } }

/* Big live-route map (scaled-up sibling of .hero-visual) */
.livemap{
  width:100%;
  background:
    radial-gradient(540px 320px at 78% -10%, rgba(98,255,42,0.14), transparent 60%),
    linear-gradient(180deg, #0b05b8, #060284);
  border:1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius-lg);
  padding: 20px;
  position: relative; overflow: hidden;
  box-shadow: 0 30px 80px -30px rgba(0,0,0,0.6);
}
.livemap-head{
  display:flex; justify-content:space-between; align-items:center;
  font-family: var(--font-mono); font-size: 12px; letter-spacing:.14em;
  color: rgba(255,255,255,0.75); margin-bottom: 14px;
}
.livemap-head .lm-route{ display:inline-flex; align-items:center; gap:8px; color:#fff; }
.livemap-head .lm-dot{
  width:8px; height:8px; border-radius:50%; background: var(--green);
  box-shadow: 0 0 0 4px rgba(98,255,42,0.22); animation: pulse 1.6s ease infinite;
}
.livemap-head .lm-time{ color: rgba(255,255,255,0.5); }
.livemap-svg{
  width:100%; height:auto; display:block; border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.08);
}
/* Radar sweep + scanning line for "alive" feel */
.lm-scan{ transform-origin: center; animation: lmScan 7s linear infinite; }
@keyframes lmScan{ from{ opacity:.0 } 10%{opacity:.5} 50%{opacity:.5} 60%{opacity:0} to{opacity:0} }

/* Live readout strip below the map */
.livemap-readout{
  display:grid; grid-template-columns: repeat(3,1fr); gap: 12px;
  margin-top: 14px; padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.livemap-readout .lbl{
  font-family: var(--font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color: rgba(255,255,255,0.45); margin-bottom:4px;
}
.livemap-readout .val{ font-size:15px; font-weight:600; color:#fff; font-variant-numeric: tabular-nums; }
.livemap-readout .val.g{ color: var(--green); }

/* RATES â€” dark live "rates board" (sample lanes) */
.lanes-board{
  border:1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius-lg);
  overflow:hidden;
  background: linear-gradient(180deg, #0a05ad, #05027a);
  box-shadow: 0 30px 80px -34px rgba(0,0,0,0.55);
}
.lanes-board .lanes-head{
  display:grid; grid-template-columns: 1.5fr 1fr 1fr 1fr 0.9fr;
  padding: 16px 26px;
  background: rgba(0,0,0,0.28);
  border-bottom: 1px solid rgba(255,255,255,0.12);
  font-family: var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color: rgba(255,255,255,0.6);
}
.lanes-board .lanes-head .live{ display:inline-flex; align-items:center; gap:7px; color: var(--green); justify-self:end; }
.lanes-board .lanes-head .live::before{
  content:""; width:7px; height:7px; border-radius:50%; background: var(--green);
  box-shadow:0 0 0 4px rgba(98,255,42,0.25); animation: pulse 1.6s ease infinite;
}
.lanes-board .lane-row{
  display:grid; grid-template-columns: 1.5fr 1fr 1fr 1fr 0.9fr;
  padding: 18px 26px; align-items:center;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 14px; color: rgba(255,255,255,0.85);
  transition: background .18s ease, box-shadow .18s ease;
}
.lanes-board .lane-row:first-child{ border-top: 0; }
.lanes-board .lane-row > span:first-child{ font-weight:500; color:#fff; }
.lanes-board .lane-row:hover{
  background: rgba(98,255,42,0.06) !important;
  box-shadow: inset 3px 0 0 var(--green);
}
.lanes-board .lane-price{
  font-family: var(--font-mono);
  font-weight:600; color: var(--green); font-size: 16px; font-variant-numeric: tabular-nums;
}
.lanes-board .lane-retail{
  font-family: var(--font-mono); font-size: 12px;
  color: rgba(255,255,255,0.45); text-decoration: line-through;
}
.lanes-board .lane-save{
  justify-self:end; font-family: var(--font-mono); font-size:12px; letter-spacing:.04em;
  background: var(--green); color: var(--blue); padding: 4px 11px; border-radius: var(--radius-pill); font-weight:600;
}
@media (max-width: 760px){
  .lanes-board .lanes-head, .lanes-board .lane-row{ grid-template-columns: 1fr 1fr; gap:8px; }
  .lanes-board .lanes-head > span:nth-child(3),
  .lanes-board .lanes-head > span:nth-child(4),
  .lanes-board .lane-row > span:nth-child(3),
  .lanes-board .lane-row > span:nth-child(4){ display:none; }
}

/* Live ticker strip */
.rate-ticker{
  background:#04014f; color:#fff; overflow:hidden; border-top:1px solid rgba(255,255,255,0.1); border-bottom:1px solid rgba(255,255,255,0.1);
  padding: 14px 0;
}
.rate-ticker-track{ display:flex; gap:48px; width:max-content; animation: marquee 36s linear infinite; white-space:nowrap; font-family: var(--font-mono); font-size:13px; letter-spacing:.06em; }
.rate-ticker-track .t-lane{ color: rgba(255,255,255,0.78); }
.rate-ticker-track .t-price{ color: var(--green); font-weight:600; }
.rate-ticker-track .sep{ color: rgba(255,255,255,0.25); }

/* ============================================================
   DARK HEROS EVERYWHERE â€” home hero + page-head heros go dark
   ============================================================ */

/* Home hero: white headline, green slab stays */
.hero.is-dark-band .hero-title{ color: #fff; }
.hero.is-dark-band .hero-title em{ color: var(--slab-ink); }
.hero.is-dark-band .lead{ color: rgba(255,255,255,0.74); }

/* Page-head heros: white headline + lead */
.page-head.is-dark-band h1{ color: #fff; }
.page-head.is-dark-band .lead{ color: rgba(255,255,255,0.74); }

/* Dark-band button treatments so CTAs stay readable */
.is-dark-band .btn-primary{ background: var(--green); color: var(--ink); border-color: var(--green-700); box-shadow: 0 12px 28px -14px rgba(98,255,42,0.6); }
.is-dark-band .btn-primary:hover{ background: var(--green-700); color: var(--ink); }
.is-dark-band .btn-ghost{ background: transparent; color: #fff; border-color: rgba(255,255,255,0.34); }
.is-dark-band .btn-ghost:hover{ background: #fff; color: var(--ink); border-color: #fff; }

/* Calculator form on dark-band hero */
.is-dark-band .calc-form{
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.14);
}
.is-dark-band .calc-form-head{ border-bottom-color: rgba(255,255,255,0.1); }
.is-dark-band .calc-form-head h3{ color: #fff; }
.is-dark-band .calc-form-head .text-mute{ color: rgba(255,255,255,0.4); }
.is-dark-band .calc-form .field label{ color: var(--green); }
.is-dark-band .calc-form .field label .unit{ color: rgba(98,255,42,0.5); }
.is-dark-band .calc-form .field input,
.is-dark-band .calc-form .field select{
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.16);
  color: #fff;
}
.is-dark-band .calc-form .field input::placeholder{ color: rgba(255,255,255,0.35); }
.is-dark-band .calc-form .field input:focus{
  background: rgba(255,255,255,0.12);
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(98,255,42,0.18);
}
.is-dark-band .calc-form .small{ color: rgba(255,255,255,0.45); }
.is-dark-band .calc-form .mono.text-mute{ color: rgba(255,255,255,0.3); }

/* Carrier strip + live visual sit on the dark hero with crisp edges */
.is-dark-band .hero-strip{ border: 1px solid rgba(255,255,255,0.16); }
.is-dark-band .hero-visual{ border: 1px solid rgba(255,255,255,0.16); }

/* The hand-drawn page-head art is built for light bg â€” float it on a
   white "blueprint card" so it reads on the dark hero */
.page-head.is-dark-band .page-head-art{
  box-sizing: border-box;
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 18px;
  border: 1px solid rgba(255,255,255,0.16);
  box-shadow: 0 34px 90px -34px rgba(0,0,0,0.6);
}

/* Eyebrow inside dark heros (markup may not use .is-light) */
.is-dark-band .eyebrow{
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.82);
}
.is-dark-band .eyebrow::before{ box-shadow: 0 0 0 4px rgba(98,255,42,0.25); }

/* Trustpilot badge keeps its solid white background on dark heros */
.is-dark-band .chip-trustpilot{
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(0,182,122,0.4);
  color: #fff;
}

/* ============================================================
   BLUE HEADER THEME â€” green logo, white links, green Ship Now
   (nav shares the blue field with the hero, per requested UI)
   ============================================================ */
.nav-logo{ color: #ffffff; }
.nav-logo .dot{ background: var(--green); box-shadow: 0 0 0 4px rgba(98,255,42,0.22); }
.nav-link{ color: rgba(255,255,255,0.82); }
.nav-link:hover{ color: #fff; background: rgba(255,255,255,0.12); }
.nav-link.active{ color: #fff; background: rgba(255,255,255,0.16); }
.nav .btn-primary{ background: var(--green); color: var(--blue); border-color: var(--green); }
.nav .btn-primary:hover{ background: #fff; color: var(--blue); border-color: #fff; }
.nav .btn-ghost{ background: transparent; color: #fff; border-color: rgba(255,255,255,0.42); }
.nav .btn-ghost:hover{ background: #fff; color: var(--blue); border-color: #fff; }
.nav-burger{ color: #fff; border-color: rgba(255,255,255,0.42); }
.nav-burger[aria-expanded="true"]{ background: var(--green); color: var(--blue); border-color: var(--green); }

/* ============================================================
   RATE CALCULATOR â€” AVIO result card + extra fields
   ============================================================ */
.calc-origin-fixed{
  width:100%; height:50px; border-radius: var(--radius);
  border:1px solid var(--line-strong); background: var(--bg-tint);
  padding: 0 16px; font-size:15px; color: var(--ink-70); font-weight:500;
}
.calc-error{
  margin-top:14px; padding:12px 14px; border-radius: var(--radius);
  background:#fdecec; border:1px solid #f3b5b5; color:#9a1b1b; font-size:13.5px;
}
.calc-result-wrap{ position: sticky; top: 96px; }
.calc-result-empty{
  border:1.5px dashed var(--line-strong); border-radius: var(--radius-lg);
  padding:48px 24px; text-align:center; color: var(--ink-50);
  font-size:14px; line-height:1.5; background: var(--bg-card);
}
.calc-result-empty .cre-icon{ font-size:28px; color: var(--ink-30); margin-bottom:12px; }

/* The dark result card â€” mirrors the livemap look */
.acr{
  color:#fff; border-radius: var(--radius-lg); padding: 26px;
  background:
    radial-gradient(520px 300px at 80% -20%, rgba(98,255,42,0.16), transparent 60%),
    linear-gradient(180deg, #0b05b8, #060284);
  border:1px solid rgba(255,255,255,0.14);
  box-shadow: 0 30px 80px -34px rgba(0,0,0,0.55);
}
.acr-label{
  font-family: var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color: rgba(255,255,255,0.6);
}
.acr-price{
  margin:10px 0 16px; font-size:52px; font-weight:600; letter-spacing:-0.03em; line-height:1;
  display:flex; align-items:baseline; gap:8px; font-variant-numeric: tabular-nums; color: var(--green);
}
.acr-cur{ font-size:15px; color: rgba(255,255,255,0.55); font-weight:500; letter-spacing:0; }
.acr-pills{ display:flex; flex-wrap:wrap; gap:7px; margin-bottom:18px; }
.acr-pill{
  background: rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.14);
  padding:4px 11px; border-radius: var(--radius-pill);
  font-family: var(--font-mono); font-size:11px; letter-spacing:.04em; color:#fff;
}
.acr-pill-g{ background: var(--green); color: var(--blue); border-color: var(--green); font-weight:600; }
.acr-breakdown{
  border-top:1px solid rgba(255,255,255,0.12); padding-top:14px; margin-bottom:18px;
  font-family: var(--font-mono); font-size:12.5px;
}
.acr-line{ display:flex; justify-content:space-between; gap:16px; padding:4px 0; color: rgba(255,255,255,0.7); }
.acr-line b{ color:#fff; font-weight:500; }
.acr-line.acr-sub{ border-top:1px dashed rgba(255,255,255,0.14); margin-top:6px; padding-top:10px; }
.acr-line.acr-disc{ color: var(--green); }
.acr-line.acr-disc b{ color: var(--green); }
.acr-cta{ display:flex; gap:10px; margin-bottom:14px; }
.acr-cta .btn{ flex:1; }
.acr-cta .btn-ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,0.45); }
.acr-cta .btn-ghost:hover{ background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.75); color:#fff; }
.acr-cta .btn-accent{ background:var(--green); color:var(--blue); border-color:var(--green); }
.acr-cta .btn-accent:hover{ background:var(--green-700); color:var(--blue); }
.acr-note{ font-size:11px; color: rgba(255,255,255,0.5); line-height:1.5; }

/* Result card pop animation — iOS app-open style */
@keyframes acrPop {
  0%   { opacity: 0; transform: scale(0.35); }
  55%  { opacity: 1; transform: scale(1.06); }
  75%  { transform: scale(0.97); }
  90%  { transform: scale(1.02); }
  100% { opacity: 1; transform: scale(1); }
}
.acr-card.acr-animate {
  animation: acrPop 0.55s cubic-bezier(0.34, 1.4, 0.64, 1) both;
  transform-origin: center center;
}

/* Centered modal popup for calculator result */
.avio-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.avio-modal.open { display: flex; }
.avio-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 1, 40, 0.6);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  animation: avioFade 0.25s ease both;
}
@keyframes avioFade { from { opacity: 0; } to { opacity: 1; } }
.avio-modal-card {
  position: relative;
  width: 100%;
  max-width: 460px;
  max-height: 90vh;
  overflow: auto;
  z-index: 1;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5);
}
.avio-modal-close {
  position: absolute;
  top: 12px;
  right: 14px;
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  transition: background 0.15s;
}
.avio-modal-close:hover { background: rgba(255, 255, 255, 0.22); }

/* Skeleton loader */
@keyframes skelPulse {
  0%,100% { opacity: 0.35; }
  50%     { opacity: 0.7;  }
}
.acr-loading { display:flex; flex-direction:column; }
.acr-skel {
  border-radius: 6px;
  background: rgba(255,255,255,0.12);
  animation: skelPulse 1.3s ease-in-out infinite;
}

/* Button spinner */
@keyframes acrSpin { to { transform: rotate(360deg); } }
.acr-spinner {
  display: inline-block; vertical-align: middle;
  width: 14px; height: 14px; margin-right: 8px;
  border: 2px solid rgba(255,255,255,0.25);
  border-top-color: #fff;
  border-radius: 50%;
  animation: acrSpin 0.65s linear infinite;
}
@media (max-width: 1000px){
  .calc-result-wrap{ position: static; }
  .acr-cta{ flex-direction: column; }
}
@media (max-width: 900px){
  .nav-links{ background: var(--blue); border-bottom: 1px solid rgba(255,255,255,0.12); box-shadow: none; }
  .nav-links .nav-link:hover{ background: rgba(255,255,255,0.12); }
}

/* ============================================================
   FLOATING LOGOS BAND â€” auto-scrolling partner marquee
   ============================================================ */
.logo-float{
  position: relative;
  background: var(--blue);
  overflow: hidden;
  padding: 40px 0;
  border-top: 1px solid rgba(255,255,255,0.12);
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
/* fade edges */
.logo-float::before, .logo-float::after{
  content:""; position:absolute; top:0; bottom:0; width: 12%; z-index:2; pointer-events:none;
}
.logo-float::before{ left:0; background: linear-gradient(90deg, var(--blue), transparent); }
.logo-float::after{ right:0; background: linear-gradient(270deg, var(--blue), transparent); }
.logo-float-track{
  display: flex; align-items: center;
  gap: clamp(48px, 7vw, 110px);
  width: max-content;
  animation: marquee 34s linear infinite;
}
.logo-float:hover .logo-float-track{ animation-play-state: paused; }
.lf-item{
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  animation: lfBob 4.5s ease-in-out infinite;
}
.lf-item:nth-child(2n){ animation-delay: -1.2s; }
.lf-item:nth-child(3n){ animation-delay: -2.4s; }
.lf-item:nth-child(4n){ animation-delay: -0.6s; }
.lf-item img{ height: 30px; width: auto; opacity: 0.95; display:block; }
.lf-item svg{ height: 26px; width: auto; display:block; fill: #fff; }
.lf-word{
  font-family: var(--font-mono);
  font-weight: 600; font-size: 20px; letter-spacing: 0.02em;
  color: rgba(255,255,255,0.9); white-space: nowrap;
}
@keyframes lfBob{
  0%, 100%{ transform: translateY(0); }
  50%{ transform: translateY(-7px); }
}
@media (prefers-reduced-motion: reduce){
  .logo-float-track{ animation: none; }
  .lf-item{ animation: none; }
}

/* ============================================================
   HOME HERO â€” diamond photo composition (matches brand mock)
   ============================================================ */
.hero.is-dark-band .hero-grid{ align-items: center; }
.hero-photo-wrap{
  position: relative;
  width: 100%;
  max-width: 580px;
  margin-left: auto;
}
.hero-photo{
  position: relative; z-index: 1;
  width: 100%; height: auto; display: block;
  filter: drop-shadow(0 26px 60px rgba(0,0,0,0.38));
}
.hero-diamonds{
  position: absolute;
  left: -52px; top: 34px;
  z-index: 0;
  width: 200px; height: 250px;
  opacity: 0.95;
}
@media (max-width: 900px){
  .hero.is-dark-band .hero-grid{ align-items: start; }
  .hero-photo-wrap{ max-width: 460px; margin: 8px auto 0; }
  .hero-diamonds{ left: -16px; top: 18px; width: 150px; height: 190px; }
}

/* Mobile: keep map/art from feeling cramped */
@media (max-width: 900px){
  .hero.is-dark-band .hero-strip{ margin-top: 32px; }
}

/* â”€â”€ Homepage calculator section â”€â”€ */
.home-calc {
  background: var(--blue);
  background-image: radial-gradient(circle, rgba(98,255,42,0.06) 1px, transparent 1px);
  background-size: 20px 20px;
  padding: 72px 0 80px;
  position: relative;
  overflow: hidden;
}
.home-calc::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(8,2,163,0.9) 0%, rgba(8,2,163,0.6) 100%);
  pointer-events: none;
}
.home-calc .container { position: relative; z-index: 1; }
.home-calc .section-eyebrow {
  color: var(--green);
  font-size: 11px; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; margin-bottom: 10px;
}
.home-calc .section-title {
  color: #fff;
  font-size: clamp(26px, 4vw, 38px);
  font-weight: 700; line-height: 1.15;
  margin: 0 0 8px;
}
.home-calc .section-sub {
  color: rgba(255,255,255,0.6);
  font-size: 15px; margin: 0 0 36px;
}
.home-calc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: start;
}
@media (max-width: 860px) {
  .home-calc-grid { grid-template-columns: 1fr; }
}

/* Calculator form card */
.hc-form {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  padding: 28px;
}
.hc-label {
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.09em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  display: block; margin-bottom: 7px;
}
.hc-input {
  width: 100%; padding: 11px 14px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 10px;
  color: #fff; font-size: 14px;
  outline: none; margin-bottom: 16px;
  font-family: inherit;
  transition: border-color 0.15s;
}
.hc-input::placeholder { color: rgba(255,255,255,0.35); }
.hc-input:focus { border-color: var(--green); }
.hc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.hc-note {
  font-size: 11px; color: rgba(255,255,255,0.4);
  margin: -8px 0 16px; line-height: 1.5;
}

/* Autocomplete dropdown */
.ac-wrap { position: relative; }
.ac-dropdown {
  display: none; position: absolute; top: calc(100% - 14px); left: 0; right: 0; z-index: 9999;
  background: #0d0b2e; border: 1px solid rgba(255,255,255,0.15); border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5); max-height: 220px; overflow-y: auto;
  margin-top: 2px;
}
.ac-dropdown.open { display: block; }
.ac-item {
  padding: 9px 14px; cursor: pointer; font-size: 13px; color: rgba(255,255,255,0.85);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  display: flex; justify-content: space-between; align-items: center; gap: 8px;
}
.ac-item:last-child { border-bottom: none; }
.ac-item:hover, .ac-item.active { background: rgba(98,255,42,0.08); }
.ac-item .ac-name { font-weight: 500; flex: 1; }
.ac-item .ac-meta { display: flex; gap: 6px; align-items: center; flex-shrink: 0; }
.ac-item .ac-code { font-size: 11px; color: rgba(255,255,255,0.4); font-family: monospace; }
.ac-item .ac-zone {
  font-size: 10px; color: var(--green); background: rgba(98,255,42,0.12);
  padding: 2px 6px; border-radius: 99px; font-family: monospace;
}

/* Result card */
.hc-result-empty {
  background: rgba(255,255,255,0.04);
  border: 1px dashed rgba(255,255,255,0.14);
  border-radius: 16px; padding: 48px 28px;
  text-align: center; color: rgba(255,255,255,0.3);
  font-size: 14px;
}
.hc-result-empty .hc-arrow { font-size: 32px; opacity: 0.3; display: block; margin-bottom: 10px; }
.acr-card {
  background: #0b0e2e;
  border: 1px solid rgba(98,255,42,0.2);
  border-radius: 16px; padding: 28px;
}
.acr-label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.09em;
  text-transform: uppercase; color: rgba(255,255,255,0.45);
  margin-bottom: 6px;
}
.acr-price {
  font-size: 54px; font-weight: 700; line-height: 1;
  color: var(--green); letter-spacing: -0.02em;
  margin-bottom: 12px;
}
.acr-cur { font-size: 18px; color: rgba(255,255,255,0.5); margin-right: 4px; font-weight: 600; }
.acr-pills { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 18px; }
.acr-pill {
  background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.7);
  padding: 3px 10px; border-radius: 99px; font-size: 12px;
}
.acr-pill-g { background: rgba(98,255,42,0.15); color: var(--green); }
.acr-breakdown { border-top: 1px solid rgba(255,255,255,0.1); padding-top: 14px; margin-bottom: 18px; }
.acr-line {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12px; color: rgba(255,255,255,0.6); padding: 4px 0;
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
}
.acr-line b { color: #fff; font-weight: 500; }
.acr-sub { border-top: 1px solid rgba(255,255,255,0.1); margin-top: 4px; padding-top: 8px; }
.acr-disc b { color: #ff8; }
.acr-cta { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.acr-cta .btn { flex: 1; min-width: 140px; justify-content: center; }
.acr-note { font-size: 11px; color: rgba(255,255,255,0.3); line-height: 1.5; }
#avioCalcError.calc-error {
  background: rgba(255,80,80,0.12); border: 1px solid rgba(255,80,80,0.3);
  border-radius: 8px; padding: 10px 14px; color: #ff8080;
  font-size: 13px; margin-top: -8px; margin-bottom: 12px;
}

/* (brainstorming CSS removed — leftover leaked styles deleted) */



/* ============================================================
   AURORA BACKGROUND — animated light-curtain behind dark bands
   Pure-CSS adaptation of the aurora effect, tuned to AVIO brand
   (deep blue / indigo / violet with a neon-green accent streak).
   Injected as a first child <div class="aurora-bg"> by main.js.
   ============================================================ */
.has-aurora{ position: relative; overflow: hidden; }
.has-aurora > .container{ position: relative; z-index: 2; }

.aurora-bg{
  position: absolute; inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  /* concentrate the glow toward the top so headline text stays clean */
  -webkit-mask-image: radial-gradient(120% 90% at 75% -10%, #000 18%, rgba(0,0,0,0.35) 55%, transparent 78%);
          mask-image: radial-gradient(120% 90% at 75% -10%, #000 18%, rgba(0,0,0,0.35) 55%, transparent 78%);
}
.aurora-bg::before,
.aurora-bg::after{
  content: "";
  position: absolute; inset: -60%;
  background-image:
    repeating-linear-gradient(100deg, #02012e 0%, #02012e 7%, transparent 10%, transparent 12%, #02012e 16%),
    repeating-linear-gradient(100deg, #1f3df0 10%, #6f7cf7 15%, #38a8ff 20%, #62FF2A 25%, #1f3df0 30%);
  background-size: 300% 300%, 220% 220%;
  background-position: 50% 50%, 50% 50%;
  filter: blur(34px);
  will-change: background-position, transform;
}
.aurora-bg::after{
  background-size: 220% 220%, 130% 130%;
  mix-blend-mode: screen;
  opacity: 0.55;
  animation: auroraDrift 58s linear infinite alternate;
}
.aurora-bg::before{
  opacity: 0.32;
  animation: auroraDrift 92s linear infinite;
}
@keyframes auroraDrift{
  from{ background-position: 50% 50%, 50% 50%; }
  to  { background-position: 360% 50%, 360% 50%; }
}
/* Lighter touch on the near-black feature band so cards stay legible */
.features .aurora-bg{ opacity: 0.8; }
/* Footer aurora drifts gently behind the giant watermark */
.footer .aurora-bg{ z-index: 0; }
.footer .footer-watermark{ z-index: 1; }

@media (prefers-reduced-motion: reduce){
  .aurora-bg::before,
  .aurora-bg::after{ animation: none; }
}


/* ============================================================
   TRANSPARENT OVERLAY NAV — blends into the dark hero / aurora
   - default: transparent, overlaps the dark hero (pulled up)
   - .is-scrolled: solid blurred blue once past the hero
   - .nav-solid: stays solid (light pages without a dark hero)
   Toggled by initNavScroll() in main.js.
   ============================================================ */
:root{ --nav-h: 72px; }

.nav{
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: background .3s ease, border-color .3s ease, box-shadow .3s ease, backdrop-filter .3s ease;
}
.nav.is-scrolled{
  background: rgba(8,2,163,0.92);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
          backdrop-filter: saturate(140%) blur(14px);
  border-bottom-color: rgba(255,255,255,0.12);
  box-shadow: 0 16px 44px -24px rgba(0,0,0,0.72);
}
.nav.nav-solid{
  background: var(--blue);
  border-bottom-color: rgba(255,255,255,0.12);
}

/* Pull the dark heroes up under the transparent nav so the aurora
   reads as one continuous field. Extra top padding keeps hero
   content clear of the overlapping nav. */
.hero.is-dark-band,
.rate-hero.is-dark-band,
.page-head.is-dark-band{
  margin-top: calc(-1 * var(--nav-h));
}
.hero.is-dark-band{ padding-top: calc(clamp(48px, 6vw, 104px) + var(--nav-h)); }
.rate-hero.is-dark-band{ padding-top: calc(clamp(56px, 7vw, 116px) + var(--nav-h)); }
.page-head.is-dark-band{ padding-top: calc(clamp(48px, 6vw, 96px) + var(--nav-h)); }


/* Longer hero headline ("...ship at 70% lower rates") — fit + balance.
   Only the middle words sit in <em> so they get the neon-green slab. */
.hero .hero-title{
  font-size: clamp(40px, 5.4vw, 88px);
  line-height: 0.98;
  text-wrap: balance;
}
.hero .hero-title em{
  /* neon-green highlight on the middle words only */
  background: var(--slab-bg);
  color: var(--slab-ink);
}
