:root {
  color-scheme: light;
  --bg: #f5f5f7;
  --surface: rgba(255, 255, 255, 0.76);
  --surface-solid: #ffffff;
  --surface-soft: #f0f2f5;
  --ink: #1d1d1f;
  --ink-soft: #424245;
  --muted: #6e6e73;
  --line: rgba(0, 0, 0, 0.08);
  --line-strong: rgba(0, 0, 0, 0.14);
  --blue: #0071e3;
  --blue-strong: #0060c8;
  --green: #15803d;
  --red: #b42318;
  --radius-xl: 30px;
  --radius-lg: 24px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --shadow-lg: 0 28px 70px rgba(0, 0, 0, 0.12);
  --shadow-md: 0 12px 30px rgba(0, 0, 0, 0.09);
  --shadow-sm: 0 8px 16px rgba(0, 0, 0, 0.07);
  --btn-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --btn-ease-press: cubic-bezier(0.34, 1.1, 0.64, 1);
  --btn-lift: translateY(-2px);
  --btn-press: translateY(1px) scale(0.985);
}
[data-theme='dark'] {
  color-scheme: dark;
  --bg: #070b14;
  --surface: rgba(14, 18, 29, 0.82);
  --surface-solid: #0d1220;
  --surface-soft: #11192a;
  --ink: #f4f7ff;
  --ink-soft: #b3bfd6;
  --muted: #7c889f;
  --line: rgba(255, 255, 255, 0.08);
  --line-strong: rgba(255, 255, 255, 0.16);
  --blue: #4aa5ff;
  --blue-strong: #2d8cff;
  --green: #37c28d;
  --red: #ff7765;
  --shadow-lg: 0 30px 80px rgba(0, 0, 0, 0.42);
  --shadow-md: 0 14px 32px rgba(0, 0, 0, 0.32);
  --shadow-sm: 0 8px 18px rgba(0, 0, 0, 0.24);
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  scrollbar-width: none;
  -ms-overflow-style: none;
  scrollbar-color: transparent transparent;
}
*::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
  background: transparent;
}
*::-webkit-scrollbar-thumb,
*::-webkit-scrollbar-track {
  display: none;
  background: transparent;
}
html,
body {
  min-height: 100%;
}
body {
  font-family:
    'SF Pro Display',
    'SF Pro Text',
    -apple-system,
    BlinkMacSystemFont,
    'Helvetica Neue',
    Helvetica,
    Arial,
    sans-serif;
  background: linear-gradient(180deg, #f6f7f9 0%, #eceff3 100%);
  color: var(--ink);
  overflow-x: hidden;
}
[data-theme='dark'] body {
  background: radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.16),
      transparent 28%
    ),
    radial-gradient(
      circle at bottom left,
      rgba(68, 215, 182, 0.08),
      transparent 26%
    ),
    linear-gradient(180deg, #09101d 0%, #060b14 100%);
}
.bg-orb {
  position: fixed;
  border-radius: 50%;
  filter: blur(45px);
  pointer-events: none;
  z-index: -2;
}
.orb-one {
  width: 420px;
  height: 420px;
  top: -120px;
  right: -120px;
  background: radial-gradient(
    circle at center,
    rgba(0, 113, 227, 0.32),
    rgba(0, 113, 227, 0)
  );
}
.orb-two {
  width: 520px;
  height: 520px;
  bottom: -190px;
  left: -150px;
  background: radial-gradient(
    circle at center,
    rgba(126, 230, 255, 0.26),
    rgba(126, 230, 255, 0)
  );
}
.bg-grid {
  position: fixed;
  inset: 0;
  background-image: linear-gradient(
      to right,
      rgba(0, 0, 0, 0.025) 1px,
      transparent 1px
    ),
    linear-gradient(to bottom, rgba(0, 0, 0, 0.025) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: -3;
}
[data-theme='dark'] .bg-grid {
  background-image: linear-gradient(
      to right,
      rgba(255, 255, 255, 0.028) 1px,
      transparent 1px
    ),
    linear-gradient(to bottom, rgba(255, 255, 255, 0.028) 1px, transparent 1px);
}
.app-shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px;
}
.glass {
  background: var(--surface);
  border: 1px solid var(--line);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--shadow-md);
}
.site-header {
  --top-nav-nudge-x: -14px;
  position: sticky;
  top: 16px;
  z-index: 60;
  border-radius: 999px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 12px 18px;
  overflow: visible;
}
.header-actions {
  display: inline-flex;
  flex-direction: row-reverse;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
  justify-self: end;
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  position: relative;
}
.settings-preferences-heading {
  margin: 14px 0 6px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--ink) 55%, transparent);
}
.settings-preferences-heading:first-child {
  margin-top: 0;
}
.brand-mark {
  width: 44px;
  height: 44px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.02em;
  background: linear-gradient(140deg, #0ea5e9 0%, #0071e3 55%, #004c99 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
}
.brand-text span {
  display: block;
  font-size: 17px;
  font-weight: 700;
  line-height: 1;
}
.brand-text small {
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 0.02em;
}
.top-nav {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.05);
  justify-self: center;
}
@media (min-width: 901px) {
  .top-nav {
    position: relative;
    left: var(--top-nav-nudge-x);
  }
}
.nav-link {
  border: none;
  background: transparent;
  color: var(--ink-soft);
  border-radius: 999px;
  padding: 10px 16px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition:
    transform 0.18s var(--btn-ease),
    background 0.18s ease,
    color 0.18s ease,
    box-shadow 0.18s ease;
}
.nav-link[data-target='tracking-insights'] {
  color: #6a4aa6;
}
.nav-link[data-target='hifi'] {
  color: #0b6b4f;
}
.nav-link[data-target='search'] {
  color: #16508f;
}
.nav-link[data-target='bookings'] {
  color: #a7631a;
}
.nav-link[data-target='settings'] {
  color: #54606f;
}
.nav-link.active {
  background: #fff;
  color: var(--ink);
  box-shadow: var(--shadow-sm);
}
.nav-link[data-target='tracking-insights'].active {
  background: linear-gradient(135deg, #7a5cff, #a855f7);
  color: #fff;
  box-shadow: 0 12px 24px rgba(122, 92, 255, 0.2);
}
.nav-link[data-target='hifi'].active {
  background: linear-gradient(135deg, #0b5fc5, #10b981);
  color: #fff;
  box-shadow: 0 12px 24px rgba(16, 185, 129, 0.22);
}
.nav-link[data-target='search'].active {
  background: linear-gradient(135deg, #0a84ff, #4f8cff);
  color: #fff;
  box-shadow:
    0 12px 24px rgba(10, 132, 255, 0.22),
    0 0 0 1px rgba(255, 255, 255, 0.18) inset;
  transform: translateY(-1px);
  padding-inline: 20px;
  font-weight: 800;
  letter-spacing: 0.01em;
}
.nav-link[data-target='bookings'].active {
  background: linear-gradient(135deg, #e59b35, #f4b942);
  color: #fff;
  box-shadow: 0 12px 24px rgba(229, 155, 53, 0.2);
}
.nav-link[data-target='settings'].active {
  background: linear-gradient(135deg, #5f6b7a, #7a8897);
  color: #fff;
  box-shadow: 0 12px 24px rgba(95, 107, 122, 0.2);
}
.nav-link[data-target='tracking-insights']:not(.active):hover {
  background: rgba(10, 132, 255, 0.1);
}
.nav-link[data-target='hifi']:not(.active):hover {
  background: rgba(16, 185, 129, 0.12);
}
.nav-link[data-target='search']:not(.active):hover {
  background: rgba(122, 92, 255, 0.1);
}
.nav-link[data-target='bookings']:not(.active):hover {
  background: rgba(229, 155, 53, 0.1);
}
.nav-link[data-target='settings']:not(.active):hover {
  background: rgba(95, 107, 122, 0.1);
}
.cta-pill {
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: linear-gradient(135deg, #0a84ff, #0066cc);
}
[data-theme='dark'] .home-command-scene {
  background: linear-gradient(
      160deg,
      rgba(11, 17, 28, 0.9),
      rgba(8, 13, 23, 0.82)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.12),
      transparent 34%
    ),
    radial-gradient(
      circle at bottom left,
      rgba(68, 215, 182, 0.06),
      transparent 28%
    );
}
[data-theme='dark'] .hero-panel-main {
  background: linear-gradient(
      160deg,
      rgba(14, 20, 33, 0.94),
      rgba(10, 15, 25, 0.9)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.08),
      transparent 34%
    );
  border-color: rgba(255, 255, 255, 0.08);
}
[data-theme='dark'] .featured-story {
  background: linear-gradient(140deg, #07111f, #0a366d 48%, #0a6fce);
}
[data-theme='dark'] .site-header {
  background: rgba(10, 15, 25, 0.76);
  border-color: rgba(255, 255, 255, 0.08);
}
[data-theme='dark'] .top-nav {
  background: rgba(255, 255, 255, 0.05);
}
[data-theme='dark'] .nav-link {
  color: var(--ink-soft);
}
[data-theme='dark'] .nav-link.active {
  background: rgba(255, 255, 255, 0.1);
  color: var(--ink);
}
[data-theme='dark'] .cta-pill,
[data-theme='dark'] .primary {
  box-shadow:
    0 14px 30px rgba(10, 132, 255, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
}
[data-theme='dark'] .secondary,
[data-theme='dark'] .ghost {
  background: rgba(255, 255, 255, 0.04);
  color: var(--ink);
  border-color: rgba(255, 255, 255, 0.08);
}
[data-theme='dark'] .secondary:hover,
[data-theme='dark'] .ghost:hover,
[data-theme='dark'] .secondary.is-hovered,
[data-theme='dark'] .ghost.is-hovered {
  background: rgba(255, 255, 255, 0.08);
}
[data-theme='dark'] .secondary:not(:disabled):not(.no-motion):hover,
[data-theme='dark'] .secondary:not(:disabled):not(.no-motion).is-hovered {
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.28);
}
[data-theme='dark'] .route-price-graph-toolbar .field input,
[data-theme='dark'] .route-price-graph-toolbar .field select,
[data-theme='dark'] .field input,
[data-theme='dark'] .field select,
[data-theme='dark'] .field textarea {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--ink);
}
[data-theme='dark'] .route-price-graph-toolbar .field input[readonly] {
  background: linear-gradient(
      180deg,
      rgba(15, 20, 32, 0.96),
      rgba(18, 24, 38, 0.92)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.16),
      transparent 38%
    );
  color: var(--ink);
}
[data-theme='dark'] .route-price-graph-card {
  background: linear-gradient(
      180deg,
      rgba(12, 18, 30, 0.94),
      rgba(8, 12, 22, 0.9)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.16),
      transparent 34%
    ),
    radial-gradient(
      circle at bottom left,
      rgba(68, 215, 182, 0.08),
      transparent 30%
    );
}
[data-theme='dark'] .result-card {
  border-color: rgba(74, 165, 255, 0.14);
  background: linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.06),
      rgba(255, 255, 255, 0) 26%
    ),
    linear-gradient(180deg, rgba(14, 19, 31, 0.98), rgba(9, 14, 24, 0.95));
  box-shadow:
    0 16px 30px rgba(0, 0, 0, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
[data-theme='dark'] .result-card::before {
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.1),
    rgba(255, 255, 255, 0) 32%,
    rgba(74, 165, 255, 0.04) 72%,
    rgba(68, 215, 182, 0.06)
  );
}
[data-theme='dark'] .result-card::after {
  background: linear-gradient(
    90deg,
    rgba(74, 165, 255, 0.04),
    rgba(74, 165, 255, 0.36),
    rgba(68, 215, 182, 0.28),
    rgba(74, 165, 255, 0.04)
  );
}
[data-theme='dark'] .result-card-price strong {
  color: #f2f7ff;
}
[data-theme='dark'] .result-airline-brand-copy strong {
  color: #dbe8ff;
}
[data-theme='dark'] .result-airline-brand-copy span {
  color: rgba(173, 196, 229, 0.86);
}
[data-theme='dark'] .result-price-caption {
  color: rgba(160, 203, 255, 0.92);
}
[data-theme='dark'] .result-card .badge,
[data-theme='dark'] .result-currency-badge {
  background: rgba(255, 255, 255, 0.06);
  color: #edf4ff;
  border-color: rgba(255, 255, 255, 0.1);
}
[data-theme='dark'] .result-card .caption,
[data-theme='dark'] .result-point span,
[data-theme='dark'] .result-flight-arc span {
  color: rgba(214, 227, 247, 0.8);
}
[data-theme='dark'] .route-price-graph-chart {
  background: linear-gradient(
      180deg,
      rgba(12, 18, 30, 0.96),
      rgba(8, 12, 22, 0.92)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.18),
      transparent 40%
    );
  border-color: rgba(255, 255, 255, 0.08);
}
[data-theme='dark'] .route-price-graph-stat,
[data-theme='dark'] .route-price-graph-summary span {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.08);
}
[data-theme='dark'] .route-price-graph-summary span:first-child {
  background: rgba(78, 165, 255, 0.16);
  color: #d8e9ff;
}
[data-theme='dark'] .route-graph-refresh {
  box-shadow:
    0 14px 30px rgba(10, 132, 255, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
}
.view-tracking-insights::before {
  background: radial-gradient(
      circle at 8% 0%,
      rgba(245, 160, 89, 0.12),
      transparent 28%
    ),
    radial-gradient(circle at 95% 12%, rgba(74, 144, 226, 0.1), transparent 26%);
}
.home-hero-grid {
  margin-top: 26px;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  gap: 18px;
}
.home-launch-grid {
  margin-top: 14px;
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
  gap: 18px;
}
.home-launch-panel {
  position: relative;
  overflow: visible;
  background: radial-gradient(
      circle at top left,
      rgba(10, 132, 255, 0.16),
      transparent 34%
    ),
    linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(245, 249, 255, 0.86));
}
.home-search-shell {
  position: relative;
  z-index: 2;
  margin-top: 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.78);
  padding: 12px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
.home-tracking-card {
  margin-top: 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 28px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.88),
      rgba(246, 249, 255, 0.86)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.12),
      transparent 30%
    );
  box-shadow:
    0 18px 50px rgba(15, 23, 42, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.65);
  overflow: visible;
}
.home-tracking-card .home-search-shell {
  margin-top: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 18px;
  box-shadow: none;
  overflow: visible;
}
.home-routes-card {
  margin-top: 16px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 26px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.86),
      rgba(249, 251, 255, 0.84)
    ),
    radial-gradient(
      circle at top left,
      rgba(245, 160, 89, 0.08),
      transparent 28%
    );
  box-shadow:
    0 12px 34px rgba(15, 23, 42, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.65);
  padding: 16px;
}
.home-routes-card .panel-header.compact {
  margin-bottom: 12px;
}
.home-routes-card .spotlight-head {
  margin-top: 14px;
}
.home-track-mode-switch {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  padding: 6px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.06);
  width: min(100%, 430px);
  margin: 0 0 10px;
}
.home-track-mode-pill {
  position: relative;
  cursor: pointer;
  border-radius: 999px;
  padding: 10px 16px;
  color: var(--ink-soft);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
  transition:
    background 0.2s ease,
    color 0.2s ease,
    box-shadow 0.2s ease;
}
.home-track-mode-pill input {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}
.home-track-mode-pill.active {
  background: #fff;
  color: var(--ink);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
}
.home-search-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.home-search-grid #homeTrackFlightField {
  grid-column: 1 / -1;
  justify-self: start;
  width: min(100%, 360px);
  max-width: 360px;
}
.home-search-grid.route-mode {
  --home-track-control-height: 50px;
  grid-template-columns: minmax(0, 1fr) minmax(138px, 0.28fr);
  gap: 10px;
  align-items: stretch;
}
.home-search-grid.route-mode #homeTrackRoutePair,
.home-search-grid.route-mode #homeTrackFromField,
.home-search-grid.route-mode #homeTrackToField {
  min-width: 0;
}
.home-search-grid.route-mode #homeTrackRoutePair {
  grid-column: 1;
}
.home-search-grid.route-mode #homeTrackDateField {
  grid-column: 2;
}
.home-search-grid .field.location-field {
  min-width: 0;
}
.home-tracking-card .field {
  position: relative;
  z-index: 3;
}
.home-track-flight-field {
  display: grid;
  align-content: center;
  gap: 1px;
  min-height: var(--home-track-control-height, 50px);
  height: var(--home-track-control-height, 50px);
  padding: 6px 14px;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 14px 30px rgba(15, 23, 42, 0.05);
}
.home-track-route-pair {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 68px minmax(0, 1fr);
  align-items: stretch;
  min-height: var(--home-track-control-height, 50px);
  height: var(--home-track-control-height, 50px);
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 14px 30px rgba(15, 23, 42, 0.05);
  overflow: visible;
}
.home-track-route-pair.hidden {
  display: none;
}
.home-track-route-endpoint {
  display: grid;
  align-content: center;
  gap: 1px;
  padding: 6px 14px;
  margin: 0;
  background: transparent;
}
.home-track-flight-field > span,
.home-tracking-card .home-track-route-endpoint > span,
.home-track-date-field > span {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.03em;
  color: var(--muted);
  line-height: 1.1;
}
.home-tracking-card .home-track-flight-field input,
.home-tracking-card .home-track-flight-field input:hover,
.home-tracking-card .home-track-flight-field input:focus,
.home-tracking-card .home-track-flight-field input:focus-visible,
.home-tracking-card .home-track-route-endpoint input,
.home-tracking-card .home-track-route-endpoint input:hover,
.home-tracking-card .home-track-route-endpoint input:focus,
.home-tracking-card .home-track-route-endpoint input:focus-visible {
  width: 100%;
  height: auto;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  outline: 0;
  background: transparent;
  box-shadow: none;
  transform: none;
  color: rgba(15, 23, 42, 0.96);
  font-size: 13px;
  line-height: 1.25;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.home-tracking-card .home-track-flight-field input::placeholder,
.home-tracking-card .home-track-route-endpoint input::placeholder {
  color: var(--ink);
  opacity: 0.9;
}
.home-track-route-divider {
  position: relative;
  display: grid;
  place-items: center;
}
.home-track-route-divider::before {
  content: '';
  position: absolute;
  top: 9px;
  bottom: 9px;
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(
    180deg,
    rgba(148, 163, 184, 0.25),
    rgba(148, 163, 184, 0.62),
    rgba(148, 163, 184, 0.25)
  );
}
.home-track-route-swap {
  align-self: center;
  justify-self: center;
}
.home-tracking-card .suggestions {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  display: none;
  z-index: 120;
  max-height: min(52vh, 420px);
  padding-top: 4px;
  padding-bottom: 4px;
  margin-top: 0;
  pointer-events: auto;
}
.home-tracking-card .suggestion {
  padding: 10px 12px;
}
.home-tracking-card .suggestion strong {
  font-size: 14px;
  line-height: 1.15;
}
.home-tracking-card .suggestion small {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  line-height: 1.2;
}
.home-tracking-card .suggestions.active {
  display: block;
}
.home-track-suggestion-portal {
  position: fixed !important;
  z-index: 9999 !important;
  max-height: min(76vh, 680px) !important;
  overflow: auto !important;
  display: none;
  pointer-events: auto;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
  isolation: isolate;
}
.home-track-suggestion-portal.active {
  display: block;
}
.home-search-grid .field {
  margin-bottom: 0;
}
.home-track-date-field input {
  display: block;
  width: 100%;
  min-height: 0;
  height: auto;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0 28px 0 0;
  line-height: 1.15;
  color: rgba(15, 23, 42, 0.96);
  font-size: 13px;
  font-weight: 800;
  appearance: none;
  -webkit-appearance: none;
}
.home-tracking-card .home-track-date-field input[readonly],
.home-tracking-card .home-track-date-field input[readonly]:hover,
.home-tracking-card .home-track-date-field input[readonly]:focus,
.home-tracking-card .home-track-date-field input[readonly]:focus-visible {
  min-height: 0;
  height: auto;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0 28px 0 0;
  transform: none;
}
.home-track-date-field {
  position: relative;
  display: grid;
  align-content: center;
  gap: 0;
  padding: 6px 14px;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 250, 255, 0.95)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.08),
      transparent 38%
    ),
    var(--surface);
  border-color: var(--line-strong);
  min-height: var(--home-track-control-height, 50px);
  height: var(--home-track-control-height, 50px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 14px 30px rgba(15, 23, 42, 0.05);
}
.home-track-date-field::after {
  content: '';
  position: absolute;
  right: 15px;
  top: calc(50% + 7px);
  width: 16px;
  height: 16px;
  transform: translateY(-50%);
  background-color: rgba(15, 23, 42, 0.62);
  pointer-events: none;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='3'/%3E%3Cpath d='M8 3v4M16 3v4M3 11h18'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='3'/%3E%3Cpath d='M8 3v4M16 3v4M3 11h18'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}
.home-track-date-field input:hover,
.home-track-date-field input:focus,
.home-track-date-field input:focus-visible {
  border: 0;
  outline: 0;
  box-shadow: none;
  transform: none;
  background: transparent;
}
.hero-panel-main {
  padding-bottom: 20px;
}
.home-search-actions {
  margin-top: 12px;
  display: flex;
  gap: 10px;
  align-items: stretch;
  justify-content: flex-start;
}
.home-search-actions .primary {
  flex: 0 0 auto;
  width: auto;
  min-width: 220px;
  max-width: 280px;
  padding-inline: 34px;
}
.home-ops-panel {
  min-height: 100%;
}
.home-ops-board {
  margin-top: 18px;
  display: grid;
  gap: 12px;
}
.home-ops-context {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  padding: 0.48rem 0.82rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.home-ops-note {
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.78rem;
  line-height: 1.45;
  margin-top: -2px;
}
.home-ops-empty + .home-ops-note {
  margin-top: -4px;
}
.home-ops-card {
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
  padding: 14px;
  display: grid;
  gap: 10px;
}
.home-ops-card strong {
  color: #fff;
  font-size: 15px;
}
.home-airline-brand,
.home-track-brand-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.home-airline-brand-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.home-airline-brand-copy strong {
  display: block;
  font-size: 16px;
  line-height: 1.2;
  color: #fff;
  letter-spacing: -0.02em;
}
.home-track-card .home-airline-brand-copy strong {
  font-size: clamp(17px, 1.6vw, 20px);
  font-weight: 700;
}
.home-airline-brand-copy small,
.home-track-subline {
  color: rgba(255, 255, 255, 0.68);
  font-size: 11px;
  line-height: 1.2;
}
.home-airline-logo {
  flex: none;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.92);
  color: #0f172a;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.16);
}
.home-airline-logo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
  background: #fff;
}
.home-airline-logo.fallback {
  padding: 0 6px;
}
.home-ops-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.home-route-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}
.home-route-point {
  display: grid;
  gap: 4px;
}
.home-route-point.align-end {
  text-align: right;
}
.home-route-point small {
  color: rgba(255, 255, 255, 0.68);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.home-route-point span {
  color: rgba(255, 255, 255, 0.88);
  font-size: 13px;
}
.home-route-point em {
  color: rgba(255, 255, 255, 0.66);
  font-size: 11px;
  font-style: normal;
}
.home-route-center {
  display: grid;
  place-items: center;
}
.home-ops-meta span {
  border-radius: 999px;
  padding: 5px 10px;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.92);
  font-size: 11px;
  font-weight: 700;
}
.home-route-toolbar {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.home-route-control {
  display: grid;
  gap: 6px;
}
.home-route-control span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}
.home-route-control select {
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  border-radius: 14px;
  padding: 0.78rem 0.92rem;
  font-size: 0.92rem;
  font-weight: 600;
  outline: none;
}
.home-route-control select:focus {
  border-color: rgba(96, 165, 250, 0.55);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.16);
}
.home-ops-pager {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  overflow-x: auto;
  padding-top: 4px;
  margin-top: 2px;
}
.home-ops-page-btn {
  min-width: 2.1rem;
  height: 2.1rem;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  transition:
    transform 0.18s ease,
    background 0.18s ease,
    color 0.18s ease;
}
.home-ops-page-btn:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
}
.home-ops-page-btn.active {
  background: linear-gradient(
    135deg,
    rgba(59, 130, 246, 0.95),
    rgba(96, 165, 250, 0.95)
  );
  color: #fff;
  box-shadow: 0 10px 22px rgba(59, 130, 246, 0.24);
}
.home-route-center-copy {
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.92rem;
  font-weight: 600;
}
.home-track-card {
  background: radial-gradient(
      circle at top right,
      rgba(59, 130, 246, 0.24),
      transparent 34%
    ),
    linear-gradient(
      165deg,
      rgba(255, 255, 255, 0.16),
      rgba(255, 255, 255, 0.05)
    );
  padding: 18px 18px 16px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
.home-track-header,
.home-track-topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}
.home-track-header-main,
.home-track-brand-wrap {
  display: grid;
  gap: 8px;
  min-width: 0;
  flex: 1;
}
.home-track-flight-meta,
.home-track-flight-id {
  margin: 0;
  min-width: 0;
  overflow: hidden;
}
.home-track-meta-line {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: rgba(255, 255, 255, 0.76);
  font-size: 11px;
  line-height: 1.35;
  letter-spacing: 0.01em;
}
.home-track-meta-item {
  white-space: nowrap;
}
.home-track-meta-flight {
  font-weight: 700;
  letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
}
.home-track-meta-sep,
.home-track-flight-id-sep {
  opacity: 0.55;
}
.home-track-status-pill {
  flex: none;
  align-self: flex-start;
  white-space: nowrap;
  border-radius: 999px;
  padding: 7px 13px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.1;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.94);
  max-width: none;
}
.home-track-status-pill.tone-active {
  border-color: rgba(90, 200, 250, 0.42);
  background: rgba(90, 200, 250, 0.16);
  color: #e8f7ff;
}
.home-track-status-pill.tone-arrived {
  border-color: rgba(74, 222, 128, 0.38);
  background: rgba(74, 222, 128, 0.14);
  color: #dcfce7;
}
.home-track-status-pill.tone-delayed {
  border-color: rgba(251, 191, 36, 0.42);
  background: rgba(251, 191, 36, 0.14);
  color: #fef3c7;
}
.home-track-status-pill.tone-cancelled {
  border-color: rgba(248, 113, 113, 0.42);
  background: rgba(248, 113, 113, 0.14);
  color: #fee2e2;
}
.home-track-status-pill.tone-boarding,
.home-track-status-pill.tone-scheduled {
  border-color: rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.92);
}
.home-track-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.home-track-plane-inline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  font-size: 16px;
  line-height: 1;
  filter: drop-shadow(0 6px 12px rgba(9, 20, 43, 0.25));
}
.home-track-card .badge {
  color: rgba(255, 255, 255, 0.92);
  background: rgba(255, 255, 255, 0.12);
  white-space: nowrap;
}
.home-ops-card .badge {
  color: rgba(255, 255, 255, 0.9);
  background: rgba(255, 255, 255, 0.08);
}
.home-track-eyebrow {
  display: block;
  margin-bottom: 6px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.home-track-topline strong {
  display: block;
  font-size: 24px;
  line-height: 1;
  color: #fff;
}
.home-track-subline {
  display: block;
  margin-top: 6px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
}
.home-track-route {
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.24fr) minmax(0, 0.78fr);
  gap: 14px;
  align-items: center;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}
.home-track-route small {
  display: block;
  color: rgba(255, 255, 255, 0.7);
  font-size: 11px;
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.home-track-airport.align-end {
  text-align: right;
}
.home-track-route strong {
  display: block;
  font-size: clamp(24px, 2.4vw, 30px);
  line-height: 1;
  letter-spacing: -0.04em;
  color: #fff;
}
.home-track-route .home-track-time,
.home-track-route span:not(.home-track-plane) {
  display: block;
  margin-top: 6px;
  color: rgba(255, 255, 255, 0.88);
  font-size: 13px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.home-track-progress-status {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  width: 100%;
  margin-bottom: 2px;
}
.home-track-progress-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.94);
}
.home-track-progress-status-pill.is-ontime {
  border-color: rgba(74, 222, 128, 0.34);
  background: rgba(74, 222, 128, 0.12);
  color: #dcfce7;
}
.home-track-progress-status-pill.is-delayed {
  border-color: rgba(251, 191, 36, 0.38);
  background: rgba(251, 191, 36, 0.14);
  color: #fef3c7;
}
.home-track-progress-activity {
  color: rgba(255, 255, 255, 0.72);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.home-track-progress-caption {
  margin-bottom: 0;
  text-align: center;
  color: rgba(255, 255, 255, 0.62);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.home-track-fact-line {
  display: block;
}
.home-track-fact-line-sub {
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.82);
  font-size: 12px;
  font-weight: 600;
}
.home-track-progress {
  display: grid;
  gap: 8px;
  justify-items: center;
  width: 100%;
}
.home-track-path {
  width: 100%;
}
.home-track-rail {
  --home-track-bar-height: 10px;
  --home-track-plane-width: 34px;
  --home-track-plane-height: 34px;
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 40px;
}
.home-track-track {
  position: relative;
  z-index: 1;
  flex: 1;
  width: 100%;
  height: var(--home-track-bar-height);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  overflow: hidden;
}
.home-track-line-fill {
  position: absolute;
  top: 0;
  left: 0;
  width: var(--home-track-progress, 0%);
  height: 100%;
  min-height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #38bdf8 0%, #0a84ff 55%, #60a5fa 100%);
  box-shadow: 0 0 12px rgba(10, 132, 255, 0.5);
  transition: width 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.home-track-plane {
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--home-track-plane-width);
  height: var(--home-track-plane-height);
  margin-top: calc(var(--home-track-plane-height) / -2);
  transform: translateX(-50%);
  color: #ffffff;
  filter: drop-shadow(0 2px 4px rgba(8, 20, 43, 0.5))
    drop-shadow(0 0 12px rgba(125, 211, 252, 0.8));
  pointer-events: none;
  transition: left 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.home-track-plane svg {
  display: block;
  width: var(--home-track-plane-width);
  height: var(--home-track-plane-height);
}
.home-track-progress small {
  margin-bottom: 0;
  text-align: center;
}
.home-track-facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}
.home-track-fact {
  border-radius: 14px;
  padding: 10px 11px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  display: grid;
  gap: 4px;
}
.home-track-fact span {
  color: rgba(255, 255, 255, 0.68);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.home-track-fact strong {
  display: grid;
  gap: 0;
  color: #fff;
  font-size: 13px;
  line-height: 1.25;
}
.home-ops-board.is-loading {
  min-height: 280px;
}
.home-ops-skeleton-line {
  height: 11px;
  border-radius: 999px;
  background: linear-gradient(
    100deg,
    rgba(255, 255, 255, 0.12),
    rgba(255, 255, 255, 0.3),
    rgba(255, 255, 255, 0.12)
  );
  background-size: 220% 100%;
  animation: skeletonPulse 1.15s linear infinite;
}
.home-ops-skeleton-line + .home-ops-skeleton-line {
  margin-top: 7px;
}
.home-ops-skeleton-line.w-90 {
  width: 90%;
}
.home-ops-skeleton-line.w-80 {
  width: 80%;
}
.home-ops-skeleton-line.w-70 {
  width: 70%;
}
.home-ops-skeleton-line.w-65 {
  width: 65%;
}
.home-ops-skeleton-line.w-55 {
  width: 55%;
}
.home-ops-skeleton-line.w-50 {
  width: 50%;
}
.home-ops-skeleton-line.w-45 {
  width: 45%;
}
.home-ops-skeleton-line.w-40 {
  width: 40%;
}
.home-ops-skeleton-line.w-35 {
  width: 35%;
}
.home-ops-skeleton-line.w-32 {
  width: 32%;
}
.home-ops-skeleton-line.w-36 {
  width: 36%;
}
.home-ops-skeleton-line.w-48 {
  width: 48%;
}
.home-ops-skeleton-line.w-50 {
  width: 50%;
}
.home-ops-skeleton-line.w-58 {
  width: 58%;
}
.home-ops-skeleton-line.w-62 {
  width: 62%;
}
.home-ops-skeleton-line.w-72 {
  width: 72%;
}
.home-ops-skeleton-line.w-90 {
  width: 90%;
}
.home-track-meta-skeleton {
  margin-top: 2px;
}
.home-ops-loading-progress-status {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  width: 100%;
}
.home-ops-skeleton-pill-inline {
  width: 72px;
  height: 24px;
  border-radius: 999px;
  display: inline-block;
}
.home-track-progress-caption-skeleton {
  margin: 0 auto;
}
.home-ops-loading-fact .home-ops-skeleton-line + .home-ops-skeleton-line {
  margin-top: 6px;
}
.home-ops-loading-card {
  pointer-events: none;
}
.home-ops-loading-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.home-ops-loading-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
}
.home-ops-skeleton-logo {
  flex: none;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: linear-gradient(
    100deg,
    rgba(255, 255, 255, 0.1),
    rgba(255, 255, 255, 0.26),
    rgba(255, 255, 255, 0.1)
  );
  background-size: 220% 100%;
  animation: skeletonPulse 1.15s linear infinite;
}
.home-ops-skeleton-pill {
  display: inline-block;
  width: 84px;
  height: 28px;
  border-radius: 999px;
  background: linear-gradient(
    100deg,
    rgba(255, 255, 255, 0.1),
    rgba(255, 255, 255, 0.24),
    rgba(255, 255, 255, 0.1)
  );
  background-size: 220% 100%;
  animation: skeletonPulse 1.15s linear infinite;
}
.home-ops-loading-route {
  margin-top: 4px;
}
.home-ops-loading-route-row > div:first-child,
.home-ops-loading-route-row > div:last-child {
  display: grid;
  gap: 6px;
}
.home-ops-loading-track .home-track-line-fill {
  animation: homeTrackSkeletonPulse 1.4s ease-in-out infinite;
}
.home-ops-loading-plane {
  left: 38% !important;
  animation: homeTrackPlaneDrift 1.6s ease-in-out infinite;
}
.home-ops-loading-fact {
  min-height: 58px;
}
#homeOpsStatus.is-pulsing {
  animation: insightStatusPulse 1.1s ease-in-out infinite;
}
.route-price-graph-output.is-loading {
  min-height: 320px;
}
.route-price-graph-loading-head .skeleton-line {
  height: 12px;
}
.route-price-graph-loading-head .route-price-graph-title {
  gap: 8px;
}
.route-price-graph-loading-chip {
  display: inline-block;
  min-height: 28px;
  border-radius: 999px;
}
.route-price-graph-chart--loading {
  position: relative;
}
.route-price-graph-chart-grid {
  position: absolute;
  inset: 18px 16px 28px;
  background-image: linear-gradient(
      to right,
      rgba(10, 132, 255, 0.06) 1px,
      transparent 1px
    ),
    linear-gradient(to top, rgba(10, 132, 255, 0.08) 1px, transparent 1px);
  background-size:
    calc(100% / 6) 100%,
    100% calc(100% / 4);
  opacity: 0.85;
}
.route-price-graph-chart-wave {
  position: absolute;
  inset: 12px 10px 18px;
  width: calc(100% - 20px);
  height: calc(100% - 30px);
}
.route-price-graph-chart-wave-fill {
  fill: rgba(10, 132, 255, 0.12);
  opacity: 0.85;
  animation: routeGraphWaveFill 1.8s ease-in-out infinite;
}
.route-price-graph-chart-wave-line {
  fill: none;
  stroke: rgba(10, 132, 255, 0.72);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 520;
  stroke-dashoffset: 520;
  animation: routeGraphWaveDraw 1.8s ease-in-out infinite;
}
.route-price-graph-loading-badge {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(10, 132, 255, 0.14);
  background: rgba(255, 255, 255, 0.94);
  color: rgba(15, 23, 42, 0.82);
  font-size: 12px;
  font-weight: 700;
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.1);
  z-index: 2;
}
.route-price-graph-loading-spinner {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid rgba(10, 132, 255, 0.18);
  border-top-color: #0a84ff;
  animation: bookingReceiptSpinner 0.75s linear infinite;
}
.route-price-graph-stat--loading {
  min-height: 72px;
  justify-content: end;
}
@keyframes homeTrackSkeletonPulse {
  0%,
  100% {
    opacity: 0.72;
  }
  50% {
    opacity: 1;
  }
}
@keyframes homeTrackPlaneDrift {
  0%,
  100% {
    transform: translateX(calc(-50% - 6px));
  }
  50% {
    transform: translateX(calc(-50% + 8px));
  }
}
@keyframes insightStatusPulse {
  0%,
  100% {
    opacity: 0.72;
    box-shadow: 0 0 0 rgba(10, 132, 255, 0);
  }
  50% {
    opacity: 1;
    box-shadow: 0 0 0 6px rgba(10, 132, 255, 0.12);
  }
}
@keyframes routeGraphWaveDraw {
  0% {
    stroke-dashoffset: 520;
    opacity: 0.45;
  }
  45%,
  55% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
  100% {
    stroke-dashoffset: -520;
    opacity: 0.45;
  }
}
@keyframes routeGraphWaveFill {
  0%,
  100% {
    opacity: 0.55;
  }
  50% {
    opacity: 0.95;
  }
}
@media (prefers-reduced-motion: reduce) {
  .home-ops-skeleton-line,
  .home-ops-skeleton-logo,
  .home-ops-skeleton-pill,
  .home-ops-loading-track .home-track-line-fill,
  .home-ops-loading-plane,
  #homeOpsStatus.is-pulsing,
  .route-price-graph-chart-wave-line,
  .route-price-graph-chart-wave-fill,
  .route-price-graph-loading-spinner {
    animation: none;
  }
}
[data-theme='dark'] .route-price-graph-loading-badge {
  border-color: rgba(112, 142, 204, 0.22);
  background: rgba(14, 22, 38, 0.94);
  color: rgba(238, 244, 255, 0.9);
}
.hero-panel,
.hero-surface,
.panel {
  border-radius: var(--radius-xl);
}
.hero-panel {
  padding: 34px;
  background: linear-gradient(
    145deg,
    rgba(255, 255, 255, 0.84),
    rgba(248, 251, 255, 0.72)
  );
}
.eyebrow {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--blue);
  margin-bottom: 12px;
}
.hero-panel h1 {
  font-size: clamp(30px, 3vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin-bottom: 14px;
}
.hero-copy {
  color: var(--ink-soft);
  font-size: 18px;
  max-width: 720px;
}
.hero-actions {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.home-user-hint {
  margin-top: 10px;
}
.hero-stat-grid {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.hero-stat {
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 14px;
}
.hero-stat strong {
  font-size: 20px;
  letter-spacing: -0.02em;
}
.hero-stat span {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: var(--muted);
}
.hero-surface {
  padding: 28px;
  background: linear-gradient(
    160deg,
    rgba(15, 23, 42, 0.9),
    rgba(20, 72, 161, 0.84)
  );
  color: #f5faff;
}
.hero-surface h2 {
  font-size: 31px;
  line-height: 1.12;
  letter-spacing: -0.02em;
}
.hero-surface p {
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.85);
}
.surface-points {
  margin-top: 22px;
  display: grid;
  gap: 10px;
}
.surface-points div {
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 12px;
}
.surface-points span {
  display: block;
  font-size: 14px;
  font-weight: 700;
}
.surface-points small {
  color: rgba(255, 255, 255, 0.8);
  font-size: 12px;
}
[data-animate] {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity 0.45s ease,
    transform 0.45s ease;
}
[data-animate].in-view {
  opacity: 1;
  transform: translateY(0);
}
.home-dynamics-grid {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.dynamic-card {
  border-radius: 22px;
  padding: 16px;
  transition:
    transform 0.22s ease,
    box-shadow 0.22s ease,
    border-color 0.22s ease;
}
.dynamic-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  border-color: var(--line-strong);
}
.pulse-ticker {
  display: grid;
  gap: 7px;
  flex: 1;
  align-content: start;
}
.pulse-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 9px 10px;
  background: rgba(255, 255, 255, 0.94);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}
.pulse-item:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.market-pulse-row {
  cursor: default;
  padding: 8px 10px;
  box-shadow: 0 6px 14px rgba(16, 32, 58, 0.035);
}
.market-pulse-row:hover {
  transform: none;
  box-shadow: 0 6px 14px rgba(16, 32, 58, 0.035);
}
.pulse-copy {
  display: grid;
  gap: 4px;
}
.pulse-copy strong {
  font-size: 12px;
  letter-spacing: -0.01em;
}
.pulse-copy small {
  color: var(--muted);
  font-size: 10px;
}
.pulse-change {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 5px 7px;
  min-width: 54px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.pulse-up {
  color: #056f2a;
  background: rgba(6, 111, 42, 0.09);
}
.pulse-down {
  color: #a3312b;
  background: rgba(163, 49, 43, 0.09);
}
.pulse-neutral {
  color: var(--muted);
  background: rgba(120, 132, 153, 0.1);
}
.spotlight-controls {
  display: inline-flex;
  gap: 6px;
}
.spotlight-track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 100%;
  overflow: hidden;
  border-radius: 16px;
}
.spotlight-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 14px;
  background: linear-gradient(145deg, #0f1d33, #1b4f97);
  color: #f4f9ff;
  min-height: 168px;
  display: grid;
  align-content: space-between;
  transform: translateX(0);
  transition: transform 0.35s ease;
}
.spotlight-card h3 {
  font-size: 18px;
  letter-spacing: -0.01em;
}
.spotlight-card p {
  margin-top: 6px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.88);
}
.spotlight-meta {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.spotlight-meta span {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.88);
}
.quick-route-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.quick-route-chip {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  color: var(--ink);
  padding: 7px 10px;
  font-size: 12px;
  cursor: pointer;
  transition: 0.2s ease;
}
.quick-route-chip:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.view-tracking-insights .home-command-scene {
  box-shadow: 0 26px 64px rgba(13, 28, 51, 0.08);
}
.view-tracking-insights .home-hero-grid {
  margin-top: 22px;
}
.view-tracking-insights .home-insight-grid {
  margin-top: 16px;
}
.featured-story {
  display: grid;
  grid-template-columns: minmax(300px, 1.08fr) minmax(0, 0.92fr);
  align-items: stretch;
  min-height: clamp(290px, 26vw, 360px);
  height: clamp(290px, 26vw, 360px);
  color: inherit;
  text-decoration: none;
  background: linear-gradient(140deg, #07111f, #0a366d 48%, #0a6fce);
  border-radius: 32px;
  padding: 0;
  box-shadow:
    0 32px 80px rgba(6, 18, 35, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  margin-bottom: 4px;
  transition:
    transform 0.24s ease,
    box-shadow 0.24s ease;
  overflow: hidden;
}
.featured-story:hover {
  transform: translateY(-2px);
  box-shadow: 0 28px 78px rgba(6, 21, 46, 0.34);
}
.featured-story.is-loading {
  pointer-events: none;
}
.featured-story-media {
  position: relative;
  min-height: 100%;
  height: 100%;
  aspect-ratio: auto;
  overflow: hidden;
  background: linear-gradient(
      160deg,
      rgba(11, 95, 197, 0.34),
      rgba(8, 20, 44, 0.18)
    ),
    radial-gradient(circle at top, rgba(255, 255, 255, 0.16), transparent 50%);
}
.featured-story-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  background: rgba(255, 255, 255, 0.06);
  position: absolute;
  inset: 0;
}
.featured-story-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
      180deg,
      rgba(3, 13, 28, 0) 0%,
      rgba(3, 13, 28, 0.12) 42%,
      rgba(3, 13, 28, 0.42) 100%
    ),
    linear-gradient(125deg, rgba(255, 255, 255, 0.12), transparent 36%);
  pointer-events: none;
}
.featured-story-copy {
  padding: 16px 18px 16px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  position: relative;
  min-width: 0;
  overflow: hidden;
  z-index: 1;
}
.featured-story-copy::before {
  content: '';
  position: absolute;
  left: -1px;
  top: 12px;
  bottom: 12px;
  width: 1px;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.28),
    rgba(255, 255, 255, 0.08),
    rgba(255, 255, 255, 0.18)
  );
  pointer-events: none;
}
.carousel-nav {
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.88);
  color: var(--ink);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease;
}
.carousel-nav:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
  border-color: var(--line-strong);
}
.carousel-dots {
  display: flex;
  align-items: center;
  gap: 6px;
  justify-content: center;
  flex: 1;
}
.carousel-dot {
  width: 8px;
  height: 8px;
  border: none;
  border-radius: 999px;
  background: rgba(12, 28, 48, 0.18);
  cursor: pointer;
  transition:
    transform 0.2s ease,
    width 0.2s ease,
    background-color 0.2s ease;
}
.carousel-dot.is-active {
  width: 22px;
  background: linear-gradient(145deg, #0a56b8, #0ea5e9);
  box-shadow: 0 0 0 4px rgba(11, 95, 197, 0.12);
}
.carousel-count {
  color: var(--muted);
  font-size: 12px;
  white-space: nowrap;
}
.featured-story.is-loading .story-chip,
.featured-story.is-loading h3,
.featured-story.is-loading p,
.featured-story.is-loading .story-meta span {
  color: transparent;
  border-radius: 8px;
  background: linear-gradient(
    100deg,
    rgba(255, 255, 255, 0.15),
    rgba(255, 255, 255, 0.36),
    rgba(255, 255, 255, 0.15)
  );
  background-size: 220% 100%;
  animation: skeletonPulse 1.2s linear infinite;
}
.story-chip {
  display: inline-block;
  border-radius: 999px;
  padding: 6px 12px;
  background: rgba(255, 255, 255, 0.12);
  color: #edf7ff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(14px);
}
.featured-story h3 {
  margin-top: 2px;
  color: #fff;
  font-size: clamp(18px, 1.6vw, 26px);
  line-height: 1.04;
  letter-spacing: -0.03em;
  text-wrap: balance;
  max-width: none;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.featured-story p {
  margin-top: 0;
  color: rgba(255, 255, 255, 0.84);
  max-width: 44ch;
  font-size: 12px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}
.story-meta {
  margin-top: auto;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  color: rgba(255, 255, 255, 0.82);
  font-size: 11px;
}
.home-command-scene {
  position: relative;
  overflow: hidden;
  margin-top: 26px;
  padding: 18px;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 14px;
  border-radius: 32px;
  background: linear-gradient(
    160deg,
    rgba(255, 255, 255, 0.82),
    rgba(240, 246, 255, 0.68)
  );
}
.home-command-scene::before {
  content: '';
  position: absolute;
  width: 440px;
  height: 440px;
  border-radius: 50%;
  right: -170px;
  top: -170px;
  background: radial-gradient(
    circle at center,
    rgba(5, 139, 255, 0.28),
    rgba(5, 139, 255, 0)
  );
  pointer-events: none;
}
.home-command-scene::after {
  content: '';
  position: absolute;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  left: -150px;
  bottom: -160px;
  background: radial-gradient(
    circle at center,
    rgba(68, 215, 182, 0.24),
    rgba(68, 215, 182, 0)
  );
  pointer-events: none;
}
.home-command-scene .hero-panel,
.home-command-scene .hero-surface {
  position: relative;
  z-index: 1;
  border-radius: 24px;
}
.hero-panel-main {
  padding: 28px;
  background: linear-gradient(
    145deg,
    rgba(255, 255, 255, 0.93),
    rgba(247, 251, 255, 0.88)
  );
  border: 1px solid var(--line);
}
.hero-panel-main h1 {
  font-size: clamp(34px, 4vw, 52px);
  letter-spacing: -0.03em;
  line-height: 1.03;
}
.hero-panel-main .hero-copy {
  margin-top: 12px;
}
.route-command-deck {
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}
.route-command-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  color: var(--ink);
  text-align: left;
  padding: 11px;
  display: grid;
  gap: 8px;
  cursor: pointer;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease;
}
.route-command-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.route-command-card:focus-visible {
  outline: 2px solid rgba(0, 113, 227, 0.55);
  outline-offset: 2px;
}
.route-command-card.active {
  border-color: rgba(0, 113, 227, 0.45);
  box-shadow: 0 0 0 2px rgba(0, 113, 227, 0.14);
}
.route-command-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.route-command-head strong {
  font-size: 13px;
  letter-spacing: 0.01em;
}
.route-command-card small {
  color: var(--muted);
  font-size: 11px;
}
.route-command-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.route-action-btn {
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  padding: 9px 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease;
}
.route-action-btn::after {
  display: inline-block;
  transition: transform 0.18s ease;
}
.route-action-search {
  color: #fff;
  border-color: rgba(0, 113, 227, 0.24);
  background: linear-gradient(135deg, #0a84ff, #0066cc);
  box-shadow: 0 10px 22px rgba(0, 113, 227, 0.24);
}
.route-action-search::after {
  content: '→';
}
.route-action-use {
  color: #064c9f;
  background: linear-gradient(135deg, #eef6ff, #dfeeff);
  border-color: rgba(0, 113, 227, 0.22);
  box-shadow: 0 8px 18px rgba(0, 113, 227, 0.12);
}
.route-action-use::after {
  content: '↗';
}
.route-action-btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.route-action-btn:hover::after {
  transform: translateX(1px);
}
.route-action-btn:active,
.route-action-btn.is-activating {
  transform: translateY(0);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
}
.route-command-go {
  justify-self: start;
}
.hero-surface-side {
  padding: 20px;
  background: linear-gradient(155deg, #08162d, #123f83 48%, #1061b6);
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: #edf6ff;
  display: grid;
  align-content: start;
  gap: 10px;
}
.hero-surface-side .panel-header {
  margin-bottom: 2px;
}
.hero-surface-side .panel-header h2 {
  color: #fff;
  font-size: 28px;
  letter-spacing: -0.02em;
}
.surface-lead {
  color: rgba(236, 245, 255, 0.86);
  font-size: 13px;
  margin-bottom: 6px;
}
.hero-surface-side .pill {
  background: rgba(255, 255, 255, 0.16);
  color: #dcedff;
}
.hero-surface-side .pill.tone-live,
.hero-surface-side .pill.tone-loading,
.hero-surface-side .pill.tone-error {
  background: rgba(255, 255, 255, 0.16);
  color: #dcedff;
}
.hero-surface-side .quick-route-chip {
  border-color: rgba(255, 255, 255, 0.32);
  background: rgba(255, 255, 255, 0.12);
  color: #f4f9ff;
}
.hero-surface-side .quick-route-chip:hover {
  background: rgba(255, 255, 255, 0.2);
  box-shadow: none;
}
.spotlight-head {
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
.spotlight-head h3 {
  font-size: 14px;
  letter-spacing: 0.02em;
  color: rgba(239, 247, 255, 0.9);
}
.hero-surface-side .spotlight-track {
  margin-top: 6px;
}
.hero-surface-side .spotlight-card {
  min-height: 170px;
  border-color: rgba(255, 255, 255, 0.2);
  background: linear-gradient(
    145deg,
    rgba(255, 255, 255, 0.14),
    rgba(255, 255, 255, 0.08)
  );
}
.hero-surface-side .story-chip {
  background: rgba(255, 255, 255, 0.2);
}
.hero-surface-side .spotlight-card p,
.hero-surface-side .spotlight-meta span {
  color: rgba(240, 248, 255, 0.84);
}
.home-insight-grid {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  align-items: stretch;
}
.route-price-graph-card {
  grid-column: 1 / -1;
  position: relative;
  overflow: visible;
  padding: 20px;
  border: 1px solid rgba(8, 15, 30, 0.1);
  background: linear-gradient(
      180deg,
      rgba(244, 249, 255, 0.98),
      rgba(232, 242, 255, 0.92)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.1),
      transparent 34%
    ),
    radial-gradient(
      circle at bottom left,
      rgba(59, 130, 246, 0.08),
      transparent 28%
    );
  box-shadow:
    0 18px 42px rgba(8, 15, 30, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.72);
}
.route-price-graph-card .panel-header.compact {
  align-items: center;
  margin-bottom: 14px;
}
.route-price-graph-card .panel-header.compact h2 {
  font-size: clamp(28px, 2.5vw, 46px);
  line-height: 0.98;
  letter-spacing: -0.04em;
}
.route-price-graph-card #routePriceGraphStatus {
  min-height: 36px;
  padding-inline: 14px;
  border-radius: 999px;
  font-size: 15px;
  letter-spacing: 0.02em;
}
.route-price-graph-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(10, 132, 255, 0.42),
    transparent
  );
  pointer-events: none;
}
.home-graph-kicker {
  margin: 2px 0 9px;
  color: var(--ink-soft);
  font-size: 11px;
  line-height: 1.35;
}
.route-price-graph-toolbar {
  display: grid;
  grid-template-columns:
    minmax(188px, 1.68fr)
    minmax(188px, 1.68fr)
    minmax(138px, 0.82fr)
    minmax(138px, 0.82fr)
    minmax(118px, 0.64fr)
    minmax(104px, 0.56fr);
  gap: 10px;
  align-items: end;
  margin-bottom: 12px;
  position: relative;
  z-index: 2;
  overflow: visible;
}
.route-price-route-pair {
  grid-column: 1 / span 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 68px minmax(0, 1fr);
  align-items: stretch;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 14px 30px rgba(15, 23, 42, 0.05);
  min-height: var(--search-control-height);
  overflow: visible;
}
.route-price-route-endpoint {
  display: grid;
  align-content: center;
  gap: 1px;
  padding: 8px 14px;
  position: relative;
}
.route-price-route-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: var(--muted);
  line-height: 1.1;
}
.route-price-route-endpoint input {
  width: 100%;
  height: auto;
  min-height: 0;
  border: 0;
  outline: 0;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  box-shadow: none;
  padding: 0;
  border-radius: 0;
  text-align: left;
  font-size: 14px;
  line-height: 1.25;
  font-family: inherit;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.route-price-route-endpoint input::placeholder {
  color: var(--ink);
  opacity: 0.9;
}
.route-price-route-endpoint input:hover,
.route-price-route-endpoint input:focus,
.route-price-route-endpoint input:focus-visible {
  border: 0;
  outline: 0;
  box-shadow: none;
  transform: none;
}
.route-price-route-divider {
  position: relative;
  display: grid;
  place-items: center;
}
.route-price-route-divider::before {
  content: '';
  position: absolute;
  top: 9px;
  bottom: 9px;
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(
    180deg,
    rgba(148, 163, 184, 0.25),
    rgba(148, 163, 184, 0.62),
    rgba(148, 163, 184, 0.25)
  );
}
.route-price-route-swap {
  position: relative;
  left: auto;
  top: auto;
  transform: none;
  z-index: 3;
  width: 44px;
  height: 44px;
  border-width: 2px;
  font-size: 18px;
  margin-bottom: 0;
}
.route-price-graph-toolbar .field {
  margin-bottom: 0;
}
.route-price-date-field {
  position: relative;
  display: grid;
  align-content: center;
  gap: 0;
  padding: 6px 14px;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 14px 30px rgba(15, 23, 42, 0.05);
  min-height: var(--search-control-height);
  align-self: stretch;
}
.route-price-date-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: var(--muted);
  line-height: 1;
}
.route-price-date-field .date-field-wrap {
  height: 100%;
  position: relative;
}
.route-price-graph-toolbar .date-field-wrap {
  position: relative;
}
.route-price-graph-toolbar .date-field-wrap::after {
  content: '';
  position: absolute;
  right: 15px;
  top: 50%;
  width: 16px;
  height: 16px;
  transform: translateY(-50%);
  background-color: rgba(15, 23, 42, 0.62);
  opacity: 1;
  pointer-events: none;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='3'/%3E%3Cpath d='M8 3v4M16 3v4M3 11h18'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='3'/%3E%3Cpath d='M8 3v4M16 3v4M3 11h18'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}
.route-price-graph-toolbar .date-field-wrap input.date-field {
  padding-right: 38px;
}
.route-price-graph-toolbar .field input,
.route-price-graph-toolbar .field select {
  min-height: var(--search-control-height);
  color: rgba(15, 23, 42, 0.96);
  font-weight: 800;
  border-radius: 18px;
  font-size: 15px;
  transition:
    border-color 0.16s ease,
    box-shadow 0.16s ease,
    transform 0.16s ease;
}
.route-price-graph-toolbar .field input[readonly] {
  border-color: rgba(10, 132, 255, 0.18);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.99),
      rgba(244, 248, 255, 0.96)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.18),
      transparent 38%
    );
  color: rgba(15, 23, 42, 0.96);
  font-weight: 800;
  letter-spacing: -0.01em;
  box-shadow:
    0 12px 26px rgba(8, 15, 30, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}
.route-price-date-field input.date-field,
.route-price-date-field .date-field {
  min-height: 0;
  height: auto;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0 34px 0 0;
  line-height: 1.15;
  font-size: 13px;
  font-family: inherit;
  font-weight: 700;
}
.route-price-date-field input.date-field:hover,
.route-price-date-field input.date-field:focus,
.route-price-date-field input.date-field:focus-visible {
  border: 0;
  outline: 0;
  box-shadow: none;
  transform: none;
}
.route-price-graph-toolbar .field input[readonly]::placeholder {
  color: rgba(15, 23, 42, 0.66);
}
.route-price-graph-toolbar .field input[readonly]:focus {
  border-color: rgba(10, 132, 255, 0.34);
  box-shadow:
    0 14px 30px rgba(10, 132, 255, 0.14),
    0 0 0 4px rgba(10, 132, 255, 0.14);
}
.route-price-graph-toolbar .suggestions {
  z-index: 40;
}
.route-graph-refresh {
  align-self: end;
  min-height: 46px;
  padding-inline: 14px;
  white-space: nowrap;
  grid-column: span 1;
  grid-column-start: 5;
  width: 100%;
  min-width: 0;
  border-radius: 18px;
  position: relative;
  overflow: hidden;
  box-shadow:
    0 14px 30px rgba(10, 132, 255, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease,
    filter 0.15s ease;
}
.route-graph-reset {
  align-self: end;
  min-height: 46px;
  padding-inline: 14px;
  white-space: nowrap;
  grid-column: span 1;
  grid-column-start: 6;
  width: 100%;
  min-width: 0;
  border-radius: 18px;
  border: 1px solid rgba(22, 37, 60, 0.12);
  background: linear-gradient(180deg, #ffffff, #f1f6fc);
  color: #15314e;
  box-shadow:
    0 8px 18px rgba(15, 23, 42, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease,
    background 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease;
}
.route-graph-reset:hover,
.route-graph-reset:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(10, 132, 255, 0.28);
  background: linear-gradient(180deg, #ffffff, #e8f2ff);
  box-shadow: 0 10px 22px rgba(8, 15, 30, 0.12);
}
.route-graph-reset:active {
  transform: translateY(1px) scale(0.99);
  box-shadow: 0 6px 14px rgba(8, 15, 30, 0.14);
}
.route-graph-refresh::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.26),
    transparent 42%,
    rgba(255, 255, 255, 0.08)
  );
  opacity: 0;
  transition: opacity 0.15s ease;
  pointer-events: none;
}
.route-graph-refresh:hover::after,
.route-graph-refresh:focus-visible::after,
.route-graph-refresh.is-pressed::after {
  opacity: 1;
}
.route-graph-refresh:hover,
.route-graph-refresh:focus-visible {
  transform: translateY(-1px);
  box-shadow:
    0 18px 34px rgba(10, 132, 255, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}
.route-graph-refresh:active,
.route-graph-refresh.is-pressed {
  transform: translateY(1px) scale(0.99);
  box-shadow:
    0 10px 20px rgba(10, 132, 255, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  filter: saturate(0.98);
}
.route-graph-refresh:focus-visible {
  outline: 2px solid rgba(10, 132, 255, 0.38);
  outline-offset: 2px;
}
.route-price-graph-output {
  display: grid;
  gap: 8px;
  min-height: 220px;
}

.route-price-graph-card .route-price-graph-output {
  flex: 1;
  min-height: 260px;
}

.route-price-graph-output:has(> .home-insight-empty:only-child) {
  display: flex;
  align-items: center;
  justify-content: center;
}

.route-price-graph-output > .home-insight-empty {
  width: min(100%, 420px);
  margin: 0;
  text-align: center;
  justify-items: center;
}
.route-price-graph-shell {
  display: grid;
  gap: 10px;
  padding: 0;
}
.route-price-graph-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 2px;
}
.route-price-graph-title {
  display: grid;
  gap: 3px;
}
.route-price-graph-title strong {
  font-size: clamp(20px, 2.1vw, 28px);
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: rgba(15, 23, 42, 0.98);
}
.route-price-graph-title small,
.route-price-graph-subline {
  color: rgba(15, 23, 42, 0.72);
  font-size: 12px;
  line-height: 1.3;
}
.route-price-graph-summary {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  margin-left: auto;
}
.route-price-graph-summary span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid rgba(10, 132, 255, 0.12);
  background: rgba(10, 132, 255, 0.06);
  color: rgba(15, 23, 42, 0.72);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.route-price-graph-summary span:first-child {
  color: rgba(10, 84, 200, 0.95);
  background: rgba(10, 132, 255, 0.12);
}
.route-price-graph-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.route-price-graph-timeline {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  color: rgba(15, 23, 42, 0.72);
  font-size: 11px;
  letter-spacing: 0.02em;
}
.route-price-graph-timeline span {
  padding-inline: 2px;
}
.route-price-graph-timeline span:nth-child(1) {
  text-align: left;
}
.route-price-graph-timeline span:nth-child(2) {
  text-align: center;
}
.route-price-graph-timeline span:nth-child(3) {
  text-align: right;
}
.route-price-graph-stat {
  border: 1px solid rgba(8, 15, 30, 0.08);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(240, 246, 255, 0.92)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.12),
      transparent 42%
    );
  padding: 11px 12px;
  display: grid;
  gap: 2px;
  box-shadow:
    0 10px 26px rgba(8, 15, 30, 0.04),
    inset 0 1px 0 rgba(255, 255, 255, 0.75);
}
.route-price-graph-stat span {
  color: rgba(15, 23, 42, 0.64);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.route-price-graph-stat strong {
  font-size: 17px;
  color: rgba(15, 23, 42, 0.95);
  letter-spacing: -0.02em;
}
.route-price-graph-chart {
  height: clamp(220px, 33vh, 310px);
  border-radius: 24px;
  position: relative;
  border: 1px solid rgba(8, 15, 30, 0.08);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.96),
      rgba(239, 245, 255, 0.92)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.18),
      transparent 40%
    );
  overflow: hidden;
  box-shadow:
    0 14px 34px rgba(17, 32, 56, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.88);
}
.route-price-graph-chart::before {
  content: '';
  position: absolute;
  inset: 10px;
  border-radius: 20px;
  border: 1px solid rgba(10, 132, 255, 0.08);
  pointer-events: none;
}
.route-price-graph-chart canvas {
  display: block;
  width: 100%;
  height: 100%;
  image-rendering: optimizeQuality;
}
.route-price-graph-tooltip {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  min-width: 190px;
  max-width: min(280px, calc(100% - 24px));
  padding: 12px 14px;
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(244, 248, 255, 0.95)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.12),
      transparent 48%
    );
  border: 1px solid rgba(8, 15, 30, 0.08);
  box-shadow:
    0 20px 40px rgba(17, 32, 56, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  display: grid;
  gap: 4px;
  opacity: 0;
  transform: translateY(4px) scale(0.98);
  transition:
    opacity 0.16s ease,
    transform 0.16s ease;
  pointer-events: none;
}
.route-price-graph-tooltip.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.route-price-graph-tooltip strong {
  font-size: 14px;
  line-height: 1.25;
  letter-spacing: -0.03em;
  color: rgba(15, 23, 42, 0.98);
}
.route-price-graph-tooltip span {
  font-size: 13px;
  font-weight: 800;
  color: rgba(10, 84, 200, 0.96);
}
[data-theme='dark'] .route-price-graph-card {
  border-color: rgba(120, 166, 236, 0.22);
  background: radial-gradient(
      130% 130% at 100% 0%,
      rgba(49, 117, 233, 0.2) 0%,
      rgba(12, 20, 36, 0) 56%
    ),
    radial-gradient(
      120% 120% at 0% 100%,
      rgba(102, 182, 255, 0.14) 0%,
      rgba(10, 16, 30, 0) 58%
    ),
    linear-gradient(180deg, rgba(10, 16, 30, 0.96), rgba(8, 13, 24, 0.94));
  box-shadow:
    0 20px 44px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
[data-theme='dark'] .route-price-graph-card #routePriceGraphStatus {
  border-color: rgba(122, 173, 255, 0.22);
  background: rgba(36, 68, 122, 0.44);
  color: rgba(228, 241, 255, 0.96);
}
[data-theme='dark'] .route-price-route-pair {
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06),
      rgba(255, 255, 255, 0.03)
    ),
    var(--surface);
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 14px 24px rgba(0, 0, 0, 0.22);
}
[data-theme='dark'] .route-price-route-label {
  color: rgba(203, 213, 225, 0.78);
}
[data-theme='dark'] .route-price-date-field {
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06),
      rgba(255, 255, 255, 0.03)
    ),
    var(--surface);
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 14px 24px rgba(0, 0, 0, 0.22);
}
[data-theme='dark'] .route-price-date-label {
  color: rgba(203, 213, 225, 0.78);
}
[data-theme='dark'] .route-price-date-field input.date-field[readonly],
[data-theme='dark'] .route-price-date-field .date-field[readonly] {
  background: transparent;
  border: 0;
  box-shadow: none;
  color: rgba(239, 246, 255, 0.94);
  -webkit-text-fill-color: rgba(239, 246, 255, 0.94);
}
[data-theme='dark']
  .route-price-date-field
  input.date-field[readonly]::placeholder,
[data-theme='dark'] .route-price-date-field .date-field[readonly]::placeholder {
  color: rgba(226, 232, 240, 0.78);
  -webkit-text-fill-color: rgba(226, 232, 240, 0.78);
  opacity: 1;
}
[data-theme='dark'] .route-price-route-endpoint input::placeholder {
  color: rgba(226, 232, 240, 0.78);
}
[data-theme='dark'] .route-price-route-divider::before {
  background: linear-gradient(
    180deg,
    rgba(148, 163, 184, 0.18),
    rgba(148, 163, 184, 0.5),
    rgba(148, 163, 184, 0.18)
  );
}
[data-theme='dark'] .route-price-route-swap {
  background: linear-gradient(
      180deg,
      rgba(22, 31, 49, 0.96),
      rgba(17, 25, 40, 0.94)
    ),
    var(--surface);
  border-color: rgba(120, 166, 236, 0.28);
  color: rgba(138, 184, 255, 0.94);
  box-shadow:
    0 12px 24px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
[data-theme='dark'] .route-price-route-swap:hover {
  border-color: rgba(120, 166, 236, 0.38);
  box-shadow:
    0 14px 26px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
[data-theme='dark'] .route-price-graph-toolbar .field > span {
  color: rgba(222, 234, 255, 0.88);
}
[data-theme='dark'] .route-price-graph-title strong {
  color: rgba(238, 247, 255, 0.98);
}
[data-theme='dark'] .route-price-graph-title small,
[data-theme='dark'] .route-price-graph-subline {
  color: rgba(205, 224, 247, 0.8);
}
[data-theme='dark'] .route-price-graph-summary span {
  color: rgba(227, 239, 255, 0.86);
  border-color: rgba(122, 173, 255, 0.24);
  background: rgba(68, 116, 190, 0.2);
}
[data-theme='dark'] .route-price-graph-summary span:first-child {
  color: rgba(228, 243, 255, 0.98);
  background: rgba(54, 141, 255, 0.3);
}
[data-theme='dark'] .route-price-graph-chart {
  border-color: rgba(124, 172, 255, 0.24);
  background: linear-gradient(
      180deg,
      rgba(14, 22, 38, 0.96),
      rgba(10, 18, 31, 0.92)
    ),
    radial-gradient(
      circle at top right,
      rgba(64, 133, 255, 0.16),
      transparent 42%
    );
  box-shadow:
    0 18px 40px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
[data-theme='dark'] .route-price-graph-chart::before {
  border-color: rgba(122, 173, 255, 0.18);
}
[data-theme='dark'] .route-price-graph-stat {
  border-color: rgba(124, 172, 255, 0.22);
  background: linear-gradient(
    180deg,
    rgba(14, 23, 40, 0.9),
    rgba(10, 18, 33, 0.84)
  );
  box-shadow:
    0 12px 26px rgba(0, 0, 0, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}
[data-theme='dark'] .route-price-graph-stat span {
  color: rgba(183, 209, 242, 0.76);
}
[data-theme='dark'] .route-price-graph-stat strong {
  color: rgba(232, 245, 255, 0.98);
}
[data-theme='dark'] .route-price-graph-toolbar .field input[readonly] {
  border-color: rgba(122, 173, 255, 0.28);
  box-shadow:
    0 12px 24px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
}
[data-theme='dark'] .route-price-graph-toolbar .date-field-wrap::after {
  background-color: rgba(188, 209, 255, 0.72);
}
[data-theme='dark'] .route-graph-refresh {
  box-shadow:
    0 16px 34px rgba(20, 126, 255, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
[data-theme='dark'] .route-price-graph-toolbar .route-graph-reset.secondary,
[data-theme='dark'] .route-graph-reset.secondary {
  border-color: rgba(124, 172, 255, 0.28);
  background: linear-gradient(
    180deg,
    rgba(36, 54, 86, 0.96),
    rgba(22, 34, 58, 0.94)
  );
  color: rgba(232, 242, 255, 0.96);
  box-shadow:
    0 10px 22px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
[data-theme='dark']
  .route-price-graph-toolbar
  .route-graph-reset.secondary:not(:disabled):not(.no-motion):hover,
[data-theme='dark']
  .route-price-graph-toolbar
  .route-graph-reset.secondary:not(:disabled):not(.no-motion).is-hovered,
[data-theme='dark']
  .route-graph-reset.secondary:not(:disabled):not(.no-motion):hover,
[data-theme='dark']
  .route-graph-reset.secondary:not(:disabled):not(.no-motion).is-hovered,
[data-theme='dark'] .route-graph-reset.secondary:hover,
[data-theme='dark'] .route-graph-reset.secondary:focus-visible {
  border-color: rgba(148, 190, 255, 0.44);
  background: linear-gradient(
    180deg,
    rgba(48, 72, 114, 0.98),
    rgba(30, 48, 78, 0.96)
  );
  color: #f4f8ff;
  filter: none;
  box-shadow:
    0 14px 28px rgba(12, 26, 52, 0.52),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}
[data-theme='dark']
  .route-price-graph-toolbar
  .route-graph-reset.secondary:not(:disabled):not(.no-motion):active,
[data-theme='dark']
  .route-price-graph-toolbar
  .route-graph-reset.secondary:not(:disabled):not(.no-motion).is-pressed,
[data-theme='dark']
  .route-graph-reset.secondary:not(:disabled):not(.no-motion):active,
[data-theme='dark']
  .route-graph-reset.secondary:not(:disabled):not(.no-motion).is-pressed,
[data-theme='dark'] .route-graph-reset.secondary:active {
  border-color: rgba(124, 172, 255, 0.32);
  background: linear-gradient(
    180deg,
    rgba(26, 40, 66, 0.98),
    rgba(16, 28, 48, 0.96)
  );
  color: rgba(220, 234, 255, 0.94);
  filter: none;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.38);
}
[data-theme='dark'] .route-graph-reset.secondary:focus-visible {
  outline: 2px solid rgba(122, 173, 255, 0.45);
  outline-offset: 2px;
}
[data-theme='dark'] .route-price-graph-tooltip {
  border-color: rgba(122, 173, 255, 0.24);
  background: radial-gradient(
      120% 120% at 100% 0%,
      rgba(66, 144, 255, 0.18),
      rgba(16, 26, 45, 0) 56%
    ),
    linear-gradient(180deg, rgba(14, 23, 40, 0.94), rgba(10, 17, 31, 0.92));
  box-shadow:
    0 20px 40px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
[data-theme='dark'] .route-price-graph-tooltip strong {
  color: rgba(232, 245, 255, 0.98);
}
[data-theme='dark'] .route-price-graph-tooltip span {
  color: rgba(156, 200, 255, 0.96);
}
[data-theme='dark'] .route-price-graph-output .home-insight-empty {
  min-height: 220px;
  border-color: rgba(124, 172, 255, 0.16);
  background: linear-gradient(
      180deg,
      rgba(15, 23, 38, 0.94),
      rgba(12, 19, 31, 0.92)
    ),
    radial-gradient(
      circle at top right,
      rgba(60, 129, 255, 0.12),
      transparent 40%
    );
  color: rgba(224, 236, 255, 0.84);
  box-shadow: inset 0 0 0 1px rgba(124, 172, 255, 0.08);
}
[data-theme='dark'] .route-price-graph-output .home-insight-empty strong {
  color: rgba(241, 247, 255, 0.98);
}
[data-theme='dark'] .route-price-graph-output .home-insight-empty span {
  color: rgba(183, 205, 238, 0.78);
}
.home-insight-toolbar {
  margin-top: 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.home-insight-toolbar-card {
  margin-top: 10px;
  margin-bottom: 8px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(8, 15, 30, 0.06);
  background: rgba(255, 255, 255, 0.7);
}
.home-insight-controls {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}
.home-insight-control {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 180px;
}
.home-insight-control span {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(15, 23, 42, 0.58);
}
.home-insight-control select {
  appearance: none;
  border: 1px solid rgba(8, 15, 30, 0.08);
  background: rgba(255, 255, 255, 0.88);
  color: rgba(15, 23, 42, 0.86);
  border-radius: 14px;
  padding: 11px 38px 11px 14px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.1;
  box-shadow: 0 10px 24px rgba(8, 15, 30, 0.04);
  min-width: 170px;
  cursor: pointer;
  background-image: linear-gradient(
      45deg,
      transparent 50%,
      rgba(15, 23, 42, 0.7) 50%
    ),
    linear-gradient(135deg, rgba(15, 23, 42, 0.7) 50%, transparent 50%);
  background-position:
    calc(100% - 17px) 50%,
    calc(100% - 11px) 50%;
  background-size:
    6px 6px,
    6px 6px;
  background-repeat: no-repeat;
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.18s ease;
}
.home-insight-control select:hover,
.home-insight-control select:focus {
  outline: none;
  transform: translateY(-1px);
  border-color: rgba(11, 95, 197, 0.22);
  box-shadow: 0 14px 28px rgba(11, 95, 197, 0.08);
}
.home-insight-summary {
  align-self: center;
  white-space: nowrap;
}
.compact-insight-card {
  padding: 14px 14px 12px;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.compact-insight-card .panel-header.compact {
  margin-bottom: 10px;
}
.compact-insight-card .eyebrow {
  margin-bottom: 3px;
}
.compact-insight-card .pill {
  align-self: flex-start;
}
.top-routes-list {
  display: grid;
  gap: 8px;
  flex: 1;
}
.home-insight-empty {
  display: grid;
  gap: 4px;
  align-content: center;
  min-height: 122px;
  padding: 14px 12px;
  border-radius: 16px;
  border: 1px dashed rgba(8, 15, 30, 0.12);
  background: rgba(255, 255, 255, 0.72);
  color: rgba(15, 23, 42, 0.72);
}
.home-insight-empty strong {
  font-size: 13px;
  letter-spacing: -0.01em;
}
.home-insight-empty span {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.45;
}
.top-deal-row {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.97), #f8fbff);
  padding: 10px 11px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(16, 32, 58, 0.04);
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease;
}
.top-deal-row:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
  border-color: var(--line-strong);
}
.fare-range-row {
  cursor: default;
  padding: 8px 10px;
  box-shadow: 0 6px 14px rgba(16, 32, 58, 0.035);
}
.fare-range-row:hover {
  transform: none;
  box-shadow: 0 6px 14px rgba(16, 32, 58, 0.035);
  border-color: var(--line);
}
.top-deal-copy {
  display: grid;
  gap: 4px;
}
.top-deal-row strong {
  font-size: 12px;
  letter-spacing: -0.01em;
}
.top-deal-copy small {
  color: var(--muted);
  font-size: 10px;
}
.top-deal-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.top-deal-meta strong {
  font-size: 13px;
}
.top-deal-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #0f4ea8;
  background: rgba(18, 107, 225, 0.1);
}
.alerts-snapshot-list {
  margin-top: 8px;
  display: grid;
  gap: 8px;
}
.alert-snapshot-row {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.9);
  padding: 9px 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
.alert-snapshot-row strong {
  font-size: 12px;
}
.alert-snapshot-row span {
  color: var(--muted);
  font-size: 11px;
}
.skeleton-card {
  position: relative;
  overflow: hidden;
}
.skeleton-line {
  height: 11px;
  border-radius: 999px;
  background: linear-gradient(
    100deg,
    rgba(221, 229, 241, 0.8),
    rgba(244, 248, 255, 0.95),
    rgba(221, 229, 241, 0.8)
  );
  background-size: 220% 100%;
  animation: skeletonPulse 1.2s linear infinite;
}
.skeleton-line + .skeleton-line {
  margin-top: 7px;
}
.skeleton-line.w-90 {
  width: 90%;
}
.skeleton-line.w-88 {
  width: 88%;
}
.skeleton-line.w-85 {
  width: 85%;
}
.skeleton-line.w-75 {
  width: 75%;
}
.skeleton-line.w-70 {
  width: 70%;
}
.skeleton-line.w-55 {
  width: 55%;
}
.skeleton-line.w-45 {
  width: 45%;
}
.skeleton-line.w-40 {
  width: 40%;
}
@keyframes skeletonPulse {
  0% {
    background-position: 100% 0;
  }
  100% {
    background-position: -100% 0;
  }
}
#search {
  position: relative;
  isolation: isolate;
}
#search .search-shell {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  gap: 14px;
}
#settings {
  position: relative;
  isolation: isolate;
}
#search .search-layout {
  margin-top: 24px;
  display: block;
}
#search .search-shell {
  display: grid;
  gap: 18px;
}
.panel {
  padding: 20px;
}
.panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
}
.panel-header h2,
.panel-header h3,
.panel-header h4 {
  letter-spacing: -0.01em;
}
.panel-header.compact {
  margin-bottom: 8px;
}
.field {
  display: grid;
  gap: 6px;
  margin-bottom: 14px;
  position: relative;
}
.field label {
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
}
.field input,
.field select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--ink);
  padding: 11px 12px;
  font-size: 14px;
  outline: none;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease;
}
.field input:focus,
.field select:focus {
  border-color: rgba(0, 113, 227, 0.7);
  box-shadow: 0 0 0 4px rgba(0, 113, 227, 0.15);
}
.field input[readonly] {
  cursor: pointer;
  user-select: none;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 250, 255, 0.95)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.08),
      transparent 38%
    );
}
.trip-toggle {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  border-radius: 999px;
  padding: 6px;
  background: rgba(0, 0, 0, 0.05);
  margin-bottom: 14px;
}
.tab {
  border: none;
  border-radius: 999px;
  padding: 10px;
  background: transparent;
  color: var(--ink-soft);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition:
    transform 0.18s var(--btn-ease),
    background 0.18s ease,
    color 0.18s ease,
    box-shadow 0.18s ease;
}
.tab.active {
  background: #fff;
  color: var(--ink);
  box-shadow: var(--shadow-sm);
}
.field-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) 48px minmax(0, 1.18fr);
  gap: 12px 10px;
  align-items: end;
}
.swap {
  width: 28px;
  height: 28px;
  border: 1px solid rgba(10, 132, 255, 0.32);
  border-radius: 999px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(237, 245, 255, 0.94)
    ),
    var(--surface);
  color: var(--blue);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  box-sizing: border-box;
  align-self: center;
  justify-self: center;
  cursor: pointer;
  box-shadow:
    0 14px 28px rgba(15, 23, 42, 0.11),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(8px);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease;
  position: relative;
}
.swap:hover {
  transform: translateY(-1px) scale(1.02);
  box-shadow:
    0 16px 30px rgba(15, 23, 42, 0.13),
    inset 0 1px 0 rgba(255, 255, 255, 0.94);
  border-color: rgba(10, 132, 255, 0.44);
}
.swap:active {
  transform: translateY(0);
  box-shadow: 0 8px 16px rgba(15, 23, 42, 0.08);
}
.swap::before,
.swap::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 10px;
  height: 1px;
  background: linear-gradient(
    90deg,
    rgba(10, 132, 255, 0),
    rgba(10, 132, 255, 0.42)
  );
  transform: translateY(-50%);
  pointer-events: none;
}
.swap::before {
  right: calc(100% + 4px);
}
.swap::after {
  left: calc(100% + 4px);
  background: linear-gradient(
    90deg,
    rgba(10, 132, 255, 0.42),
    rgba(10, 132, 255, 0)
  );
}
.nearby-block,
.multi-city,
.traveler-card,
.segment-card,
.forecast-card,
.calendar-card,
.result-card,
.booking-card,
.explore-card,
.flex-card,
.recent-card {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
}
.nearby-block,
.multi-city,
.traveler-card {
  padding: 14px;
  margin-bottom: 14px;
}
.nearby-row {
  display: grid;
  gap: 6px;
  font-size: 12px;
  color: var(--muted);
}
.nearby-row + .nearby-row {
  margin-top: 8px;
}
.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chip-row button {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
  color: var(--ink-soft);
  font-size: 12px;
  padding: 6px 10px;
  cursor: pointer;
}
.segment-list {
  display: grid;
  gap: 10px;
}
.segment-card {
  padding: 10px 10px 9px;
  display: grid;
  gap: 8px;
  position: relative;
  overflow: visible;
}
.segment-card.segment-traveler-open {
  z-index: 8;
}
.segment-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.segment-card-label {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0;
  color: var(--ink);
  line-height: 1.2;
}
.segment-row {
  display: grid;
  grid-template-columns:
    minmax(0, 1.55fr)
    minmax(148px, 0.72fr)
    minmax(170px, 0.92fr)
    minmax(148px, 0.78fr);
  gap: 8px;
}
.segment-row .field {
  margin-bottom: 0;
}
.segment-route-pair {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 68px minmax(0, 1fr);
  align-items: stretch;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 10px 24px rgba(15, 23, 42, 0.04);
  min-height: var(--search-control-height);
  overflow: visible;
}
.segment-route-endpoint {
  display: grid;
  align-content: center;
  gap: 2px;
  padding: 8px 12px;
  margin-bottom: 0;
  min-width: 0;
}
.segment-route-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: var(--muted);
  line-height: 1.1;
}
.segment-route-endpoint input {
  width: 100%;
  height: auto;
  min-height: 0;
  border: 0;
  outline: 0;
  appearance: none;
  background: transparent;
  box-shadow: none;
  padding: 0;
  border-radius: 0;
  text-align: left;
  font-size: 14px;
  line-height: 1.25;
  font-weight: 700;
}
.segment-route-endpoint input:hover,
.segment-route-endpoint input:focus {
  border: 0;
  outline: 0;
  box-shadow: none;
  transform: none;
}
.segment-route-divider {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 100%;
}
.segment-route-divider::before {
  content: '';
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(
    180deg,
    rgba(148, 163, 184, 0.18),
    rgba(148, 163, 184, 0.4),
    rgba(148, 163, 184, 0.18)
  );
}
.segment-swap {
  position: relative;
  z-index: 1;
  align-self: center;
  justify-self: center;
}
.segment-row .field:not(.segment-route-endpoint) input {
  text-align: center;
  font: inherit;
  font-size: 13px;
  font-weight: 700;
}
.segment-row .field:not(.segment-route-endpoint) input::placeholder {
  color: var(--ink);
  font-weight: 700;
  opacity: 1;
}
.traveler-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.traveler-head h4 {
  font-size: 15px;
}
#travelerSummary {
  font-size: 12px;
  color: var(--muted);
}
.traveler-grid {
  display: grid;
  gap: 8px;
}
.traveler-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 12px;
  background: var(--surface-soft);
  padding: 10px;
}
.traveler-row strong {
  display: block;
  font-size: 13px;
}
.traveler-row small {
  color: var(--muted);
  font-size: 11px;
}
.counter {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.counter button {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink-soft);
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  transition:
    transform 0.18s var(--btn-ease),
    background 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease;
}
.counter span {
  min-width: 16px;
  text-align: center;
  font-size: 13px;
  font-weight: 600;
}
.toggle {
  display: flex;
  align-items: center;
  gap: 9px;
  color: var(--ink-soft);
  font-size: 13px;
  margin-bottom: 12px;
}
.inline-toggle {
  margin-bottom: 0;
}
.suggestions {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--shadow-md);
  z-index: 260;
  overflow: auto;
  max-height: 48vh;
  display: none;
}
#search .route-pair .suggestions,
#search .field-grid .suggestions {
  z-index: 320;
}
.suggestions.active {
  display: block;
}
#bookingChangeOverlay .booking-change-slice,
#bookingChangeOverlay .booking-change-card,
#bookingChangeOverlay .booking-change-slices {
  overflow: visible;
}
[data-theme='dark'] .calendar-trend {
  border-color: rgba(74, 165, 255, 0.2);
  background: linear-gradient(
    135deg,
    rgba(74, 165, 255, 0.12),
    rgba(68, 215, 182, 0.08)
  );
}
[data-theme='dark'] .calendar-trend-label {
  color: #8ec0ff;
}
[data-theme='dark'] .calendar-trend-copy strong {
  color: #eef4ff;
}
[data-theme='dark'] .calendar-chart-card,
[data-theme='dark'] .calendar-card {
  border-color: rgba(146, 178, 244, 0.16);
  background: linear-gradient(
      180deg,
      rgba(15, 22, 37, 0.94),
      rgba(10, 16, 28, 0.98)
    ),
    radial-gradient(
      circle at top right,
      rgba(74, 165, 255, 0.1),
      transparent 38%
    );
  box-shadow:
    0 14px 28px rgba(0, 0, 0, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
[data-theme='dark'] .calendar-weekday,
[data-theme='dark'] .calendar-card .calendar-meta {
  color: rgba(237, 243, 255, 0.68);
}
[data-theme='dark'] .calendar-card strong,
[data-theme='dark'] .calendar-card .calendar-price {
  color: #eef4ff;
}
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(124px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.calendar-shell {
  display: grid;
  gap: 12px;
}
.calendar-trend {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 18px;
  background: linear-gradient(
    135deg,
    rgba(10, 132, 255, 0.1),
    rgba(26, 170, 208, 0.1)
  );
  border: 1px solid rgba(10, 132, 255, 0.14);
}
.calendar-trend-copy {
  display: grid;
  gap: 4px;
}
.calendar-trend-label {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #0b5bbf;
}
.calendar-trend-copy strong {
  font-size: 16px;
  letter-spacing: -0.02em;
}
.calendar-trend-arrow {
  min-width: 66px;
  display: grid;
  place-items: center;
  font-size: 16px;
}
.calendar-trend-badge {
  border-radius: 999px;
  padding: 7px 10px;
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 10px 18px rgba(10, 132, 255, 0.14);
}
.calendar-chart-card {
  height: 128px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.95),
      rgba(245, 249, 255, 0.9)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.12),
      transparent 34%
    );
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(17, 32, 56, 0.05);
}
.calendar-chart {
  display: block;
  width: 100%;
  height: 100%;
}
.calendar-card {
  padding: 13px 13px 12px;
  text-align: left;
  border-radius: 20px;
  border: 1px solid rgba(8, 86, 160, 0.12);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.96),
      rgba(245, 249, 255, 0.92)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.12),
      transparent 38%
    );
  box-shadow: 0 10px 24px rgba(17, 32, 56, 0.05);
  overflow: hidden;
  min-height: 118px;
  display: grid;
  gap: 6px;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.calendar-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.calendar-weekday {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}
.calendar-card strong {
  display: block;
  margin-bottom: 0;
  font-size: 15px;
  letter-spacing: -0.02em;
}
.calendar-card .calendar-price {
  font-size: 19px;
  font-weight: 900;
  letter-spacing: -0.04em;
}
.calendar-card .calendar-meta {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  margin-top: 4px;
  font-size: 11px;
  color: var(--muted);
}
.calendar-card .calendar-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background: rgba(10, 132, 255, 0.1);
  color: #0b5bbf;
  margin-left: auto;
}
.calendar-card[data-band='cheap'] {
  border-color: rgba(37, 99, 235, 0.16);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(241, 247, 255, 0.95)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.18),
      transparent 38%
    );
}
.calendar-card[data-band='cheap'] .calendar-price {
  color: #0b5bbf;
}
.calendar-card[data-band='mid'] .calendar-price {
  color: #0f172a;
}
.calendar-card[data-band='expensive'] {
  border-color: rgba(220, 38, 38, 0.14);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(255, 245, 245, 0.95)
    ),
    radial-gradient(
      circle at top right,
      rgba(248, 113, 113, 0.16),
      transparent 38%
    );
}
.calendar-card[data-band='expensive'] .calendar-price {
  color: #b42318;
}
.forecast-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  margin-bottom: 16px;
  color: var(--ink-soft);
  font-size: 13px;
}
.forecast-card strong {
  color: var(--ink);
}
.results-summary {
  margin: 0 0 8px;
  color: var(--muted);
}
.explore-grid,
.flex-grid,
.results-grid,
.booking-list,
.recent-searches {
  display: grid;
  gap: 10px;
}
.results-grid.view-list {
  grid-template-columns: 1fr;
}
.results-grid.view-grid {
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr));
  gap: 12px;
}
.results-grid.view-grid .result-card {
  height: 100%;
}
.results-grid.view-grid .result-trip-stack {
  gap: 8px;
}
.results-grid.view-grid .result-trip-line + .result-trip-line {
  padding-top: 8px;
  border-top: 1px solid rgba(0, 113, 227, 0.1);
}
.explore-card,
.flex-card,
.result-card,
.booking-card,
.recent-card {
  padding: 12px;
}
.explore-card,
.recent-card,
.result-card .row,
.booking-card .row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.flex-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 16px;
}
.flex-card {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.9);
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 5px;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease;
}
.flex-card:hover {
  transform: translateY(-1px);
  border-color: rgba(0, 113, 227, 0.32);
  box-shadow: var(--shadow-sm);
}
.flex-card strong {
  font-size: 13px;
}
.flex-card small {
  color: var(--muted);
  font-size: 11px;
}
.flex-card .price {
  font-weight: 700;
  color: #0a4f98;
}
.flex-card.is-selected {
  border-color: rgba(0, 113, 227, 0.52);
  background: linear-gradient(
    180deg,
    rgba(10, 132, 255, 0.14),
    rgba(255, 255, 255, 0.94)
  );
  box-shadow: 0 10px 22px rgba(0, 113, 227, 0.16);
}
.result-card .row + .row {
  margin-top: 10px;
}
.badge {
  border-radius: 999px;
  padding: 4px 9px;
  background: rgba(0, 113, 227, 0.12);
  color: var(--blue);
  font-size: 11px;
  font-weight: 700;
}
.pill {
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 700;
  background: rgba(0, 113, 227, 0.12);
  color: var(--blue);
}
.pill.tone-live {
  background: rgba(21, 128, 61, 0.15);
  color: var(--green);
}
.pill.tone-loading {
  background: rgba(0, 113, 227, 0.12);
  color: var(--blue);
}
.pill.tone-error {
  background: rgba(180, 35, 24, 0.12);
  color: var(--red);
}
#search .search-hero {
  margin-top: 20px;
  padding: 16px 16px 14px;
  border-radius: 30px;
  background: radial-gradient(
      115% 92% at 0% 0%,
      rgba(10, 132, 255, 0.15),
      rgba(10, 132, 255, 0) 52%
    ),
    radial-gradient(
      108% 96% at 100% 0%,
      rgba(26, 212, 181, 0.12),
      rgba(26, 212, 181, 0) 46%
    ),
    radial-gradient(
      96% 64% at 50% 100%,
      rgba(255, 255, 255, 0.58),
      rgba(255, 255, 255, 0) 70%
    ),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98) 0%,
      rgba(245, 249, 255, 0.95) 100%
    ),
    var(--surface);
  border: 1px solid rgba(148, 163, 184, 0.22);
  box-shadow:
    0 24px 62px rgba(15, 23, 42, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.86);
  position: relative;
  z-index: 160;
  overflow: visible;
  backdrop-filter: blur(18px);
}
#search .search-hero.traveler-open,
#search .search-hero.cabin-open {
  z-index: 220;
}
#search .search-hero:focus-within {
  z-index: 240;
}
#search .search-hero::before {
  content: '';
  position: absolute;
  inset: 8px;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  box-shadow: inset 0 0 0 1px rgba(10, 132, 255, 0.05);
  pointer-events: none;
}
#search .search-hero::after {
  content: none;
  pointer-events: none;
}
#search .search-hero .panel-header.compact h2 {
  font-size: clamp(2.1rem, 1.85rem + 0.85vw, 2.75rem);
  font-weight: 800;
  letter-spacing: -0.03em;
}
#search .search-hero .panel-header.compact {
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  margin-bottom: 10px;
}
#search .search-hero .search-hero-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}
#search .search-hero .search-hero-top h2 {
  grid-column: 1;
  grid-row: 1;
  justify-self: start;
}
#search .search-hero .search-hero-top .pill {
  grid-column: 3;
  grid-row: 1;
  width: fit-content;
  margin-left: auto;
  justify-self: end;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid rgba(10, 132, 255, 0.18);
  background: linear-gradient(
      180deg,
      rgba(235, 244, 255, 0.95),
      rgba(226, 239, 255, 0.88)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 10px 20px rgba(15, 23, 42, 0.08);
}
#search .search-hero .panel-header.compact h2 {
  margin-top: 0;
  flex: 0 1 auto;
}
#search .search-hero .surface-lead {
  margin-top: 1px;
  font-size: 11px;
  line-height: 1.45;
  max-width: 50ch;
  color: var(--ink-soft);
}
#search .search-shell.is-results-mode {
  gap: 16px;
}
#search .search-results-toolbar {
  overflow: hidden;
  max-height: 140px;
  opacity: 1;
  margin-bottom: 14px;
  transform: translateY(0);
  transition:
    max-height 0.34s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.28s ease,
    margin-bottom 0.34s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
}
#search .search-shell.is-results-form-expanded .search-results-toolbar {
  max-height: 0;
  opacity: 0;
  margin-bottom: 0;
  pointer-events: none;
  transform: translateY(-8px);
}
#search .search-prep-shell.search-prep-inline {
  position: relative;
  z-index: 80;
  overflow: visible;
  max-height: min(640px, 92vh);
  opacity: 1;
  transform: translateY(0);
  transition:
    max-height 0.34s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.28s ease,
    transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
}
#search .search-prep-shell.search-prep-inline.is-search-prep-entering,
#search .search-prep-shell.search-prep-inline.is-search-prep-exiting {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(-10px);
  pointer-events: none;
}
#search
  .search-shell.is-results-form-expanded
  .search-prep-shell.search-prep-inline
  .search-hero {
  z-index: 1;
  overflow: visible;
}
#search
  .search-shell.is-results-form-expanded
  .search-prep-shell.search-prep-inline
  .search-hero.traveler-open {
  z-index: 120;
}
#search
  .search-shell.is-results-form-expanded
  .search-prep-shell.search-prep-inline
  .search-hero:focus-within {
  z-index: 110;
}
#search
  .search-shell.is-results-form-expanded
  .search-prep-shell.search-prep-inline
  .traveler-field.is-open {
  z-index: 130;
}
#search
  .search-shell.is-results-form-expanded
  .search-prep-shell.search-prep-inline
  .traveler-dropdown-panel {
  z-index: 140;
}
#search .search-prep-shell.search-prep-inline .search-hero {
  margin-top: 20px;
}
#search .search-results-toolbar.hidden {
  display: none;
}
#search .search-compact-bar {
  width: 100%;
  padding: 14px 16px;
}
#search .search-compact-entry {
  margin-top: 0;
}
#search .search-compact-row {
  display: grid;
  grid-template-columns:
    minmax(0, 1.45fr) minmax(128px, 0.72fr) minmax(148px, 0.82fr)
    auto auto;
  gap: 8px;
  align-items: stretch;
}
#search .search-compact-row .route-pair {
  grid-template-columns: minmax(0, 1fr) 52px minmax(0, 1fr);
}
#search .search-compact-row .route-divider {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  align-self: stretch;
}
#search .search-compact-row .route-divider::before {
  top: 10px;
  bottom: 10px;
}
#search .search-compact-row .route-divider .swap {
  width: 34px;
  height: 34px;
  font-size: 14px;
  font-weight: 800;
  border-width: 2px;
  z-index: 3;
  pointer-events: auto;
  cursor: pointer;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  padding: 0;
  margin: 0;
  box-sizing: border-box;
  box-shadow:
    0 10px 22px rgba(15, 23, 42, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.94);
}
#search .search-compact-row .route-divider .swap::before,
#search .search-compact-row .route-divider .swap::after {
  display: none;
}
#search .search-compact-hit {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: inherit;
  cursor: pointer;
  width: 100%;
  min-width: 0;
}
#search .search-compact-hit.route-pair {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 52px minmax(0, 1fr);
  align-items: stretch;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 14px 30px rgba(15, 23, 42, 0.05);
  min-height: var(--search-control-height);
  overflow: visible;
}
#search .search-compact-hit.route-pair:hover,
#search .search-compact-hit.route-pair:focus-visible {
  border-color: rgba(0, 113, 227, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 0 0 4px rgba(0, 113, 227, 0.12),
    0 14px 30px rgba(15, 23, 42, 0.05);
  outline: none;
}
#search .search-compact-hit.date-field-wrap {
  display: grid;
  align-content: center;
  gap: 2px;
  margin-bottom: 0;
  padding: 8px 38px 8px 14px;
  min-height: var(--search-control-height);
  position: relative;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(248, 250, 253, 0.95)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 14px 30px rgba(15, 23, 42, 0.05);
  text-align: center;
}
#search .search-compact-hit.date-field-wrap .route-endpoint-label {
  justify-self: center;
}
#search .search-compact-hit.date-field-wrap:hover,
#search .search-compact-hit.date-field-wrap:focus-visible {
  border-color: rgba(0, 113, 227, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 0 0 4px rgba(0, 113, 227, 0.12),
    0 14px 30px rgba(15, 23, 42, 0.05);
  outline: none;
}
#search .search-compact-hit.traveler-field-trigger {
  justify-content: center;
  overflow: hidden;
}
#search .search-compact-hit.traveler-field-trigger:hover,
#search .search-compact-hit.traveler-field-trigger:focus-visible {
  border-color: rgba(0, 113, 227, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 0 0 4px rgba(0, 113, 227, 0.12),
    0 14px 30px rgba(15, 23, 42, 0.05);
  outline: none;
}
#search .search-compact-travelers span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
#search .search-compact-value {
  display: block;
  font-size: 15px;
  line-height: 1.25;
  font-weight: 700;
  color: var(--ink);
}
#search .search-compact-value.date-field {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  min-height: 0;
  height: auto;
}
#search .search-compact-submit {
  min-width: 118px;
  min-height: var(--search-control-height);
  width: auto;
  align-self: stretch;
  padding-inline: 22px;
}
#search .search-compact-submit.is-loading {
  opacity: 0.88;
}
#search .search-results-status {
  align-self: center;
  flex-shrink: 0;
  white-space: nowrap;
}
#search .results-grid.view-list {
  gap: 12px;
  width: 100%;
  max-width: min(100%, 720px);
  margin-inline: auto;
}
#search .results-grid.view-list .result-card {
  max-width: 100%;
}
@media (max-width: 980px) {
  #search .search-compact-row {
    grid-template-columns: 1fr 1fr auto;
  }
  #search .search-compact-route {
    grid-column: 1 / -1;
  }
  #search .search-compact-dates {
    grid-column: 1;
  }
  #search .search-compact-travelers {
    grid-column: 2;
  }
  #search .search-compact-submit {
    grid-column: 3;
  }
  #search .search-results-status {
    grid-column: 1 / -1;
    justify-self: end;
  }
}
@media (max-width: 860px) {
  #search .search-compact-row {
    grid-template-columns: 1fr;
  }
  #search .search-compact-row > * {
    grid-column: 1 / -1;
  }
  #search .search-compact-submit {
    width: 100%;
  }
  #search .search-results-status {
    justify-self: center;
  }
}
#search .search-prep-card {
  border-radius: 20px;
  border: 1px solid var(--line);
  background: radial-gradient(
      100% 80% at 100% 0%,
      rgba(10, 132, 255, 0.08),
      rgba(10, 132, 255, 0)
    ),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.96),
      rgba(246, 249, 255, 0.93)
    );
  padding: 18px;
  display: grid;
  gap: 8px;
}
#search .search-prep-card h3 {
  font-size: 18px;
  letter-spacing: -0.02em;
}
#search .search-prep-card p {
  color: var(--ink-soft);
  font-size: 14px;
}
#search .search-results-workspace {
  display: block;
}
#search .search-results-columns {
  display: block;
}
#search .search-insights-panel {
  display: grid;
  gap: 12px;
  margin-bottom: 16px;
}
#search .search-insights-options {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
}
#search .search-refine-column {
  position: sticky;
  top: 18px;
}
#search .search-results-column {
  position: relative;
  display: grid;
  gap: 12px;
}
#search .search-results-column.is-results-loading {
  min-height: min(280px, 42vh);
}
#search #showAllButton {
  width: 100%;
  min-height: 46px;
  border-radius: 18px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.01em;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid var(--line);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}
#search #showAllButton:not(:disabled):not(.no-motion):hover,
#search #showAllButton:not(:disabled):not(.no-motion).is-hovered {
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(10, 132, 255, 0.22);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}
#search .search-hero-top .trip-toggle {
  grid-column: 2;
  grid-row: 1;
  margin: 0 auto;
  justify-self: center;
  align-self: center;
  width: fit-content;
  max-width: 100%;
}
#search .search-entry-form {
  --search-control-height: 50px;
  --search-col-1: minmax(230px, 1.3fr);
  --search-col-2: minmax(230px, 1.3fr);
  --search-col-3: minmax(180px, 0.95fr);
  --search-col-4: minmax(165px, 0.85fr);
  margin-top: 4px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  align-items: start;
  overflow: visible;
}
#search .search-actions {
  display: contents;
}
#search .search-entry-form.multi-city-mode .travel-meta-grid .traveler-field,
#search .search-entry-form.multi-city-mode .travel-meta-grid .cabin-field {
  display: none;
}
#search .search-entry-form.multi-city-mode .search-actions {
  display: flex;
  grid-column: 1 / -1;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
  width: 100%;
}
#search .search-entry-form.multi-city-mode .search-actions .primary,
#search .search-entry-form.multi-city-mode .search-actions .secondary {
  width: auto;
  min-width: 150px;
}
#search .nearby-block,
#search .multi-city {
  background: transparent;
  border: none;
  padding: 0;
  margin-bottom: 0;
}
#search .multi-city .panel-header.compact {
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
#search .search-hero.multi-city-mode::after {
  display: none;
}
#search .travel-meta-grid {
  display: grid;
  grid-template-columns:
    var(--search-col-1) var(--search-col-2) var(--search-col-3)
    var(--search-col-4);
  gap: 8px;
  grid-column: 1 / -1;
  align-items: stretch;
  overflow: visible;
}
#searchButton {
  grid-column: 3;
}
#resetSearchButton {
  grid-column: 4;
}
#search .traveler-field,
#search .cabin-field {
  margin-bottom: 0;
  position: relative;
  z-index: 1;
  overflow: visible;
}
#search .traveler-field {
  z-index: 2;
}
#search .traveler-field.is-open,
#search .cabin-field.is-open {
  z-index: 90;
}
#search .traveler-field-trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: var(--search-control-height);
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  color: var(--ink);
  padding: 12px 34px 12px 14px;
  text-align: center;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.75),
    0 1px 0 rgba(15, 23, 42, 0.02),
    0 14px 28px rgba(15, 23, 42, 0.05);
  font: inherit;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.2;
  position: relative;
}
#search .traveler-field-trigger span {
  flex: 1;
  text-align: center;
  font-weight: 700;
}
#search .traveler-field-trigger.placeholder {
  color: var(--ink);
}
#search .traveler-field-trigger.placeholder .traveler-caret {
  color: var(--muted);
}
#search #travelerSummary {
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: 0.01em;
  line-height: 1;
}
#search .traveler-caret {
  color: var(--muted);
  font-size: 12px;
  margin-left: 0;
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
}
#search .traveler-dropdown-panel,
#search .cabin-dropdown-panel {
  display: grid;
  gap: 6px;
  padding: 8px;
  border-radius: 15px;
  border: 1px solid var(--line);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  box-shadow: 0 20px 42px rgba(15, 23, 42, 0.12);
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  width: min(100%, 320px);
  max-width: 100%;
  z-index: 120;
}
#search .cabin-select-native {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
#search .cabin-field-trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: var(--search-control-height);
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  color: var(--ink);
  padding: 12px 34px 12px 14px;
  text-align: center;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.75),
    0 1px 0 rgba(15, 23, 42, 0.02),
    0 14px 28px rgba(15, 23, 42, 0.05);
  font: inherit;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.2;
  position: relative;
  cursor: pointer;
}
#search .cabin-field-trigger span {
  flex: 1;
  text-align: center;
  font-weight: 700;
}
#search .cabin-field-trigger.placeholder {
  color: var(--ink);
}
#search .cabin-field-trigger.placeholder .cabin-caret {
  color: var(--muted);
}
#search .cabin-caret {
  color: var(--muted);
  font-size: 12px;
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
}
#search .cabin-dropdown-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid rgba(22, 37, 60, 0.08);
  border-radius: 12px;
  background: rgba(246, 249, 255, 0.92);
  color: var(--ink);
  font: inherit;
  font-size: 15px;
  font-weight: 700;
  text-align: left;
  cursor: pointer;
}
#search .cabin-dropdown-option:hover,
#search .cabin-dropdown-option:focus-visible {
  border-color: rgba(10, 132, 255, 0.32);
  background: rgba(239, 246, 255, 0.98);
  outline: none;
}
#search .cabin-dropdown-option.is-selected {
  border-color: rgba(10, 132, 255, 0.42);
  background: rgba(219, 234, 254, 0.95);
  color: #0b63ce;
}
#search .cabin-dropdown-option.is-selected::after {
  content: '✓';
  font-size: 14px;
  font-weight: 900;
}
#search .segment-traveler-field {
  z-index: 3;
}
#search .segment-traveler-panel {
  width: min(300px, calc(100vw - 32px));
  z-index: 70;
}
#search .segment-cabin-field select {
  width: 100%;
}
#search .traveler-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 11px;
  background: rgba(246, 249, 255, 0.92);
  border: 1px solid var(--line);
}
#search .traveler-row strong {
  font-size: 12px;
}
#search .traveler-row small {
  font-size: 10px;
}
#search .counter {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  padding: 2px;
  border: 1px solid var(--line);
}
#search .search-results-panel .panel-header h3 {
  font-size: 17px;
}
#search .results-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}
#search .results-kpis-wide {
  display: grid;
  grid-template-columns: minmax(280px, 0.36fr) minmax(0, 0.64fr);
  gap: 14px;
  margin-bottom: 10px;
  margin-top: 0;
  align-items: stretch;
}
#search .results-kpi-stack {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
#search .results-kpi-matches {
  display: grid;
  min-height: 72px;
  align-content: space-between;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
}
#search .results-kpi-matches-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}
#search .results-kpi-matches-primary {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--ink);
}
#search .results-kpi-matches-secondary {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.35;
  color: var(--muted);
}
#search .results-kpi-matches-secondary:empty {
  display: none;
}
[data-theme='dark'] #search .results-kpi-matches-primary {
  color: var(--ink);
}
[data-theme='dark'] #search .results-kpi-matches-secondary {
  color: rgba(237, 243, 255, 0.68);
}
#search .field-grid {
  position: relative;
  grid-template-columns:
    var(--search-col-1) var(--search-col-2) var(--search-col-3)
    var(--search-col-4);
  gap: 8px;
  grid-column: 1 / -1;
  align-items: end;
}
#fieldGrid > #routePair {
  grid-column: 1 / 3;
}
#fieldGrid > #departField {
  grid-column: 3;
}
#fieldGrid > #returnField {
  grid-column: 4;
}
#search .route-pair {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 68px minmax(0, 1fr);
  align-items: stretch;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.96)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 14px 30px rgba(15, 23, 42, 0.05);
  min-height: var(--search-control-height);
  overflow: visible;
}
#search .route-endpoint {
  display: grid;
  align-content: center;
  gap: 2px;
  padding: 8px 14px;
  position: relative;
}
#search .route-endpoint-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: var(--muted);
  line-height: 1.1;
}
#search .route-endpoint input {
  width: 100%;
  height: auto;
  min-height: 0;
  border: 0;
  outline: 0;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  box-shadow: none;
  padding: 0;
  border-radius: 0;
  text-align: left;
  font-size: 15px;
  line-height: 1.25;
  font-weight: 700;
}
#search .route-endpoint input::placeholder {
  color: var(--ink);
  opacity: 0.9;
}
#search .route-endpoint input:hover,
#search .route-endpoint input:focus {
  border: 0;
  outline: 0;
  box-shadow: none;
  transform: none;
}
#search .route-endpoint input:focus-visible {
  outline: 0;
  box-shadow: none;
}
#search .route-divider {
  position: relative;
  display: grid;
  place-items: center;
}
#search .route-divider::before {
  content: '';
  position: absolute;
  top: 9px;
  bottom: 9px;
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(
    180deg,
    rgba(148, 163, 184, 0.25),
    rgba(148, 163, 184, 0.62),
    rgba(148, 163, 184, 0.25)
  );
}
#search .field {
  margin-bottom: 0;
}
#swapButton {
  position: relative;
  left: auto;
  top: auto;
  transform: none;
  z-index: 3;
  width: 44px;
  height: 44px;
  border-width: 2px;
  font-size: 18px;
  margin-bottom: 0;
}
#search .field input,
#search .field select,
#search .traveler-field-trigger {
  height: var(--search-control-height);
  min-height: var(--search-control-height);
  padding: 12px 14px;
  border-radius: 18px;
  font-size: 15px;
  font-family: inherit;
  font-weight: 700;
  line-height: 1.2;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(248, 250, 253, 0.95)
    ),
    var(--surface);
  border-color: var(--line-strong);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 1px 0 rgba(15, 23, 42, 0.03),
    0 14px 30px rgba(15, 23, 42, 0.05);
  text-align: center;
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.18s ease;
}
#search .segment-route-endpoint input {
  width: 100%;
  height: auto;
  min-height: 0;
  border: 0;
  outline: 0;
  appearance: none;
  background: transparent;
  box-shadow: none;
  padding: 0;
  border-radius: 0;
  text-align: left;
  font-size: 15px;
  line-height: 1.25;
  font-weight: 700;
}
#search .segment-route-endpoint input::placeholder {
  color: var(--ink);
  opacity: 0.9;
}
#search .segment-route-endpoint input:hover,
#search .segment-route-endpoint input:focus,
#search .segment-route-endpoint input:focus-visible {
  border: 0;
  outline: 0;
  box-shadow: none;
  transform: none;
}
#search .date-field-wrap {
  position: relative;
}
#search .date-field-wrap::after {
  content: '';
  position: absolute;
  right: 15px;
  top: 50%;
  width: 16px;
  height: 16px;
  transform: translateY(-50%);
  background-color: var(--muted);
  opacity: 0.95;
  pointer-events: none;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='3'/%3E%3Cpath d='M8 3v4M16 3v4M3 11h18'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='3'/%3E%3Cpath d='M8 3v4M16 3v4M3 11h18'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}
#search .date-field-wrap input.date-field {
  padding-right: 38px;
}
#search .field input:hover,
#search .field select:hover,
#search .traveler-field-trigger:hover,
#search .cabin-field-trigger:hover {
  border-color: rgba(15, 23, 42, 0.24);
  transform: translateY(-1px);
}
#search .field input:focus,
#search .field select:focus,
#search .traveler-field-trigger:focus-visible,
#search .cabin-field-trigger:focus-visible {
  border-color: rgba(10, 132, 255, 0.74);
  box-shadow:
    0 0 0 3px rgba(10, 132, 255, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.72);
  transform: translateY(-1px);
}
#search .travel-meta-grid .field input,
#search .travel-meta-grid .field select,
#search .traveler-field-trigger,
#search .cabin-field-trigger {
  box-sizing: border-box;
}
#search .field input::placeholder {
  color: var(--ink);
  font-weight: 700;
  letter-spacing: 0.01em;
  opacity: 1;
}
#search .trip-toggle {
  padding: 4px;
  gap: 4px;
  grid-column: auto;
  width: fit-content;
  justify-self: start;
  border: 1px solid rgba(148, 163, 184, 0.32);
  border-radius: 999px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.94),
      rgba(244, 248, 255, 0.88)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.8),
    0 8px 16px rgba(15, 23, 42, 0.06);
}
#search .tab {
  min-height: 38px;
  padding: 8px 16px;
  font-size: 14px;
  font-weight: 700;
  border-radius: 999px;
}
#search .tab.active {
  background: linear-gradient(135deg, #0a84ff, #4f8cff);
  color: #fff;
  box-shadow:
    0 10px 20px rgba(10, 132, 255, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
#search .counter button {
  width: 24px;
  height: 24px;
}
#search .search-actions .primary,
#search .search-actions .secondary {
  padding-block: 12px;
  min-height: var(--search-control-height);
  border-radius: 18px;
  width: 100%;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.01em;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    filter 0.18s ease;
}
#search .search-actions .primary {
  background: linear-gradient(135deg, #0a84ff, #4f8cff);
  box-shadow:
    0 18px 34px rgba(10, 132, 255, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
#search .search-actions .primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 21px 38px rgba(10, 132, 255, 0.28);
}
#search .search-actions .primary.is-loading {
  background: linear-gradient(135deg, #0a84ff, #66a6ff, #0a84ff);
  background-size: 220% 220%;
  animation: searchButtonShimmer 1.2s ease-in-out infinite;
  box-shadow:
    0 18px 34px rgba(10, 132, 255, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}
#search .search-actions .primary.is-loading::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.22),
    transparent
  );
  transform: translateX(-120%);
  animation: searchButtonSweep 1.2s ease-in-out infinite;
  pointer-events: none;
}
@keyframes searchButtonShimmer {
  0%,
  100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}
@keyframes searchButtonSweep {
  0% {
    transform: translateX(-120%);
  }
  50%,
  100% {
    transform: translateX(120%);
  }
}
#search .search-actions .secondary {
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 255, 0.9)
    ),
    var(--surface);
  border: 1px solid rgba(148, 163, 184, 0.4);
  color: var(--ink-soft);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 14px 26px rgba(15, 23, 42, 0.06);
}
#search .search-actions .secondary:hover {
  transform: translateY(-1px);
  filter: brightness(0.99);
  box-shadow: 0 17px 28px rgba(15, 23, 42, 0.08);
}
[data-theme='dark'] #search .search-hero {
  background: radial-gradient(
      110% 95% at 0% 0%,
      rgba(74, 165, 255, 0.2),
      rgba(74, 165, 255, 0) 52%
    ),
    radial-gradient(
      104% 90% at 100% 0%,
      rgba(68, 215, 182, 0.14),
      rgba(68, 215, 182, 0) 46%
    ),
    linear-gradient(180deg, rgba(13, 19, 31, 0.95), rgba(9, 14, 24, 0.9));
  border-color: rgba(148, 196, 255, 0.18);
  box-shadow:
    0 28px 64px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
[data-theme='dark'] #search .search-hero::before {
  border-color: rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 0 0 1px rgba(74, 165, 255, 0.12);
}
[data-theme='dark'] #search .search-hero .search-hero-top .pill {
  border-color: rgba(74, 165, 255, 0.3);
  background: linear-gradient(
    180deg,
    rgba(20, 43, 70, 0.84),
    rgba(16, 35, 58, 0.78)
  );
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 22px rgba(0, 0, 0, 0.25);
}
[data-theme='dark'] #search .trip-toggle {
  border-color: rgba(148, 196, 255, 0.22);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.07),
      rgba(255, 255, 255, 0.03)
    ),
    var(--surface);
}
[data-theme='dark'] #search .tab {
  color: rgba(237, 243, 255, 0.92);
}
[data-theme='dark'] #search .tab.active {
  background: linear-gradient(
    135deg,
    rgba(84, 135, 255, 0.92),
    rgba(57, 103, 214, 0.96)
  );
  color: #f8fbff;
  box-shadow:
    0 18px 32px rgba(20, 39, 92, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
[data-theme='dark'] #search .field input,
[data-theme='dark'] #search .field select,
[data-theme='dark'] #search .traveler-field-trigger,
[data-theme='dark'] #search .cabin-field-trigger,
[data-theme='dark'] #search .search-actions .secondary {
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06),
      rgba(255, 255, 255, 0.03)
    ),
    var(--surface);
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 14px 24px rgba(0, 0, 0, 0.22);
  color: #eef4ff;
}
[data-theme='dark'] #search .search-actions .secondary {
  color: rgba(230, 240, 255, 0.88);
}
[data-theme='dark'] #search .route-pair {
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06),
      rgba(255, 255, 255, 0.03)
    ),
    var(--surface);
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 14px 24px rgba(0, 0, 0, 0.22);
}
[data-theme='dark'] #search .route-endpoint-label {
  color: rgba(237, 243, 255, 0.9);
}
[data-theme='dark'] #search .route-endpoint input::placeholder {
  color: rgba(238, 244, 255, 0.9);
}
[data-theme='dark'] #search .route-divider::before {
  background: linear-gradient(
    180deg,
    rgba(148, 163, 184, 0.18),
    rgba(148, 163, 184, 0.5),
    rgba(148, 163, 184, 0.18)
  );
}
[data-theme='dark'] #search .multi-city,
[data-theme='dark'] #search .traveler-card {
  border-color: rgba(146, 178, 244, 0.16);
  background: linear-gradient(
      180deg,
      rgba(15, 22, 37, 0.92),
      rgba(10, 16, 28, 0.96)
    ),
    radial-gradient(
      circle at top right,
      rgba(74, 165, 255, 0.1),
      transparent 34%
    );
  box-shadow:
    0 22px 44px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
[data-theme='dark'] #search .multi-city .panel-header h3,
[data-theme='dark'] #search .traveler-head h4,
[data-theme='dark'] #search .segment-card-label,
[data-theme='dark'] #search .field label {
  color: #edf3ff;
}
[data-theme='dark'] #search .multi-city .panel-header .caption,
[data-theme='dark'] #search .segment-card-head .ghost,
[data-theme='dark'] #search #travelerSummary,
[data-theme='dark'] #search .traveler-row small {
  color: rgba(237, 243, 255, 0.9);
}
[data-theme='dark'] #search .segment-card {
  border-color: rgba(146, 178, 244, 0.14);
  background: linear-gradient(
      180deg,
      rgba(18, 27, 44, 0.94),
      rgba(12, 20, 34, 0.98)
    ),
    linear-gradient(135deg, rgba(84, 135, 255, 0.06), transparent 52%);
  box-shadow:
    0 18px 34px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
[data-theme='dark'] #search .segment-route-pair {
  border-color: rgba(146, 178, 244, 0.16);
  background: linear-gradient(
      180deg,
      rgba(17, 26, 42, 0.96),
      rgba(12, 20, 34, 0.98)
    ),
    rgba(12, 18, 31, 0.96);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 10px 22px rgba(0, 0, 0, 0.26);
}
[data-theme='dark'] #search .segment-route-label {
  color: rgba(237, 243, 255, 0.88);
}
[data-theme='dark'] #search .segment-route-endpoint input::placeholder {
  color: rgba(238, 244, 255, 0.9);
}
[data-theme='dark'] #search .segment-route-divider::before {
  background: linear-gradient(
    180deg,
    rgba(148, 163, 184, 0.2),
    rgba(148, 163, 184, 0.48),
    rgba(148, 163, 184, 0.2)
  );
}
[data-theme='dark'] #search .segment-row .field input::placeholder,
[data-theme='dark'] #search .traveler-field-trigger.placeholder,
[data-theme='dark']
  #search
  .traveler-field-trigger.placeholder
  .traveler-caret {
  color: rgba(238, 244, 255, 0.9);
}
[data-theme='dark'] #search .field input::placeholder,
[data-theme='dark'] #search .field select,
[data-theme='dark'] #search .traveler-caret,
[data-theme='dark'] #search .cabin-field-trigger.placeholder,
[data-theme='dark'] #search .cabin-field-trigger.placeholder .cabin-caret {
  color: rgba(238, 244, 255, 0.9);
}
[data-theme='dark'] #search .segment-swap,
[data-theme='dark'] #search .swap {
  border-color: rgba(111, 160, 255, 0.28);
  background: linear-gradient(
      180deg,
      rgba(22, 39, 69, 0.96),
      rgba(15, 28, 50, 0.94)
    ),
    rgba(12, 20, 34, 0.94);
  color: #8db5ff;
  box-shadow:
    0 14px 28px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}
[data-theme='dark'] #search .search-compact-hit.route-pair,
[data-theme='dark'] #search .search-compact-hit.date-field-wrap,
[data-theme='dark'] #search .search-compact-hit.traveler-field-trigger {
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06),
      rgba(255, 255, 255, 0.03)
    ),
    var(--surface);
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 14px 24px rgba(0, 0, 0, 0.22);
  color: #eef4ff;
}
[data-theme='dark'] #search .search-compact-hit.route-pair:hover,
[data-theme='dark'] #search .search-compact-hit.route-pair:focus-visible,
[data-theme='dark'] #search .search-compact-hit.date-field-wrap:hover,
[data-theme='dark'] #search .search-compact-hit.date-field-wrap:focus-visible,
[data-theme='dark'] #search .search-compact-hit.traveler-field-trigger:hover,
[data-theme='dark']
  #search
  .search-compact-hit.traveler-field-trigger:focus-visible {
  border-color: rgba(111, 160, 255, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 0 0 4px rgba(74, 165, 255, 0.14),
    0 14px 24px rgba(0, 0, 0, 0.24);
}
[data-theme='dark'] #search .search-compact-value,
[data-theme='dark'] #search .search-compact-hit .route-endpoint-label {
  color: rgba(237, 243, 255, 0.88);
}
[data-theme='dark'] #search .search-compact-value {
  color: #eef4ff;
}
[data-theme='dark'] #search .search-compact-row .route-divider .swap {
  border-color: rgba(126, 176, 255, 0.48);
  background: linear-gradient(
      180deg,
      rgba(32, 52, 88, 0.98),
      rgba(20, 36, 64, 0.96)
    ),
    rgba(14, 24, 42, 0.98);
  color: #a8c8ff;
  box-shadow:
    0 10px 22px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}
[data-theme='dark'] #search .search-compact-row .route-divider::before {
  background: linear-gradient(
    180deg,
    rgba(148, 163, 184, 0.12),
    rgba(148, 163, 184, 0.38),
    rgba(148, 163, 184, 0.12)
  );
}
[data-theme='dark'] #search .search-results-status {
  border-color: rgba(126, 176, 255, 0.28);
  background: linear-gradient(
    180deg,
    rgba(20, 43, 70, 0.84),
    rgba(16, 35, 58, 0.78)
  );
  color: #a8c8ff;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 8px 18px rgba(0, 0, 0, 0.22);
}
[data-theme='dark'] #search .results-kpi-card {
  border-color: rgba(146, 178, 244, 0.16);
  background: radial-gradient(
      circle at top right,
      rgba(74, 165, 255, 0.12),
      rgba(74, 165, 255, 0) 56%
    ),
    linear-gradient(180deg, rgba(15, 22, 37, 0.94), rgba(10, 16, 28, 0.98));
  box-shadow:
    0 14px 28px rgba(0, 0, 0, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
[data-theme='dark'] #search .results-kpi-card span {
  color: rgba(237, 243, 255, 0.72);
}
[data-theme='dark'] #search .results-kpi-card strong {
  color: #7ec8ff;
}
[data-theme='dark'] #search .results-kpi-sort:hover:not(.active) {
  border-color: rgba(126, 176, 255, 0.28);
  box-shadow:
    0 14px 26px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}
[data-theme='dark'] #search .results-kpi-sort.active {
  border-color: rgba(126, 176, 255, 0.58);
  background: linear-gradient(180deg, #4b8cff 0%, #2563eb 100%);
  box-shadow:
    0 0 0 2px rgba(74, 165, 255, 0.22),
    0 14px 28px rgba(47, 110, 232, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
}
[data-theme='dark'] #search .results-kpi-sort.active:hover {
  border-color: rgba(146, 196, 255, 0.72);
  box-shadow:
    0 0 0 2px rgba(96, 165, 255, 0.28),
    0 16px 30px rgba(47, 110, 232, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.16);
}
[data-theme='dark'] #search .results-kpi-sort.active span {
  color: rgba(255, 255, 255, 0.82);
}
[data-theme='dark'] #search .results-kpi-sort.active strong {
  color: #ffffff;
}
[data-theme='dark'] #search .results-filter-bar {
  border-color: rgba(146, 178, 244, 0.16);
  background: linear-gradient(
      180deg,
      rgba(13, 19, 31, 0.95),
      rgba(9, 14, 24, 0.92)
    ),
    var(--surface);
  box-shadow:
    0 16px 32px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}
[data-theme='dark'] #search .results-filter-label {
  color: rgba(237, 243, 255, 0.68);
}
[data-theme='dark'] #search .results-filter-reset {
  color: rgba(237, 243, 255, 0.82);
}
[data-theme='dark'] #search #showAllButton {
  background: linear-gradient(
      180deg,
      rgba(13, 19, 31, 0.95),
      rgba(9, 14, 24, 0.92)
    ),
    var(--surface);
  border-color: rgba(146, 178, 244, 0.16);
  color: rgba(237, 243, 255, 0.88);
  box-shadow:
    0 16px 32px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}
[data-theme='dark'] #search #showAllButton:not(:disabled):not(.no-motion):hover,
[data-theme='dark']
  #search
  #showAllButton:not(:disabled):not(.no-motion).is-hovered {
  background: linear-gradient(
      180deg,
      rgba(17, 24, 38, 0.98),
      rgba(12, 18, 30, 0.96)
    ),
    var(--surface);
  border-color: rgba(146, 178, 244, 0.28);
  color: #ffffff;
  box-shadow:
    0 18px 34px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
[data-theme='dark'] #search .traveler-dropdown-panel,
[data-theme='dark'] #search .cabin-dropdown-panel {
  border-color: rgba(146, 178, 244, 0.18);
  background: linear-gradient(
      180deg,
      rgba(15, 22, 37, 0.98),
      rgba(10, 16, 28, 0.99)
    ),
    radial-gradient(
      circle at top right,
      rgba(74, 165, 255, 0.12),
      transparent 36%
    );
  box-shadow:
    0 28px 52px rgba(0, 0, 0, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
[data-theme='dark'] #search .cabin-dropdown-option {
  border-color: rgba(146, 178, 244, 0.12);
  background: rgba(255, 255, 255, 0.04);
  color: #eef4ff;
}
[data-theme='dark'] #search .cabin-dropdown-option.is-selected {
  border-color: rgba(111, 160, 255, 0.42);
  background: rgba(37, 99, 235, 0.22);
  color: #dbeafe;
}
[data-theme='dark'] #search .traveler-row {
  border-color: rgba(146, 178, 244, 0.12);
  background: rgba(255, 255, 255, 0.04);
}
[data-theme='dark'] #search .traveler-row strong,
[data-theme='dark'] #search .counter span {
  color: #eef4ff;
}
[data-theme='dark'] #search .counter {
  border-color: rgba(146, 178, 244, 0.16);
  background: rgba(255, 255, 255, 0.05);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
[data-theme='dark'] #search .counter button {
  border-color: rgba(146, 178, 244, 0.16);
  background: rgba(255, 255, 255, 0.05);
  color: #a8c7ff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
#search .nearby-block,
#search .multi-city {
  grid-column: 1 / -1;
}
#search .search-entry-form .error:empty {
  display: none;
}
#search .results-kpi-card {
  border-radius: 16px;
  border: 1px solid rgba(0, 113, 227, 0.12);
  background: radial-gradient(
      circle at top right,
      rgba(0, 113, 227, 0.08),
      rgba(0, 113, 227, 0) 56%
    ),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 249, 253, 0.92)
    ),
    var(--surface);
  padding: 11px;
  display: grid;
  gap: 4px;
  box-shadow:
    0 10px 22px rgba(15, 23, 42, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
}
#search .results-kpi-card span {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-weight: 700;
}
#search .results-kpi-card strong {
  font-size: 14px;
  letter-spacing: -0.01em;
  color: var(--blue-strong);
}
#search .price-alert-switch {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 9px;
  margin: 0;
  color: var(--ink-soft);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: -0.02em;
  cursor: pointer;
  user-select: none;
}
#search .price-alert-switch input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
#search .price-alert-switch-track {
  position: relative;
  width: 48px;
  height: 28px;
  flex: 0 0 auto;
  border-radius: 999px;
  border: 1px solid rgba(239, 68, 68, 0.42);
  background: linear-gradient(135deg, #ef4444, #b91c1c);
  box-shadow:
    inset 0 1px 2px rgba(15, 23, 42, 0.08),
    0 8px 18px rgba(15, 23, 42, 0.06);
  transition:
    background 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease;
}
#search .price-alert-switch-thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: #ffffff;
  box-shadow:
    0 4px 10px rgba(15, 23, 42, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
  transition:
    transform 0.18s ease,
    background 0.18s ease;
}
#search .price-alert-switch input:checked + .price-alert-switch-track {
  border-color: rgba(52, 117, 224, 0.55);
  background: linear-gradient(135deg, #3b82f6, #1f65d6);
  box-shadow:
    0 12px 22px rgba(37, 99, 235, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}
#search
  .price-alert-switch
  input:checked
  + .price-alert-switch-track
  .price-alert-switch-thumb {
  transform: translateX(20px);
}
#search .price-alert-switch input:focus-visible + .price-alert-switch-track {
  outline: 2px solid rgba(59, 130, 246, 0.45);
  outline-offset: 3px;
}
[data-theme='dark'] #search .price-alert-switch {
  color: rgba(218, 228, 251, 0.9);
}
[data-theme='dark'] #search .price-alert-switch-track {
  border-color: rgba(248, 113, 113, 0.44);
  background: linear-gradient(135deg, #dc2626, #7f1d1d);
  box-shadow:
    inset 0 1px 2px rgba(2, 8, 23, 0.38),
    0 10px 22px rgba(2, 8, 23, 0.2);
}
[data-theme='dark'] #search .price-alert-switch-thumb {
  background: #dce7ff;
}
[data-theme='dark']
  #search
  .price-alert-switch
  input:checked
  + .price-alert-switch-track {
  border-color: rgba(143, 177, 255, 0.56);
  background: linear-gradient(135deg, #4b8cff, #2f6ee8);
}
#search .results-kpi-sort {
  width: 100%;
  text-align: left;
  appearance: none;
  cursor: pointer;
  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease;
}
#search .results-kpi-sort:hover:not(.active) {
  transform: translateY(-1px);
  border-color: rgba(0, 113, 227, 0.24);
  box-shadow:
    0 14px 26px rgba(7, 41, 84, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.86);
}
#search .results-kpi-sort:focus-visible {
  outline: 2px solid rgba(0, 113, 227, 0.42);
  outline-offset: 2px;
}
#search .results-kpi-sort.active {
  border-color: rgba(0, 113, 227, 0.55);
  background: linear-gradient(135deg, #0a84ff 0%, #0066cc 100%);
  box-shadow:
    0 14px 26px rgba(0, 113, 227, 0.28),
    0 0 0 1px rgba(0, 113, 227, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  transform: none;
}
#search .results-kpi-sort.active:hover {
  border-color: rgba(0, 113, 227, 0.68);
  box-shadow:
    0 16px 28px rgba(0, 113, 227, 0.32),
    0 0 0 1px rgba(0, 113, 227, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.26);
  transform: none;
}
#search .results-kpi-sort.active:focus-visible {
  outline-color: rgba(255, 255, 255, 0.92);
}
#search .results-kpi-sort.active span {
  color: rgba(255, 255, 255, 0.84);
}
#search .results-kpi-sort.active strong {
  color: #ffffff;
}
#search .results-kpis-wide {
  margin-bottom: 12px;
}
#search .results-kpis-wide .results-kpi-card {
  min-height: 72px;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
#searchError {
  display: none;
}
.filters-shell {
  border: 1px solid var(--line);
  border-radius: 20px;
  background: radial-gradient(
      120% 90% at 100% 0%,
      rgba(10, 132, 255, 0.08),
      rgba(10, 132, 255, 0) 54%
    ),
    linear-gradient(180deg, var(--surface), var(--surface-solid));
  padding: 14px;
  display: grid;
  gap: 10px;
  box-shadow:
    0 16px 34px rgba(15, 23, 42, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
.filters-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}
.filters-toolbar h4 {
  font-size: 14px;
  letter-spacing: -0.01em;
}
.filters-toolbar .caption {
  margin-top: 2px;
}
.filters-main {
  display: grid;
  gap: 8px;
}
.filter-block {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: linear-gradient(180deg, var(--surface-solid), var(--surface));
  padding: 10px 11px 11px;
  display: grid;
  gap: 8px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.52);
}
.filter-block-combined {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 6px;
}
.filter-block-section {
  display: grid;
  gap: 8px;
  padding: 1px 0;
}
.filter-title {
  font-size: 10px;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.sort-chip-group {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 4px;
}
.sort-chip {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: linear-gradient(180deg, var(--surface-solid), var(--surface));
  color: var(--ink-soft);
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 7px 8px;
  cursor: pointer;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.42);
}
.sort-chip:hover {
  transform: translateY(-1px);
}
.sort-chip.active {
  border-color: rgba(0, 113, 227, 0.45);
  background: linear-gradient(
    135deg,
    rgba(0, 113, 227, 0.18),
    rgba(10, 132, 255, 0.12)
  );
  color: #06509b;
  box-shadow:
    0 8px 18px rgba(0, 113, 227, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.5);
}
.sort-chip:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}
.nonstop-toggle {
  margin-bottom: 0;
  min-height: 100%;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, var(--surface-solid), var(--surface));
  padding: 9px 11px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.52);
}
.filter-block-section .nonstop-toggle {
  min-height: 40px;
}
.active-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.active-filter-chips:empty {
  display: none;
}
.active-filter-chip {
  border-radius: 999px;
  border: 1px solid rgba(0, 113, 227, 0.2);
  background: linear-gradient(
    180deg,
    rgba(0, 113, 227, 0.12),
    rgba(0, 113, 227, 0.06)
  );
  color: #08549f;
  font-size: 10px;
  font-weight: 700;
  padding: 4px 8px;
  letter-spacing: 0.01em;
}
.slider-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}
.slider-card {
  border: 1px solid var(--line);
  border-radius: 13px;
  background: linear-gradient(180deg, var(--surface-solid), var(--surface));
  padding: 9px 10px 10px;
  display: grid;
  gap: 7px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.52);
}
.slider-card input[type='range'] {
  accent-color: var(--blue);
}
.slider-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  font-size: 10px;
  font-weight: 700;
  color: var(--ink);
}
.slider-head label {
  font-size: 11px;
  color: var(--muted);
  font-weight: 700;
}
.slider-head span {
  font-size: 12px;
  color: #0b5ea8;
  font-weight: 700;
}
.result-card {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  border: 1px solid rgba(0, 113, 227, 0.14);
  background: linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.2),
      rgba(255, 255, 255, 0) 30%
    ),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.99),
      rgba(243, 248, 255, 0.95)
    );
  box-shadow:
    0 16px 28px rgba(7, 41, 84, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.84),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  padding: 10px 12px;
  display: grid;
  gap: 7px;
  cursor: pointer;
  isolation: isolate;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease;
}
.result-card:hover {
  z-index: 2;
  transform: translateY(-4px);
  border-color: rgba(0, 113, 227, 0.3);
  box-shadow:
    0 24px 42px rgba(7, 41, 84, 0.13),
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    inset 0 0 0 1px rgba(255, 255, 255, 0.28);
}
.result-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.22),
    rgba(255, 255, 255, 0) 30%,
    rgba(0, 113, 227, 0.05) 72%,
    rgba(14, 165, 233, 0.08)
  );
  pointer-events: none;
}
.result-card::after {
  content: '';
  position: absolute;
  inset: 0 0 auto;
  height: 2px;
  background: linear-gradient(
    90deg,
    rgba(0, 113, 227, 0.08),
    rgba(0, 113, 227, 0.42),
    rgba(14, 165, 233, 0.28),
    rgba(0, 113, 227, 0.08)
  );
  pointer-events: none;
}
.result-card:focus-visible {
  outline: 3px solid rgba(10, 132, 255, 0.22);
  outline-offset: 2px;
}
.result-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  position: relative;
  z-index: 1;
}
.result-airline-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.result-airline-brand .home-airline-logo {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  box-shadow: 0 8px 16px rgba(15, 23, 42, 0.13);
}
.result-airline-brand .home-airline-logo img {
  padding: 2px;
}
.result-airline-brand-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.result-airline-brand-copy strong {
  font-size: 14px;
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: #163866;
}
.result-airline-brand-copy span {
  font-size: 9px;
  line-height: 1;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.result-stops-badge {
  align-self: start;
  width: fit-content;
  margin-top: 1px;
  font-size: 8px;
  padding: 3px 7px;
}
.result-card-price {
  display: grid;
  justify-items: end;
  gap: 2px;
}
.result-currency-badge {
  background: rgba(0, 113, 227, 0.12);
  color: var(--blue-strong);
  border: 1px solid rgba(0, 113, 227, 0.16);
  font-size: 7px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.result-card-price strong {
  font-size: 19px;
  letter-spacing: -0.04em;
  color: var(--blue-strong);
  line-height: 1;
}
.result-price-caption {
  font-size: 8px;
  color: var(--blue);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.result-card-body {
  display: grid;
  gap: 7px;
  position: relative;
  z-index: 1;
}
.result-timeline {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 5px;
  align-items: center;
}
.result-point {
  display: grid;
  gap: 0;
}
.result-point.align-end {
  text-align: right;
}
.result-point strong {
  font-size: 14px;
  letter-spacing: -0.02em;
}
.result-point span {
  font-size: 10px;
  color: var(--muted);
}
.result-point-place {
  display: block;
  min-width: 0;
  max-width: 100%;
}
.result-point-place-compact {
  display: none;
}
.result-point-place-full {
  display: block;
}
.result-flight-arc {
  min-width: 88px;
  display: grid;
  justify-items: center;
  gap: 2px;
}
.result-flight-arc::before {
  content: '';
  width: 100%;
  height: 1px;
  background: linear-gradient(
    90deg,
    rgba(8, 86, 160, 0.1),
    rgba(8, 86, 160, 0.42),
    rgba(14, 165, 233, 0.34),
    rgba(8, 86, 160, 0.1)
  );
}
.result-flight-arc span {
  font-size: 8px;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.result-trip-stops {
  width: fit-content;
  justify-self: center;
  font-size: 7px;
  padding: 3px 6px;
  line-height: 1;
}
.result-card .badge {
  background: rgba(0, 113, 227, 0.1);
  color: var(--blue-strong);
  border: 1px solid rgba(0, 113, 227, 0.12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
.result-card .caption {
  color: rgba(8, 84, 159, 0.76);
}
.result-card .row {
  align-items: center;
}
.result-card .primary {
  padding: 8px 13px;
  font-size: 12px;
}
.result-meta {
  margin-top: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.results-grid.loading .result-card {
  animation: pulseResults 1s ease-in-out infinite alternate;
}
#search .search-results-workspace {
  transition:
    opacity 0.24s ease,
    transform 0.24s cubic-bezier(0.22, 1, 0.36, 1);
}
#search .search-results-workspace.is-workspace-entering {
  opacity: 0;
  transform: translateY(-12px);
}
.results-grid.is-filtering {
  opacity: 1;
}
.result-card-enter {
  opacity: 0;
  animation: resultCardEnter 0.34s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  animation-delay: var(--result-enter-delay, 0ms);
}
@keyframes resultCardEnter {
  to {
    opacity: 1;
  }
}

.fare-insight-calendar-skeleton,
.fare-insight-flex-skeleton {
  display: grid;
  gap: 8px;
}
.fare-insight-calendar-skeleton {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}
.fare-insight-flex-skeleton {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.fare-insight-skeleton-cell {
  min-height: 52px;
  border-radius: 12px;
  animation-delay: var(--skeleton-delay, 0ms);
}
.fare-insight-skeleton-card {
  min-height: 72px;
  border-radius: 14px;
  animation-delay: var(--skeleton-delay, 0ms);
}
.fare-insight-forecast-skeleton {
  display: grid;
  gap: 10px;
  padding: 4px 0;
}
.fare-insight-forecast-skeleton-chart {
  min-height: 120px;
  border-radius: 16px;
}
.fare-insight-progress {
  height: 4px;
  margin: 0 0 10px;
  border-radius: 999px;
  background: rgba(10, 132, 255, 0.12);
  overflow: hidden;
}
.fare-insight-progress-bar {
  display: block;
  width: var(--progress-pct, 0%);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #0a84ff, #5ac8fa);
  transition: width 0.24s ease;
}
#bookings .booking-ticket-skeleton {
  pointer-events: none;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  display: grid;
  gap: 12px;
}
#bookings .booking-ticket-skeleton-route,
#bookings .booking-ticket-skeleton-meta {
  display: grid;
  gap: 8px;
}
.bookings-sync-banner {
  opacity: 0;
  transform: translateY(-8px);
  transition:
    opacity 0.22s ease,
    transform 0.22s cubic-bezier(0.22, 1, 0.36, 1);
}
.bookings-sync-banner.is-visible {
  opacity: 1;
  transform: translateY(0);
}
body {
  background: radial-gradient(
      circle at 12% 18%,
      rgba(255, 211, 138, 0.22),
      transparent 24%
    ),
    radial-gradient(circle at 86% 14%, rgba(74, 144, 226, 0.2), transparent 28%),
    linear-gradient(180deg, #f3efe8 0%, #edf2f7 38%, #e7edf3 100%);
}
.bg-grid {
  opacity: 0.3;
  background-size: 36px 36px;
}
.orb-one {
  background: radial-gradient(
    circle at center,
    rgba(255, 164, 76, 0.24),
    rgba(255, 164, 76, 0)
  );
}
.orb-two {
  background: radial-gradient(
    circle at center,
    rgba(71, 132, 255, 0.22),
    rgba(71, 132, 255, 0)
  );
}
.site-header {
  background: rgba(248, 244, 238, 0.82);
  border: 1px solid rgba(84, 72, 54, 0.08);
}
.brand-mark {
  background: linear-gradient(145deg, #1d3656 0%, #3a7bc8 52%, #f4a261 100%);
}
.brand-text span {
  font-size: 18px;
  letter-spacing: -0.02em;
}
.cta-pill {
  border: 1px solid rgba(20, 42, 68, 0.12);
  background: linear-gradient(135deg, #f8fafc, #e7eef8);
  color: #15314e;
  box-shadow: 0 10px 24px rgba(21, 49, 78, 0.12);
  cursor: pointer;
}
#headerAuthButton.header-auth-button {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 6.5rem;
  width: 6.5rem;
  flex: 0 0 auto;
  white-space: nowrap;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition:
    transform 0.18s var(--btn-ease),
    box-shadow 0.18s ease,
    filter 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease;
}
#headerAuthButton.header-auth-button:hover {
  transform: var(--btn-lift);
  filter: brightness(1.04);
  box-shadow: 0 14px 28px rgba(21, 49, 78, 0.18);
  border-color: rgba(20, 42, 68, 0.22);
}
#headerAuthButton.header-auth-button:active {
  transform: var(--btn-press);
  filter: brightness(0.98);
  box-shadow: 0 6px 14px rgba(21, 49, 78, 0.14);
  transition-duration: 0.08s;
}
#headerAuthButton.header-auth-button:focus-visible {
  outline: 2px solid var(--blue);
  outline-offset: 2px;
}
[data-theme='dark'] #headerAuthButton.header-auth-button:hover {
  filter: brightness(1.08);
  box-shadow:
    0 16px 32px rgba(10, 132, 255, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
}
[data-theme='dark'] #headerAuthButton.header-auth-button:active {
  filter: brightness(0.96);
  box-shadow: 0 8px 18px rgba(10, 132, 255, 0.2);
}
.hero-stat-grid {
  display: none !important;
}
.home-command-scene {
  background: linear-gradient(
      135deg,
      rgba(255, 248, 238, 0.92),
      rgba(240, 246, 255, 0.84)
    ),
    radial-gradient(
      circle at top left,
      rgba(245, 160, 89, 0.14),
      transparent 30%
    ),
    radial-gradient(
      circle at bottom right,
      rgba(74, 144, 226, 0.16),
      transparent 34%
    );
  border: 1px solid rgba(88, 79, 62, 0.08);
}
.home-launch-panel {
  background: linear-gradient(
      160deg,
      rgba(255, 251, 245, 0.97),
      rgba(247, 250, 255, 0.92)
    ),
    radial-gradient(
      circle at top right,
      rgba(244, 162, 97, 0.14),
      transparent 28%
    );
}
.hero-panel-main h1 {
  font-size: clamp(32px, 3.4vw, 46px);
  letter-spacing: -0.04em;
}
.home-title-lockup {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.home-title-separator {
  color: #111111;
  font-size: 0.78em;
  line-height: 1;
  transform: translateY(1px);
}
[data-theme='dark'] .home-tracking-card {
  background: linear-gradient(
      180deg,
      rgba(12, 17, 29, 0.96),
      rgba(9, 14, 24, 0.94)
    ),
    radial-gradient(
      circle at top right,
      rgba(64, 126, 255, 0.12),
      transparent 32%
    );
  border-color: rgba(137, 169, 255, 0.14);
  box-shadow:
    0 26px 70px rgba(3, 8, 18, 0.52),
    inset 0 1px 0 rgba(176, 203, 255, 0.06);
}
[data-theme='dark'] .home-tracking-card .home-search-shell {
  background: linear-gradient(
    180deg,
    rgba(14, 20, 34, 0.86),
    rgba(12, 18, 31, 0.84)
  );
  border-radius: 24px;
  box-shadow: inset 0 0 0 1px rgba(137, 169, 255, 0.08);
}
[data-theme='dark'] .home-title-separator {
  color: rgba(129, 171, 255, 0.22);
}
[data-theme='dark'] .home-track-mode-switch {
  background: rgba(12, 19, 34, 0.92);
  box-shadow: inset 0 0 0 1px rgba(137, 169, 255, 0.12);
}
[data-theme='dark'] .home-track-mode-pill {
  color: rgba(201, 214, 244, 0.78);
}
[data-theme='dark'] .home-track-mode-pill.active {
  background: linear-gradient(
    180deg,
    rgba(80, 134, 255, 0.98),
    rgba(62, 116, 237, 0.96)
  );
  color: #f8fbff;
  box-shadow: 0 10px 24px rgba(26, 74, 175, 0.34);
}
[data-theme='dark'] .home-tracking-card .field {
  background: rgba(0, 0, 0, 0);
}
[data-theme='dark'] .home-tracking-card .field input,
[data-theme='dark'] .home-tracking-card .field button,
[data-theme='dark'] .home-track-date-field input {
  background: linear-gradient(
    180deg,
    rgba(24, 30, 45, 0.96),
    rgba(20, 26, 40, 0.94)
  );
  border-color: rgba(137, 169, 255, 0.12);
  color: #eef4ff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
[data-theme='dark'] .home-tracking-card .field input::placeholder,
[data-theme='dark'] .home-track-date-field input::placeholder {
  color: rgba(176, 190, 221, 0.62);
}
[data-theme='dark'] .home-track-flight-field,
[data-theme='dark'] .home-track-route-pair,
[data-theme='dark'] .home-track-date-field {
  border-color: rgba(255, 255, 255, 0.14);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06),
      rgba(255, 255, 255, 0.03)
    ),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 14px 24px rgba(0, 0, 0, 0.22);
}
[data-theme='dark'] .home-tracking-card .home-track-flight-field input,
[data-theme='dark'] .home-tracking-card .home-track-route-endpoint input,
[data-theme='dark'] .home-track-date-field input,
[data-theme='dark'] .home-tracking-card .home-track-flight-field input:hover,
[data-theme='dark'] .home-tracking-card .home-track-flight-field input:focus,
[data-theme='dark']
  .home-tracking-card
  .home-track-flight-field
  input:focus-visible,
[data-theme='dark'] .home-tracking-card .home-track-route-endpoint input:hover,
[data-theme='dark'] .home-tracking-card .home-track-route-endpoint input:focus,
[data-theme='dark']
  .home-tracking-card
  .home-track-route-endpoint
  input:focus-visible,
[data-theme='dark'] .home-track-date-field input:hover,
[data-theme='dark'] .home-track-date-field input:focus,
[data-theme='dark'] .home-track-date-field input:focus-visible {
  border: 0;
  background: transparent;
  box-shadow: none;
  color: rgba(239, 246, 255, 0.94);
  -webkit-text-fill-color: rgba(239, 246, 255, 0.94);
}
[data-theme='dark'] .home-track-flight-field > span,
[data-theme='dark'] .home-tracking-card .home-track-route-endpoint > span,
[data-theme='dark'] .home-track-date-field > span {
  color: rgba(203, 213, 225, 0.78);
}
[data-theme='dark']
  .home-tracking-card
  .home-track-flight-field
  input::placeholder,
[data-theme='dark']
  .home-tracking-card
  .home-track-route-endpoint
  input::placeholder,
[data-theme='dark'] .home-track-date-field input::placeholder {
  color: rgba(226, 232, 240, 0.78);
  -webkit-text-fill-color: rgba(226, 232, 240, 0.78);
  opacity: 1;
}
[data-theme='dark'] .home-track-route-divider::before {
  background: linear-gradient(
    180deg,
    rgba(148, 163, 184, 0.18),
    rgba(148, 163, 184, 0.5),
    rgba(148, 163, 184, 0.18)
  );
}
[data-theme='dark'] .home-track-date-field::after {
  background-color: rgba(190, 210, 244, 0.82);
}
[data-theme='dark'] .home-search-actions .ghost {
  background: linear-gradient(
    180deg,
    rgba(25, 31, 45, 0.96),
    rgba(21, 27, 39, 0.94)
  );
  border-color: rgba(137, 169, 255, 0.12);
  color: rgba(232, 239, 255, 0.9);
}
[data-theme='dark'] .home-search-actions .ghost:hover {
  border-color: rgba(137, 169, 255, 0.22);
  background: linear-gradient(
    180deg,
    rgba(30, 37, 54, 0.98),
    rgba(24, 31, 46, 0.96)
  );
}
.home-ops-panel.hidden {
  display: none !important;
}
.recent-card {
  width: 100%;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: inherit;
}
#bookings .booking-card {
  display: grid;
  gap: 10px;
  padding: 10px 11px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(245, 250, 255, 0.92)
    ),
    rgba(255, 255, 255, 0.9);
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.05);
}
#bookings .booking-signed-out-state {
  display: flex;
  justify-content: center;
  gap: 12px;
  align-items: center;
  padding: 18px 18px 16px;
  border-radius: 22px;
  border: 1px solid rgba(0, 113, 227, 0.12);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(246, 250, 255, 0.95)
    ),
    radial-gradient(
      circle at top right,
      rgba(10, 132, 255, 0.1),
      transparent 28%
    );
  box-shadow: 0 20px 48px rgba(15, 23, 42, 0.06);
}
#bookings .booking-signed-out-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}
#bookings .booking-signed-out-actions .primary,
#bookings .booking-signed-out-actions .secondary {
  min-height: 42px;
  padding-inline: 16px;
}
#bookings .booking-collections {
  display: grid;
  gap: 18px;
}
#bookings .booking-section-panel {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(15, 23, 42, 0.06);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(248, 250, 252, 0.94)
    ),
    rgba(255, 255, 255, 0.9);
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06);
}
#bookings .booking-ticket-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
#bookings .booking-ticket-tile {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(10, 132, 255, 0.12);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(243, 248, 255, 0.94)
    ),
    rgba(255, 255, 255, 0.96);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
  cursor: pointer;
  text-align: left;
  color: inherit;
  font: inherit;
}
#bookings .booking-ticket-tile::before {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  border-radius: 18px 0 0 18px;
  background: linear-gradient(180deg, #0a84ff 0%, #00c2c2 100%);
}
#bookings .booking-ticket-tile-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
}
#bookings .booking-ticket-status {
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
  color: #0b4f91;
}
#bookings .booking-ticket-status-upcoming {
  color: #166534;
}
#bookings .booking-ticket-status-history {
  color: #0b4f91;
}
#bookings .booking-ticket-status-cancelled {
  color: #b91c1c;
}
#bookings .booking-ticket-status-pending {
  color: #9a3412;
}
#bookings .booking-ticket-route {
  font-size: 11px;
  color: var(--muted);
  text-align: right;
}
#bookings .booking-ticket-leg {
  display: grid;
  gap: 2px;
}
#bookings .booking-ticket-leg strong {
  font-size: 13px;
  color: var(--ink);
}
#bookings .booking-ticket-leg-meta {
  display: grid;
  gap: 1px;
}
#bookings .booking-ticket-leg-meta span {
  font-size: 11px;
  color: var(--ink-soft);
  line-height: 1.2;
}
#bookings .booking-ticket-leg-meta span:first-child {
  font-weight: 700;
  color: var(--ink);
}
#bookings .booking-ticket-tile-title,
#bookings .booking-ticket-tile-journey {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
}
#bookings .booking-ticket-tile-title strong,
#bookings .booking-ticket-tile-journey strong {
  font-size: 13px;
  color: var(--ink);
}
#bookings .booking-ticket-tile-title span,
#bookings .booking-ticket-tile-journey span {
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}
#bookings .booking-ticket-tile-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
#bookings .booking-ticket-tile:hover {
  transform: translateY(-2px);
  border-color: rgba(10, 132, 255, 0.24);
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.1);
}
#bookings .booking-ticket-tile:active {
  transform: translateY(0);
}
#bookings .booking-ticket-tile:focus-visible {
  outline: 2px solid rgba(59, 130, 246, 0.42);
  outline-offset: 2px;
}
#bookings .booking-ticket-tile-cancelled {
  border-color: rgba(239, 68, 68, 0.18);
  background: linear-gradient(
      180deg,
      rgba(255, 244, 244, 0.98),
      rgba(255, 250, 250, 0.94)
    ),
    rgba(255, 255, 255, 0.96);
}
#bookings .booking-ticket-tile-cancelled::before {
  background: linear-gradient(180deg, #ef4444 0%, #fb7185 100%);
}
#bookings .booking-ticket-tile-upcoming::before {
  background: linear-gradient(180deg, #16a34a 0%, #10b981 100%);
}
#bookings .booking-ticket-tile-pending::before {
  background: linear-gradient(180deg, #f59e0b 0%, #f97316 100%);
}
#bookings .booking-ticket-tile-history::before {
  background: linear-gradient(180deg, #0a84ff 0%, #00c2c2 100%);
}
#bookings .booking-ticket-tile-cancelled.booking-ticket-tile-history::before {
  background: linear-gradient(180deg, #ef4444 0%, #fb7185 100%);
}
#bookings .booking-ticket-tile-pending {
  border-color: rgba(245, 158, 11, 0.24);
  background: linear-gradient(
      180deg,
      rgba(255, 251, 235, 0.98),
      rgba(255, 247, 237, 0.94)
    ),
    rgba(255, 255, 255, 0.96);
}
#bookings .booking-ticket-tile-cancelled .booking-ticket-route,
#bookings .booking-ticket-tile-cancelled .booking-ticket-tile-title span,
#bookings .booking-ticket-tile-cancelled .booking-ticket-tile-journey span {
  color: #b91c1c;
}
#bookings .booking-ticket-pill {
  display: grid;
  gap: 2px;
  padding: 8px 9px;
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.03);
  min-width: 0;
  flex: 1 1 130px;
}
#bookings .booking-ticket-pill span {
  font-size: 8px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
#bookings .booking-ticket-pill strong {
  font-size: 11px;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
#bookings .booking-ticket-pill-muted {
  background: rgba(10, 132, 255, 0.06);
}
#bookings .booking-ticket-empty {
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px dashed rgba(15, 23, 42, 0.1);
  color: var(--muted);
  background: rgba(255, 255, 255, 0.72);
}
#bookings .guest-booking-access-card {
  display: grid;
  gap: 8px;
  margin-bottom: 10px;
  padding: 10px;
  border: 1px solid rgba(0, 113, 227, 0.1);
  border-radius: 18px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(243, 248, 255, 0.94)
    ),
    rgba(255, 255, 255, 0.9);
  box-shadow:
    0 14px 32px rgba(15, 23, 42, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
[data-theme='dark'] #bookings .booking-collections {
  gap: 20px;
}
[data-theme='dark'] #bookings .booking-section-panel {
  border-color: rgba(112, 142, 204, 0.16);
  background: linear-gradient(
      180deg,
      rgba(15, 22, 37, 0.96),
      rgba(10, 16, 28, 0.98)
    ),
    radial-gradient(
      circle at top right,
      rgba(78, 121, 255, 0.12),
      transparent 34%
    );
  box-shadow:
    0 24px 56px rgba(3, 7, 18, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
[data-theme='dark'] #bookings .booking-section-panel .panel-header h2,
[data-theme='dark'] #bookings .booking-section-panel .panel-header strong,
[data-theme='dark'] #bookings .booking-ticket-leg strong,
[data-theme='dark'] #bookings .booking-ticket-tile-title strong,
[data-theme='dark'] #bookings .booking-ticket-tile-journey strong,
[data-theme='dark'] #bookings .booking-ticket-pill strong {
  color: #eff4ff;
}
[data-theme='dark'] #bookings .booking-section-panel .caption,
[data-theme='dark'] #bookings .booking-ticket-route,
[data-theme='dark'] #bookings .booking-ticket-leg-meta span,
[data-theme='dark'] #bookings .booking-ticket-tile-title span,
[data-theme='dark'] #bookings .booking-ticket-tile-journey span,
[data-theme='dark'] #bookings .booking-ticket-pill span,
[data-theme='dark'] #bookings .booking-head .caption {
  color: rgba(191, 203, 230, 0.76);
}
[data-theme='dark'] #bookings .booking-ticket-grid {
  gap: 14px;
}
[data-theme='dark'] #bookings .booking-ticket-tile {
  border-color: rgba(108, 143, 212, 0.18);
  background: linear-gradient(
      180deg,
      rgba(18, 27, 44, 0.96),
      rgba(13, 20, 33, 0.98)
    ),
    linear-gradient(135deg, rgba(109, 145, 255, 0.06), transparent 52%);
  box-shadow:
    0 18px 34px rgba(2, 6, 18, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
[data-theme='dark'] #bookings .booking-ticket-tile:hover {
  border-color: rgba(126, 164, 255, 0.3);
  box-shadow:
    0 24px 44px rgba(2, 6, 18, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
[data-theme='dark'] #bookings .booking-ticket-status-history {
  color: #8db5ff;
}
[data-theme='dark'] #bookings .booking-ticket-status-upcoming {
  color: #67d998;
}
[data-theme='dark'] #bookings .booking-ticket-status-cancelled {
  color: #ff8f8f;
}
[data-theme='dark'] #bookings .booking-ticket-status-pending {
  color: #fdba74;
}
[data-theme='dark'] #bookings .booking-ticket-tile-cancelled {
  border-color: rgba(239, 68, 68, 0.2);
  background: linear-gradient(
      180deg,
      rgba(43, 22, 28, 0.94),
      rgba(24, 15, 20, 0.98)
    ),
    linear-gradient(135deg, rgba(239, 68, 68, 0.08), transparent 54%);
}
[data-theme='dark'] #bookings .booking-ticket-tile-pending {
  border-color: rgba(251, 146, 60, 0.3);
  background: linear-gradient(
      180deg,
      rgba(56, 34, 16, 0.94),
      rgba(31, 23, 16, 0.98)
    ),
    linear-gradient(135deg, rgba(249, 115, 22, 0.12), transparent 56%);
}
[data-theme='dark']
  #bookings
  .booking-ticket-tile-cancelled
  .booking-ticket-route,
[data-theme='dark']
  #bookings
  .booking-ticket-tile-cancelled
  .booking-ticket-tile-title
  span,
[data-theme='dark']
  #bookings
  .booking-ticket-tile-cancelled
  .booking-ticket-tile-journey
  span {
  color: #ff9898;
}
[data-theme='dark'] #bookings .booking-ticket-pill {
  background: rgba(255, 255, 255, 0.03);
}
[data-theme='dark'] #bookings .booking-ticket-pill-muted {
  background: rgba(78, 121, 255, 0.1);
}
[data-theme='dark'] #bookings .booking-ticket-empty {
  border-color: rgba(112, 142, 204, 0.18);
  background: rgba(18, 27, 44, 0.72);
  color: rgba(191, 203, 230, 0.76);
}
[data-theme='dark'] #bookings .booking-signed-out-state,
[data-theme='dark'] #bookings .guest-booking-access-card {
  border-color: rgba(112, 142, 204, 0.16);
  background: linear-gradient(
      180deg,
      rgba(16, 25, 41, 0.96),
      rgba(11, 18, 31, 0.98)
    ),
    radial-gradient(
      circle at top right,
      rgba(78, 121, 255, 0.1),
      transparent 30%
    );
  box-shadow:
    0 18px 40px rgba(3, 7, 18, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
[data-theme='dark'] #bookings .booking-badge {
  background: rgba(255, 255, 255, 0.05);
  color: rgba(191, 203, 230, 0.84);
}
[data-theme='dark'] #bookings .booking-badge-success {
  background: rgba(34, 197, 94, 0.18);
  color: #7be2a2;
}
[data-theme='dark'] #bookings .booking-cancelled-badge {
  background: rgba(239, 68, 68, 0.16);
  color: #ff9797;
}
#bookings .guest-booking-access-card .panel-header {
  align-items: flex-start;
}
#bookings .guest-booking-access-card h2 {
  font-size: 15px;
}
#bookings .guest-booking-access-form {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) minmax(0, 1fr);
  gap: 6px;
  align-items: end;
}
#bookings .guest-booking-access-form .field {
  margin-bottom: 0;
}
#bookings .guest-booking-access-form .field label {
  font-size: 10px;
  margin-bottom: 4px;
}
#bookings .guest-booking-access-form .field input {
  min-height: 34px;
  padding-block: 7px;
}
#bookings .guest-booking-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
#bookings .guest-booking-access-form button {
  min-height: 34px;
  padding-inline: 11px;
  font-size: 10px;
}
#bookings #guestBookingAccessMessage.hidden {
  display: none;
}
#bookings #guestBookingAccessMessage {
  font-size: 10px;
  margin-top: 0;
}
#bookings #guestBookingAccessStatus.success {
  background: rgba(34, 197, 94, 0.14);
  color: #166534;
}
#bookings #guestBookingAccessStatus.warning {
  background: rgba(245, 158, 11, 0.14);
  color: #92400e;
}
#bookings .booking-head,
#bookings .booking-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
#bookings .booking-head strong {
  font-size: 14px;
}
#bookings .booking-head .caption {
  font-size: 11px;
}
#bookings .booking-price-stack {
  display: grid;
  justify-items: end;
  gap: 3px;
}
#bookings .booking-price-stack strong {
  font-size: 15px;
}
#bookings .booking-id-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
#bookings .booking-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
#bookings .booking-action-button {
  padding: 8px 10px;
  min-height: 32px;
  font-size: 11px;
  letter-spacing: 0.02em;
  border-radius: 11px;
}
#bookings .booking-badge {
  background: rgba(15, 23, 42, 0.06);
  color: var(--ink-soft);
}
#bookings .booking-currency-badge {
  font-size: 10px;
  letter-spacing: 0.12em;
  padding-inline: 7px;
}
#bookings .booking-badge-success {
  background: rgba(34, 197, 94, 0.14);
  color: #166534;
}
#bookings .booking-cancelled-badge {
  background: rgba(239, 68, 68, 0.12);
  color: #b91c1c;
}
#bookings .booking-detail-sheet {
  position: relative;
  z-index: 1;
  display: block;
  padding: 0;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
#bookingOverlay.itinerary-overlay {
  padding: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
#bookings .booking-detail-sheet .itinerary-sheet-head {
  flex: 0 0 auto;
  width: 100%;
}
#bookingOverlay .booking-detail-surface,
#bookings .booking-detail-surface {
  position: relative;
  border-radius: 24px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(246, 249, 255, 0.94)
    ),
    #ffffff;
  box-shadow:
    0 28px 60px rgba(15, 23, 42, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}
#bookings .booking-detail-loading,
#bookingOverlay.itinerary-overlay .booking-detail-loading {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: grid;
  place-items: center;
  padding: 24px 20px;
  border-radius: inherit;
  background: rgba(248, 250, 253, 0.45);
  backdrop-filter: blur(10px) saturate(1.08);
  -webkit-backdrop-filter: blur(10px) saturate(1.08);
}
#bookings .booking-detail-loading.hidden,
#bookingOverlay.itinerary-overlay .booking-detail-loading.hidden {
  display: none;
}
#bookings .booking-detail-loading-card,
#bookingOverlay.itinerary-overlay .booking-detail-loading-card {
  display: grid;
  justify-items: center;
  gap: 10px;
  width: min(320px, calc(100% - 24px));
  padding: 22px 26px 20px;
  border-radius: 20px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.96);
  box-shadow:
    0 22px 48px rgba(15, 23, 42, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.92);
  text-align: center;
}
#bookings .booking-detail-loading-spinner,
#bookingOverlay.itinerary-overlay .booking-detail-loading-spinner {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 3px solid rgba(10, 132, 255, 0.16);
  border-top-color: #0a84ff;
  animation: bookingReceiptSpinner 0.8s linear infinite;
}
#bookings .booking-detail-loading-title,
#bookingOverlay.itinerary-overlay .booking-detail-loading-title {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--ink);
}
#bookings .booking-detail-loading-subtitle,
#bookingOverlay.itinerary-overlay .booking-detail-loading-subtitle {
  margin: 0;
  max-width: 22rem;
  font-size: 12px;
  line-height: 1.45;
  color: var(--muted);
}
#bookings .booking-detail-loading-cta,
#bookingOverlay.itinerary-overlay .booking-detail-loading-cta {
  margin: 4px 0 0;
  max-width: 22rem;
  font-size: 12px;
  line-height: 1.45;
  font-weight: 600;
  color: var(--ink);
}
#bookings .booking-detail-loading-cta.hidden,
#bookingOverlay.itinerary-overlay .booking-detail-loading-cta.hidden {
  display: none;
}
#bookings .booking-detail-loading-card.is-payment-success,
#bookingOverlay.itinerary-overlay
  .booking-detail-loading-card.is-payment-success {
  border-color: rgba(16, 185, 129, 0.28);
  background: rgba(255, 255, 255, 0.98);
}
#bookings
  .booking-detail-loading-card.is-payment-success
  .booking-detail-loading-spinner,
#bookingOverlay.itinerary-overlay
  .booking-detail-loading-card.is-payment-success
  .booking-detail-loading-spinner {
  border-color: rgba(16, 185, 129, 0.2);
  border-top-color: #10b981;
}
#bookings
  .booking-detail-loading-card.is-payment-success
  .booking-detail-loading-title,
#bookingOverlay.itinerary-overlay
  .booking-detail-loading-card.is-payment-success
  .booking-detail-loading-title {
  color: #047857;
}
#bookings .booking-detail-loading-card.is-payment-failed,
#bookingOverlay.itinerary-overlay
  .booking-detail-loading-card.is-payment-failed {
  border-color: rgba(239, 68, 68, 0.28);
  background: rgba(255, 255, 255, 0.98);
}
#bookings
  .booking-detail-loading-card.is-payment-failed
  .booking-detail-loading-spinner,
#bookingOverlay.itinerary-overlay
  .booking-detail-loading-card.is-payment-failed
  .booking-detail-loading-spinner {
  border-color: rgba(239, 68, 68, 0.2);
  border-top-color: #ef4444;
}
#bookings
  .booking-detail-loading-card.is-payment-failed
  .booking-detail-loading-title,
#bookingOverlay.itinerary-overlay
  .booking-detail-loading-card.is-payment-failed
  .booking-detail-loading-title {
  color: #b91c1c;
}
#bookings .booking-detail-surface.is-loading-receipt {
  min-height: min(640px, calc(100vh - 96px));
}
#bookings .booking-detail-surface.is-loading-receipt .booking-detail-timeline {
  max-height: min(640px, calc(100vh - 96px));
  overflow: hidden;
  pointer-events: none;
}
#bookings .booking-receipt-skeleton {
  padding: 18px 16px 20px;
}
#bookings .booking-receipt-skeleton-hero {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  padding-bottom: 14px;
  margin-bottom: 12px;
  border-bottom: 1px dashed rgba(15, 23, 42, 0.12);
}
#bookings .booking-receipt-skeleton-status {
  width: min(280px, 72%);
  height: 30px;
  border-radius: 999px;
}
#bookings .booking-receipt-skeleton-fare {
  display: grid;
  justify-items: end;
  gap: 8px;
  min-width: 120px;
}
#bookings .booking-receipt-skeleton-kv {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}
#bookings .booking-receipt-skeleton-trip {
  display: grid;
  gap: 8px;
  padding: 12px;
  margin-bottom: 10px;
  border-radius: 16px;
  border: 1px solid rgba(15, 23, 42, 0.06);
  background: rgba(255, 255, 255, 0.72);
}
#bookings .booking-receipt-skeleton-trip-route {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
#bookings .booking-receipt-skeleton-passengers {
  display: grid;
  gap: 8px;
  margin-top: 4px;
}
#bookings
  #bookingOverlay.itinerary-overlay
  .booking-detail-sheet.is-receipt-loading {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: center;
  gap: 14px;
  padding: 12px;
  width: min(1140px, calc(100vw - 48px));
  max-height: min(880px, calc(100vh - 48px));
  box-sizing: border-box;
}
#bookings
  #bookingOverlay.itinerary-overlay
  .booking-detail-sheet.is-receipt-loading
  .booking-detail-surface {
  flex: 0 0 760px;
  width: 760px;
  max-width: calc(100vw - 120px);
}
@keyframes bookingReceiptSpinner {
  to {
    transform: rotate(360deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  #bookings .booking-detail-loading-spinner {
    animation: none;
    border-top-color: rgba(10, 132, 255, 0.45);
  }
  .post-booking-extras-product-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}
.post-booking-extras-booked {
  margin: 0 0 12px;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(37, 99, 235, 0.08);
}
.post-booking-extras-checkout-lines {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 12px 0;
}
.post-booking-extras-checkout-line {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 13px;
}
.post-booking-extras-empty {
  text-align: center;
  padding: 28px 16px 20px;
}
.post-booking-extras-empty-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  margin: 0 0 12px;
  border-radius: 999px;
  background: rgba(5, 150, 105, 0.12);
  color: #047857;
  font-size: 20px;
  font-weight: 700;
}
.post-booking-extras-empty h3 {
  margin: 0 0 8px;
  font-size: 1.05rem;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.post-booking-extras-empty-booked {
  margin: 14px auto 0;
  padding: 0;
  max-width: 360px;
  list-style: none;
  text-align: left;
  font-size: 13px;
  color: var(--muted);
}
.post-booking-extras-empty-booked li {
  padding: 6px 10px;
  border-radius: 10px;
  background: rgba(37, 99, 235, 0.06);
  margin-bottom: 6px;
}
.post-booking-extras-error-banner {
  margin: 0 0 12px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(220, 38, 38, 0.08);
  border: 1px solid rgba(220, 38, 38, 0.2);
  color: #991b1b;
  font-size: 13px;
  line-height: 1.45;
}
.post-booking-extras-error {
  padding: 20px 8px;
  text-align: center;
}
.post-booking-extras-loading {
  padding: 32px 12px;
  text-align: center;
}
.post-booking-extras-seat-map-host {
  min-height: 280px;
  margin-bottom: 12px;
}
.post-booking-extras-cart-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  margin-left: 8px;
  padding: 0 7px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.22);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}
.post-booking-extras-checkout-line-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}
.post-booking-extras-remove {
  min-height: auto;
  padding: 2px 0;
  font-size: 12px;
  color: #b91c1c;
  text-decoration: underline;
}
.post-booking-extras-remove:hover {
  color: #991b1b;
}
.post-booking-extras-checkout-total {
  display: flex;
  justify-content: space-between;
  padding-top: 10px;
  border-top: 1px solid rgba(15, 23, 42, 0.1);
  font-size: 1rem;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.post-booking-extras-seat-panel .caption {
  margin: 0 0 12px;
  line-height: 1.45;
}
.post-booking-extras-seat-panel .ghost {
  margin-top: 12px;
  min-height: 46px;
  padding-inline: 18px;
  border-radius: 999px;
}
[data-theme='dark'] .post-booking-extras-sheet .itinerary-sheet-head {
  border-bottom-color: rgba(148, 163, 184, 0.12);
}
[data-theme='dark'] .post-booking-extras-footer {
  border-top-color: rgba(148, 163, 184, 0.12);
}
[data-theme='dark'] .post-booking-extras-panel,
[data-theme='dark'] .post-booking-extras-product {
  border-color: rgba(74, 165, 255, 0.16);
  background: radial-gradient(
      circle at top left,
      rgba(74, 165, 255, 0.12),
      transparent 32%
    ),
    linear-gradient(180deg, rgba(18, 24, 39, 0.96), rgba(13, 18, 31, 0.95));
  box-shadow:
    0 16px 36px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
[data-theme='dark'] .post-booking-extras-head h3,
[data-theme='dark'] .post-booking-extras-section h3,
[data-theme='dark'] .post-booking-extras-checkout h3,
[data-theme='dark'] .post-booking-extras-empty h3,
[data-theme='dark'] .post-booking-extras-checkout-total {
  color: #f3f7ff;
}
#bookings .booking-detail-actions-row .booking-action-button-extras {
  background: linear-gradient(
    180deg,
    rgba(8, 145, 178, 0.96),
    rgba(7, 89, 133, 0.94)
  );
  color: #f0fdfa;
}
.booking-detail-sheet .booking-doc-keyvalue span {
  font-size: 9px;
  color: var(--muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 800;
}
.booking-detail-sheet .booking-doc-keyvalue strong {
  font-size: 12px;
  color: var(--ink);
  text-align: right;
  font-variant-numeric: tabular-nums;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.booking-detail-sheet .booking-doc-hero-copy .caption,
.booking-detail-sheet .booking-doc-trip-head strong,
.booking-detail-sheet .booking-doc-trip-flight,
.booking-detail-sheet .booking-manifest-field strong,
.booking-detail-sheet .booking-manifest-contact-row strong {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
#bookings .booking-manifest {
  display: grid;
  gap: 12px;
}
#bookings .booking-manifest-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.06);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(248, 250, 252, 0.96)
    ),
    rgba(255, 255, 255, 0.92);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.04);
}
#bookings .booking-manifest-card--receipt {
  position: relative;
  gap: 14px;
  padding: 15px 15px 14px;
  border: 1px solid rgba(10, 132, 255, 0.16);
  border-radius: 22px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.99),
      rgba(246, 249, 255, 0.96)
    ),
    repeating-linear-gradient(
      180deg,
      rgba(15, 23, 42, 0.013) 0,
      rgba(15, 23, 42, 0.013) 1px,
      transparent 1px,
      transparent 22px
    ),
    rgba(255, 255, 255, 0.96);
  box-shadow:
    0 16px 36px rgba(15, 23, 42, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
  overflow: hidden;
}
#bookings .booking-manifest-card--receipt::before {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 14px;
  background: radial-gradient(
      circle at 7px 8px,
      rgba(10, 132, 255, 0.22) 0 2px,
      transparent 2.4px
    ),
    radial-gradient(
      circle at 7px 22px,
      rgba(10, 132, 255, 0.14) 0 2px,
      transparent 2.4px
    ),
    radial-gradient(
      circle at 7px 36px,
      rgba(10, 132, 255, 0.14) 0 2px,
      transparent 2.4px
    ),
    radial-gradient(
      circle at 7px 50px,
      rgba(10, 132, 255, 0.14) 0 2px,
      transparent 2.4px
    ),
    linear-gradient(180deg, rgba(10, 132, 255, 0.08), rgba(10, 132, 255, 0.03));
  background-repeat: repeat-y;
  background-size: 14px 56px;
  opacity: 0.9;
  pointer-events: none;
}
#bookings .booking-manifest-card--receipt::after {
  content: '';
  position: absolute;
  inset: auto 0 0 0;
  height: 8px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(10, 132, 255, 0.12),
    transparent
  );
  pointer-events: none;
}
#bookings .booking-manifest-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
}
#bookings .booking-manifest-head h4 {
  margin: 0;
  font-size: 14px;
  letter-spacing: -0.02em;
}
#bookings .booking-manifest-count {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
#bookings .booking-manifest-list {
  display: grid;
  gap: 10px;
}
#bookings .booking-manifest-row {
  display: grid;
  gap: 8px;
  padding: 10px 10px 9px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.05);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(248, 250, 255, 0.96)
    ),
    rgba(255, 255, 255, 0.9);
  box-shadow: 0 7px 14px rgba(15, 23, 42, 0.03);
}
#bookings .booking-manifest-row-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: baseline;
}
#bookings .booking-manifest-row-head span {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
}
#bookings .booking-manifest-row-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 6px;
}
#bookings .booking-manifest-field,
#bookings .booking-manifest-contact-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
}
#bookings .booking-manifest-field span,
#bookings .booking-manifest-contact-row span {
  font-size: 9px;
  color: var(--muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
#bookings .booking-manifest-field strong,
#bookings .booking-manifest-contact-row strong {
  font-size: 11px;
  color: var(--ink);
  text-align: right;
  font-weight: 400;
  font-variant-numeric: tabular-nums;
}
#bookings .booking-manifest-contact-list {
  display: grid;
  gap: 8px;
}
#bookings .booking-manifest-contact-list--inline .booking-manifest-contact-row {
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.05);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(248, 250, 255, 0.94)
    ),
    rgba(255, 255, 255, 0.9);
}
#bookings .booking-manifest-actions {
  gap: 10px;
}
#bookings .booking-manifest-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
#bookings .booking-manifest-action-row .booking-action-button {
  border-radius: 999px;
  min-height: 28px;
  padding: 6px 10px;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
#bookings .booking-manifest-action-row .booking-action-button.secondary,
#bookings .booking-manifest-action-row .booking-action-button.ghost {
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.92),
    rgba(240, 244, 255, 0.82)
  );
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
}
#bookings .booking-manifest-action-row .booking-action-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.12);
}
#bookings .booking-detail-sheet .booking-detail-card,
.booking-detail-sheet .booking-detail-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(10, 132, 255, 0.16);
  border-radius: 24px;
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.985),
      rgba(246, 249, 255, 0.96)
    ),
    repeating-linear-gradient(
      180deg,
      rgba(15, 23, 42, 0.011) 0,
      rgba(15, 23, 42, 0.011) 1px,
      transparent 1px,
      transparent 20px
    ),
    rgba(255, 255, 255, 0.96);
  box-shadow:
    0 18px 40px rgba(15, 23, 42, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.72);
  position: relative;
  overflow: hidden;
}
#bookings .booking-detail-sheet .booking-detail-card::before,
.booking-detail-sheet .booking-detail-card::before {
  content: none;
}
#bookings .booking-detail-sheet .booking-detail-card::after,
.booking-detail-sheet .booking-detail-card::after {
  content: none;
}
.booking-detail-sheet .booking-manifest-card--receipt::before,
.booking-detail-sheet .booking-manifest-card--receipt::after {
  content: none;
}
.booking-detail-sheet .booking-manifest-row {
  display: grid;
  gap: 7px;
  padding: 9px 10px 8px;
  border-radius: 13px;
  border: 1px solid rgba(15, 23, 42, 0.05);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(248, 250, 255, 0.96)
    ),
    rgba(255, 255, 255, 0.9);
  box-shadow: 0 7px 14px rgba(15, 23, 42, 0.03);
}
.booking-detail-sheet .booking-manifest-field span,
.booking-detail-sheet .booking-manifest-contact-row span {
  font-size: 9px;
  color: var(--muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.booking-detail-sheet .booking-manifest-field strong,
.booking-detail-sheet .booking-manifest-contact-row strong {
  font-size: 11px;
  color: var(--ink);
  text-align: right;
  font-weight: 400;
  font-variant-numeric: tabular-nums;
}
.booking-detail-sheet
  .booking-manifest-contact-list--inline
  .booking-manifest-contact-row {
  padding: 9px 11px;
  border-radius: 13px;
  border: 1px solid rgba(15, 23, 42, 0.05);
  background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(248, 250, 255, 0.94)
    ),
    rgba(255, 255, 255, 0.9);
}
.booking-detail-sheet .booking-doc-panel-head--sub h4 {
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
#bookings .booking-side-receipt-body {
  display: block;
}
#bookings .booking-detail-timeline .booking-receipt {
  gap: 7px;
}
#bookings .booking-detail-timeline .duffel-receipt-summary-row {
  font-size: 0.68rem;
}
#bookings .booking-detail-timeline .duffel-receipt-details {
  gap: 5px;
}
#bookings .booking-detail-timeline .duffel-receipt-row {
  font-size: 0.72rem;
}
#bookings .booking-ticket-list {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px 11px;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.94),
    rgba(248, 250, 252, 0.88)
  );
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.03) inset;
}
#bookings .booking-ticket-line {
  font-size: 8px;
  color: var(--ink-soft);
  font-weight: 400;
}
#bookings .booking-side-receipt {
  display: grid;
  gap: 0;
}
#bookings .booking-passenger-header span {
  font-size: 8px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
#bookings .booking-passenger-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, 0.95fr) minmax(0, 0.8fr);
  gap: 8px;
  margin-top: 6px;
}
#bookings .booking-passenger-grid span,
#bookings .booking-passenger-flight-card span {
  display: block;
  margin-top: 2px;
  font-size: 8px;
  color: var(--muted);
  font-weight: 400;
}
#bookings .booking-passenger-grid strong {
  display: block;
  font-size: 8px;
  font-weight: 400;
}
#bookings .booking-payment-row:last-child,
#bookings .booking-person-row:last-child,
#bookings .booking-contact-card:last-child {
  margin-bottom: 0;
}
#bookings .booking-trip-row,
#bookings .booking-person-row,
#bookings .booking-contact-card,
#bookings .booking-payment-row {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.94),
    rgba(248, 250, 252, 0.88)
  );
  padding: 10px 11px;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.03) inset;
}
#bookings .booking-trip-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}
#bookings .booking-trip-row strong,
#bookings .booking-person-row strong,
#bookings .booking-contact-card strong,
#bookings .booking-payment-row strong {
  display: block;
  font-size: 8px;
  font-weight: 400;
}
#bookings .booking-trip-row span,
#bookings .booking-person-row span,
#bookings .booking-contact-card span,
#bookings .booking-payment-row span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 8px;
  font-weight: 400;
}
#bookings .booking-trip-times {
  text-align: right;
}
#bookings .booking-payment-list {
  gap: 8px;
}
#bookings .booking-change-sheet {
  max-width: 1040px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), #fff);
}
#bookings .booking-change-sheet .itinerary-sheet-head {
  align-items: flex-start;
}
#bookings .booking-change-grid {
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.85fr);
  align-items: start;
}
#bookings .booking-change-card {
  display: grid;
  gap: 12px;
}
#bookings .booking-change-slices {
  display: grid;
  gap: 12px;
}
#bookings .booking-change-slice {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.82);
  padding: 12px;
  display: grid;
  gap: 10px;
}
#bookings .booking-change-slice-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
#bookings .booking-change-slice-head strong {
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
#bookings .booking-change-note {
  margin-top: -2px;
  max-width: 46rem;
}
#bookings .booking-change-actions {
  display: flex;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}
#bookings .booking-change-grid .location-field {
  position: relative;
}
#bookings .booking-change-suggestions {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 4px);
  z-index: 30;
}
#bookings .booking-change-grid label {
  display: grid;
  gap: 6px;
}
#bookings .booking-change-grid span {
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
#bookings .booking-change-grid input,
#bookings .booking-change-grid select {
  width: 100%;
  min-height: 42px;
  border-radius: 12px;
  border: 1px solid var(--line);
  padding: 0 12px;
  background: rgba(255, 255, 255, 0.96);
  color: var(--ink);
  font: inherit;
}
#bookings .booking-change-grid input:focus,
#bookings .booking-change-grid select:focus {
  outline: none;
  border-color: rgba(59, 130, 246, 0.45);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}
#bookings .booking-change-offers {
  display: grid;
  gap: 12px;
}
#bookings .booking-change-offer-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.84);
  display: grid;
  gap: 10px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.04);
}
#bookings .booking-change-offer-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 12px;
  color: var(--muted);
}
#bookings .booking-change-offer-meta strong {
  color: var(--ink);
}
#bookings .booking-change-offer-trips {
  display: grid;
  gap: 4px;
  margin-top: 2px;
}
#bookings .booking-change-offer-carry {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
#bookings .booking-change-offer-carry span {
  border-radius: 999px;
  border: 1px solid rgba(59, 130, 246, 0.18);
  background: rgba(59, 130, 246, 0.08);
  color: #1d4ed8;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
}
#bookings .booking-change-offer-line {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  font-size: 12px;
  color: var(--muted);
}
#bookings .booking-change-offer-line strong {
  color: var(--ink);
}
#bookings .booking-change-offer-actions {
  display: flex;
  justify-content: flex-end;
}
#bookings .booking-change-offer-actions .secondary {
  min-height: 36px;
  padding-inline: 14px;
}
/* Mobile Optimization Pass (non-desktop breakpoints only) */
@media (max-width: 900px) {
  .app-shell {
    padding: 12px;
  }
  .site-header {
    position: static;
    top: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      'brand actions'
      'nav nav';
    align-items: center;
    gap: 12px 10px;
    padding: 14px;
    border-radius: 24px;
  }
  .brand {
    grid-area: brand;
    min-width: 0;
    gap: 10px;
  }
  .brand-mark {
    width: 40px;
    height: 40px;
    border-radius: 13px;
    font-size: 17px;
  }
  .brand-text span {
    font-size: 16px;
  }
  .header-actions {
    grid-area: actions;
    justify-self: end;
    gap: 8px;
    margin-left: 0;
  }
  .top-nav {
    grid-area: nav;
    width: 100%;
    position: static;
    left: auto;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 7px;
    padding: 7px;
    border-radius: 18px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
  }
  .top-nav::-webkit-scrollbar {
    display: none;
  }
  .nav-link {
    flex: 0 0 auto;
    min-height: 42px;
    min-width: max-content;
    padding: 9px 14px;
    border-radius: 14px;
    font-size: 13px;
    white-space: nowrap;
    scroll-snap-align: start;
  }
  .hero-panel,
  .hero-surface,
  .panel,
  .dynamic-card {
    border-radius: 20px;
  }
  main {
    display: grid;
    gap: 10px;
  }
  .hero-panel,
  .hero-surface,
  .panel {
    padding: 14px;
  }
  .home-search-shell {
    padding: 12px;
    border-radius: 18px;
  }
  .home-search-grid,
  .home-search-grid.route-mode,
  .home-track-facts {
    grid-template-columns: 1fr;
  }
  .home-search-grid #homeTrackFlightField {
    grid-column: auto;
    max-width: none;
  }
  .home-search-grid.route-mode #homeTrackRoutePair,
  .home-search-grid.route-mode #homeTrackFromField,
  .home-search-grid.route-mode #homeTrackToField,
  .home-search-grid.route-mode #homeTrackDateField {
    grid-column: auto;
  }
  .home-search-actions {
    display: grid;
    grid-template-columns: auto auto;
    align-items: stretch;
    justify-content: flex-start;
    gap: 8px;
  }
  .home-search-actions .primary,
  .home-search-actions .ghost {
    min-height: 44px;
  }
  .home-search-actions .primary {
    min-width: 190px;
    max-width: 240px;
  }
  .home-track-card,
  .home-ops-card {
    min-width: 0;
    overflow: hidden;
  }
  .home-track-topline {
    align-items: flex-start;
    flex-wrap: wrap;
  }
  .home-track-brand-wrap {
    display: grid;
    align-items: start;
    gap: 6px;
    min-width: 0;
  }
  .home-track-brand-wrap .home-airline-brand {
    min-width: 0;
  }
  .home-track-brand-wrap .home-airline-brand-copy strong {
    overflow-wrap: anywhere;
  }
  .home-track-status {
    flex-wrap: wrap;
    justify-content: flex-start;
    min-width: 0;
  }
  .home-track-route strong {
    font-size: 19px;
  }
  .home-track-route span {
    font-size: 12px;
  }
  .route-price-graph-card {
    padding: 14px;
    border-radius: 22px;
  }
  .route-price-graph-toolbar {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .route-price-route-pair {
    grid-template-columns: 1fr;
    border-radius: 16px;
  }
  .route-price-route-endpoint {
    padding: 11px 12px;
  }
  .route-price-route-divider {
    min-height: 0;
    height: 0;
    border-top: 1px solid rgba(148, 163, 184, 0.34);
  }
  .route-price-route-divider::before {
    display: none;
  }
  .route-price-route-swap {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
  }
  .route-price-graph-meta {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .route-price-graph-chart {
    min-height: 220px;
  }
  #search .search-hero {
    margin-top: 10px;
    padding: 12px 12px 11px;
    border-radius: 24px;
  }
  #search .search-hero::before {
    inset: 6px;
    border-radius: 18px;
  }
  #search .search-hero::after {
    left: 14px;
    right: 14px;
    bottom: 8px;
    height: 36px;
  }
  #search .search-hero .panel-header.compact h2 {
    font-size: clamp(1.75rem, 8vw, 2.35rem);
  }
  #search .search-hero .search-hero-top {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      'title status'
      'tabs tabs';
    gap: 8px 10px;
  }
  #search .search-hero .search-hero-top h2 {
    grid-area: title;
  }
  #search .search-hero .search-hero-top .pill {
    grid-area: status;
  }
  #search .search-hero-top .trip-toggle {
    grid-area: tabs;
    margin: 0;
    width: 100%;
  }
  #search .trip-toggle {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  #search .tab {
    min-height: 40px;
    padding: 8px 10px;
    font-size: 13px;
  }
  #search .field-grid,
  #search .travel-meta-grid {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  #fieldGrid > #routePair,
  #fieldGrid > #departField,
  #fieldGrid > #returnField {
    grid-column: auto;
  }
  #search .route-pair {
    grid-template-columns: 1fr;
    border-radius: 16px;
    min-height: auto;
  }
  #search .route-endpoint {
    padding: 10px 12px;
  }
  #search .route-endpoint input {
    font-size: 16px;
  }
  #search .route-divider {
    min-height: 0;
    height: 0;
    border-top: 1px solid rgba(148, 163, 184, 0.34);
  }
  #search .route-divider::before {
    display: none;
  }
  #swapButton {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
    width: 40px;
    height: 40px;
    font-size: 18px;
  }
  #search .search-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }
  #searchButton,
  #resetSearchButton {
    grid-column: auto;
  }
  #search .search-actions .primary,
  #search .search-actions .secondary {
    min-height: 46px;
    font-size: 17px;
  }
  #search .search-results-columns {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  #search .search-refine-column {
    position: static;
    top: auto;
  }
  #search .results-kpis-wide,
  #search .results-kpi-stack,
  #search .results-kpis {
    grid-template-columns: 1fr;
  }
  #search .results-filter-bar-inner {
    grid-template-columns:
      minmax(74px, 0.78fr) minmax(96px, 1.05fr) minmax(96px, 1.05fr)
      repeat(6, minmax(58px, 0.62fr)) auto auto;
  }
  #search .results-grid.view-grid {
    grid-template-columns: 1fr;
  }
  #search .result-card,
  #search .itinerary-card {
    border-radius: 16px;
  }
  .duffel-checkout-overlay,
  .duffel-payment-overlay {
    padding: 8px;
  }
}
@media (max-width: 640px) {
  .app-shell {
    padding: 10px;
  }
  .site-header {
    padding: 12px;
    border-radius: 20px;
    gap: 10px 8px;
  }
  .brand-mark {
    width: 36px;
    height: 36px;
    border-radius: 12px;
    font-size: 16px;
  }
  .brand-text span {
    font-size: 15px;
  }
  .cta-pill {
    min-height: 38px;
    font-size: 11px;
    padding: 7px 10px;
  }
  .top-nav {
    gap: 6px;
    padding: 6px;
    border-radius: 16px;
  }
  .nav-link {
    min-height: 40px;
    padding: 8px 12px;
    font-size: 12px;
    border-radius: 13px;
  }
  .home-search-actions {
    grid-template-columns: auto;
    justify-content: stretch;
  }
  .route-price-graph-card {
    padding: 12px;
  }
  .route-price-route-endpoint input,
  #search .route-endpoint input {
    font-size: 15px;
  }
  #search .search-hero {
    padding: 11px 10px 10px;
    border-radius: 20px;
  }
  #search .search-hero .search-hero-top .pill {
    font-size: 10px;
    padding: 6px 10px;
  }
  #search .search-hero .panel-header.compact h2 {
    font-size: clamp(1.5rem, 9vw, 2.1rem);
    letter-spacing: -0.02em;
  }
  #search .tab {
    font-size: 12px;
    min-height: 38px;
    padding: 7px 8px;
  }
  #search .field input,
  #search .field select,
  #search .traveler-field-trigger,
  #search .search-actions .primary,
  #search .search-actions .secondary {
    height: 44px;
    min-height: 44px;
    border-radius: 14px;
    font-size: 16px;
    padding: 10px 12px;
  }
  #search .segment-route-endpoint input {
    height: auto;
    min-height: 0;
    border: 0;
    outline: 0;
    box-shadow: none;
    padding: 0;
    border-radius: 0;
    background: transparent;
    transform: none;
  }
  #search .segment-route-endpoint input:hover,
  #search .segment-route-endpoint input:focus,
  #search .segment-route-endpoint input:focus-visible {
    border: 0;
    outline: 0;
    box-shadow: none;
    padding: 0;
    transform: none;
  }
  #search .search-actions .primary,
  #search .search-actions .secondary {
    font-size: 16px;
  }
  #search .route-pair,
  .route-price-route-pair {
    border-radius: 14px;
  }
  #swapButton,
  .route-price-route-swap {
    width: 38px;
    height: 38px;
    font-size: 16px;
  }
}
@media (max-width: 430px) {
  .app-shell {
    padding: 8px;
  }
  .site-header {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      'brand actions'
      'nav nav';
    padding: 10px;
    border-radius: 18px;
    gap: 8px 10px;
  }
  .brand {
    justify-content: flex-start;
    align-self: center;
  }
  .header-actions {
    width: auto;
    justify-self: end;
    justify-content: flex-end;
    align-self: center;
  }
  .top-nav {
    width: 100%;
    padding: 5px;
    border-radius: 14px;
  }
  .nav-link {
    min-height: 38px;
    padding: 7px 10px;
    font-size: 11.5px;
  }
  #search .search-hero .search-hero-top {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      'title status'
      'tabs tabs';
    align-items: center;
    gap: 7px 10px;
  }
  #search .search-hero .search-hero-top h2 {
    grid-area: title;
    white-space: nowrap;
    font-size: clamp(1.85rem, 8.2vw, 2.25rem);
  }
  #search .search-hero .search-hero-top .pill {
    grid-area: status;
    justify-self: end;
  }
  #search .search-hero-top .trip-toggle {
    grid-area: tabs;
  }
  #search .trip-toggle {
    gap: 2px;
    padding: 3px;
  }
  #search .tab {
    min-height: 36px;
    font-size: 11.5px;
    padding: 6px 6px;
  }
  #search .route-endpoint {
    padding: 9px 10px;
  }
  #search .route-endpoint-label,
  .route-price-route-label {
    font-size: 10px;
  }
  #search .field input,
  #search .field select,
  #search .traveler-field-trigger {
    font-size: 15px;
  }
  #search .search-actions .primary,
  #search .search-actions .secondary {
    min-height: 44px;
    font-size: 15px;
  }
  .route-price-route-endpoint {
    padding: 10px;
  }
  .route-price-route-endpoint input {
    font-size: 15px;
  }
  .route-price-graph-chart {
    min-height: 196px;
  }
}
@media (max-width: 390px) {
  .brand-mark {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    font-size: 15px;
  }
  .brand-text span {
    font-size: 14px;
  }
  .cta-pill {
    min-height: 36px;
    padding: 6px 8px;
    font-size: 10px;
  }
  #search .search-hero .panel-header.compact h2 {
    font-size: clamp(1.35rem, 9vw, 1.85rem);
  }
  #search .field input,
  #search .field select,
  #search .traveler-field-trigger,
  #search .search-actions .primary,
  #search .search-actions .secondary {
    min-height: 42px;
    height: 42px;
    font-size: 14px;
  }
  #swapButton,
  .route-price-route-swap {
    width: 36px;
    height: 36px;
    font-size: 15px;
  }
  .route-price-graph-chart {
    min-height: 184px;
  }
}
@media (max-width: 768px) {
  .hero-panel-main {
    padding: 18px;
  }
  .hero-panel-main .eyebrow {
    margin-bottom: 8px;
    font-size: 11px;
    letter-spacing: 0.11em;
  }
  .hero-panel h1 {
    font-size: clamp(1.65rem, 9vw, 2.4rem);
    line-height: 1.05;
  }
  .hero-panel-main .home-title-lockup {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 10px;
    white-space: nowrap;
  }
  .hero-panel-main .home-title-lockup span:first-child {
    white-space: nowrap;
  }
  .hero-panel-main .home-title-lockup span:not(.home-title-separator) {
    font-size: clamp(1.55rem, 6.5vw, 2.25rem);
    line-height: 1;
  }
  .hero-panel-main .home-title-separator {
    flex: 0 0 auto;
    font-size: clamp(1.15rem, 5.4vw, 1.65rem);
    transform: translateY(1px);
  }
  .home-tracking-card {
    margin-top: 8px;
  }
  .home-tracking-card .home-search-shell {
    padding: 12px;
  }
  .hero-copy {
    font-size: 15px;
    line-height: 1.45;
  }
  .home-track-mode-switch {
    width: 100%;
    gap: 5px;
    padding: 5px;
  }
  .home-track-mode-pill {
    min-height: 40px;
    padding: 7px 8px;
    font-size: 12px;
  }
  .home-track-mode-pill span {
    text-align: center;
    width: 100%;
  }
  .home-ops-panel {
    padding: 12px;
  }
  .home-ops-board {
    gap: 10px;
    margin-top: 12px;
  }
  .home-route-grid {
    grid-template-columns: 1fr;
  }
  .route-price-graph-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .route-price-graph-summary {
    width: 100%;
    flex-wrap: wrap;
    gap: 6px;
  }
  .route-price-graph-summary span {
    min-height: 30px;
  }
  .route-price-graph-chart {
    min-height: 210px;
    border-radius: 16px;
  }
  .result-card-header {
    flex-direction: column;
    align-items: stretch;
    gap: 7px;
  }
  .result-card-price {
    text-align: left;
    justify-items: start;
  }
  .result-card .row {
    gap: 8px;
  }
  .field input,
  .field select,
  .field textarea,
  .home-tracking-card .field input,
  #search .field input,
  #search .field select,
  #settings .field input,
  #settings .field select {
    font-size: 16px;
  }
  .duffel-checkout-card,
  .duffel-contact-card,
  .duffel-summary-card,
  .duffel-checkout-actions,
  .duffel-passenger-section,
  .duffel-payment-card {
    border-radius: 16px;
  }
}
@media (max-width: 520px) {
  .panel,
  .hero-panel,
  .hero-surface {
    padding: 10px;
    border-radius: 16px;
  }
  .route-price-graph-card {
    padding: 10px;
    border-radius: 16px;
  }
  .route-price-graph-summary span {
    font-size: 10px;
    padding: 5px 9px;
  }
  .route-price-graph-stat strong {
    font-size: 1.75rem;
  }
  .top-nav {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    width: 100%;
    overflow: visible;
    gap: 4px;
    padding: 4px;
  }
  .nav-link {
    min-width: 0;
    min-height: 42px;
    padding: 7px 4px;
    font-size: 11.5px;
    line-height: 1.08;
    white-space: normal;
    text-wrap: balance;
    text-align: center;
    border-radius: 12px;
  }
  .nav-link[data-target='tracking-insights'] {
    font-size: 11.5px;
    line-height: 1.05;
  }
  .home-search-actions {
    grid-template-columns: auto;
  }
  .home-track-topline {
    flex-direction: column;
    gap: 8px;
  }
  .home-track-status {
    width: 100%;
    justify-content: flex-start;
  }
  .home-track-card {
    padding: 12px;
  }
  .home-track-route {
    gap: 10px;
  }
  .home-track-fact {
    padding: 9px 10px;
  }
  .route-price-graph-chart {
    min-height: 180px;
  }
}
@media (max-width: 640px) {
  #search .field-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
  #fieldGrid > #routePair {
    grid-column: 1 / -1;
  }
  #fieldGrid.single-date > #departField {
    grid-column: 1 / -1;
  }
  #search .travel-meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
  #search .search-actions {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
  #searchButton,
  #resetSearchButton {
    width: 100%;
    min-height: 44px;
  }
  .segment-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
  .segment-row > .segment-route-pair,
  .segment-row > .date-field-wrap {
    grid-column: 1 / -1;
  }
  .segment-row > .segment-traveler-field,
  .segment-row > .segment-cabin-field {
    grid-column: auto;
  }
  #search .search-entry-form.multi-city-mode .search-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
    width: 100%;
  }
  #search .search-entry-form.multi-city-mode .search-actions .primary,
  #search .search-entry-form.multi-city-mode .search-actions .secondary {
    width: 100%;
    min-width: 0;
  }
}
@media (max-width: 560px) {
  #bookingOverlay.itinerary-overlay {
    padding: 6px !important;
    align-items: start;
    overflow-x: hidden !important;
  }
  #bookingOverlay.itinerary-overlay .booking-detail-sheet {
    width: calc(100vw - 12px) !important;
    max-width: calc(100vw - 12px) !important;
    max-height: calc(100dvh - 12px) !important;
    inset: 6px !important;
    padding: 6px !important;
    gap: 8px !important;
    overflow-x: hidden !important;
  }
  #bookingOverlay.itinerary-overlay .booking-detail-actions {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    padding: 10px 10px 10px 12px;
    border-radius: 18px;
    gap: 8px;
  }
  #bookings
    #bookingOverlay.itinerary-overlay
    .booking-detail-actions-row
    .booking-action-button {
    min-height: 36px;
    padding: 8px 10px;
    font-size: 10px;
  }
  #bookingOverlay.itinerary-overlay .booking-detail-surface,
  #bookingOverlay.itinerary-overlay .booking-detail-timeline,
  #bookingOverlay.itinerary-overlay .booking-detail-card,
  #bookingOverlay.itinerary-overlay .booking-doc {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box;
    overflow-x: hidden !important;
  }
  #bookingOverlay.itinerary-overlay .booking-detail-card {
    padding: 6px;
    border-radius: 18px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc {
    gap: 7px;
    padding: 10px 10px 10px 14px;
    border-radius: 18px;
    font-size: 12px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-hero {
    gap: 8px;
    padding-bottom: 8px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-journey-status {
    gap: 6px;
    padding: 6px 9px;
    font-size: 10px;
    line-height: 1.15;
    letter-spacing: 0.05em;
    max-width: 100%;
  }
  #bookings
    #bookingOverlay.itinerary-overlay
    .booking-doc-journey-status
    span:last-child {
    white-space: normal;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-journey-status-icon {
    width: 24px;
    height: 24px;
    min-width: 24px;
    font-size: 17px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-fare {
    min-width: 88px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-fare strong {
    font-size: 20px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-panel {
    padding: 10px;
    border-radius: 16px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-keyvalue {
    grid-template-columns: minmax(88px, 0.75fr) minmax(0, 1fr);
    gap: 8px;
    padding: 7px 0;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-keyvalue span {
    font-size: 8px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-keyvalue strong {
    font-size: 10.5px;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-trip {
    padding: 9px;
    border-radius: 15px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-trip-stations,
  #bookings
    #bookingOverlay.itinerary-overlay
    .booking-doc-trip-stations.has-layover {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-trip-airline-stack {
    grid-column: 1 / -1;
    align-items: flex-start;
    text-align: left;
    min-width: 0;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-station strong {
    font-size: 14px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-station small,
  #bookingOverlay.itinerary-overlay .booking-doc-trip-meta,
  #bookingOverlay.itinerary-overlay .booking-doc-trip-meta span {
    font-size: 8px;
  }
  #bookingOverlay.itinerary-overlay .booking-doc-trip-meta {
    gap: 5px 7px !important;
    white-space: normal !important;
    flex-wrap: wrap !important;
  }
  #bookings
    #bookingOverlay.itinerary-overlay
    .booking-manifest-contact-list--inline,
  #bookingOverlay.itinerary-overlay .booking-manifest-row-grid,
  #bookingOverlay.itinerary-overlay .booking-manifest-row-split {
    grid-template-columns: 1fr;
  }
  #bookings
    #bookingOverlay.itinerary-overlay
    .booking-manifest-row-col--extras {
    padding-left: 0;
    border-left: 0;
    padding-top: 8px;
    border-top: 1px dashed rgba(15, 23, 42, 0.1);
  }
}

/* Safari: match Edge smoothness — avoid backdrop-filter compositor flicker on search. */
html.is-safari #search .search-hero,
html.is-safari #search .results-filter-bar,
html.is-safari #search .results-kpis-wide,
html.is-safari #search .results-kpi-card,
html.is-safari .results-loading-panel,
html.is-safari #search .search-results-toolbar .panel,
html.is-safari #search .results-summary {
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
}
html.is-safari #search .search-results-workspace {
  transition: none;
}
html.is-safari
  #search
  .search-shell.is-search-form-animating
  .search-results-toolbar,
html.is-safari
  #search
  .search-shell.is-search-form-animating
  .search-prep-shell.search-prep-inline {
  -webkit-transition:
    max-height 0.34s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.28s ease,
    margin-bottom 0.34s cubic-bezier(0.22, 1, 0.36, 1),
    -webkit-transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
  transition:
    max-height 0.34s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.28s ease,
    margin-bottom 0.34s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
}
html.is-safari #search .results-grid {
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
html.is-safari .result-card {
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
html.is-safari .result-card:hover {
  -webkit-transform: translateY(-4px) translateZ(0);
  transform: translateY(-4px) translateZ(0);
}
html.is-safari .result-card-enter {
  animation-duration: 0.22s;
}
html.is-safari #search .results-filter-dual-range-track {
  height: 14px;
}
html.is-safari #search .results-filter-control select {
  line-height: 1.2;
}
