:root {
  --page-bg: #eff3f9;
  --surface: #ffffff;
  --text: #1d2433;
  --muted: #7d8799;
  --line: #e7ebf2;
  --primary: #004aca;
  --primary-dark: #0d4fe7;
  --shadow: 0 24px 50px rgba(18, 39, 80, 0.08);
  --fs-8: clamp(0.5rem, 0.48rem + 0.08vw, 0.625rem);
  --fs-10: clamp(0.625rem, 0.58rem + 0.2vw, 0.75rem);
  --fs-11: clamp(0.6875rem, 0.66rem + 0.12vw, 0.75rem);
  --fs-12: clamp(0.625rem, 0.58rem + 0.2vw, 0.75rem);
  --fs-13: clamp(0.75rem, 0.72rem + 0.14vw, 0.8125rem);
  --fs-14: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --fs-15: clamp(0.875rem, 0.84rem + 0.16vw, 0.9375rem);
  --fs-16: clamp(0.875rem, 0.82rem + 0.3vw, 1rem);
  --fs-17: clamp(1rem, 0.97rem + 0.14vw, 1.0625rem);
  --fs-18: clamp(0.875rem, 0.6875rem + 0.5vw, 1.125rem);
  --fs-22: clamp(1.25rem, 1.16rem + 0.4vw, 1.375rem);
  --fs-24: clamp(1.25rem, 1.1rem + 0.6vw, 1.5rem);
  --fs-28: clamp(1.5rem, 1.3rem + 0.8vw, 1.75rem);
  --fs-30: clamp(1.25rem, 0.7813rem + 1.25vw, 1.875rem);
  --fs-34: clamp(2rem, 1.9rem + 0.45vw, 2.125rem);
  --fs-38: clamp(1.75rem, 1.2813rem + 1.25vw, 2.375rem);
  --fs-48: clamp(1.5rem, 0.375rem + 3vw, 3rem);

  --gap-2: clamp(0.0625rem, 0.04rem + 0.1vw, 0.125rem);
  --gap-6: clamp(0.25rem, 0.2rem + 0.2vw, 0.375rem);
  --gap-7: clamp(0.375rem, 0.35rem + 0.12vw, 0.4375rem);
  --gap-8: clamp(0.375rem, 0.3rem + 0.25vw, 0.5rem);
  --gap-10: clamp(0.5rem, 0.45rem + 0.2vw, 0.625rem);
  --gap-11: clamp(0.625rem, 0.6rem + 0.12vw, 0.6875rem);
  --gap-12: clamp(0.625rem, 0.55rem + 0.25vw, 0.75rem);
  --gap-14: clamp(0.75rem, 0.7rem + 0.2vw, 0.875rem);
  --gap-16: clamp(0.875rem, 0.82rem + 0.22vw, 1rem);
  --gap-18: clamp(1rem, 0.95rem + 0.22vw, 1.125rem);
  --gap-20: clamp(1.125rem, 1.05rem + 0.3vw, 1.25rem);
  --gap-21: clamp(1.25rem, 1.22rem + 0.12vw, 1.3125rem);
  --gap-22: clamp(1.25rem, 1.18rem + 0.28vw, 1.375rem);
  --gap-24: clamp(1.25rem, 1.1rem + 0.6vw, 1.5rem);
  --gap-28: clamp(1.5rem, 1.35rem + 0.55vw, 1.75rem);
  --gap-32: clamp(1.75rem, 1.6rem + 0.6vw, 2rem);
  --gap-34: clamp(2rem, 1.92rem + 0.35vw, 2.125rem);
  --gap-36: clamp(2rem, 1.85rem + 0.6vw, 2.25rem);
  --gap-56: clamp(1.75rem, 1rem + 3vw, 3.5rem);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: "Inter", sans-serif;
  background: #ffffff;
  color: var(--text);
}

.font_family {
  font-family: "Poppins", sans-serif;
}

button,
a {
  font: inherit;
}

button {
  cursor: pointer;
  border: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

.page-shell {
  width: 100%;
  margin: 0 auto;
  background: var(--surface);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.03);
}

.container {
  width: min(100%, 1440px);
  margin: 0 auto;
  padding: 0 clamp(1.25rem, 0.3125rem + 2.5vw, 2.5rem);
}

.hero {
  position: relative;
  min-height: clamp(25.4375rem, 22.4583rem + 13.2407vw, 34.375rem);
  padding-bottom: clamp(1.435rem, 1.33rem + 0.4667vw, 1.75rem);
  color: #fff;
  background:
    linear-gradient(
      180deg,
      rgba(14, 18, 27, 0.82) 0%,
      rgba(14, 18, 27, 0.38) 34%,
      rgba(14, 18, 27, 0.22) 100%
    ),
    url("../images/hero_section.png");

  background-repeat: no-repeat;
  background-position: top center;

  /* THIS */
  background-size: 100% 700px;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(10, 12, 17, 0.45) 0%,
    rgba(10, 12, 17, 0) 36%,
    rgba(255, 255, 255, 0) 100%
  );
  pointer-events: none;
}

.topbar,
.hero-content {
  position: relative;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-20);
  padding: clamp(1.435rem, 1.33rem + 0.4667vw, 1.75rem)
    clamp(1.25rem, 0.3125rem + 2.5vw, 2.5rem);
  font-family: "Poppins", sans-serif;
}

.nav-toggle-btn {
  display: none;
}

.brand {
  font-size: var(--fs-30);
  font-weight: 700;
}

.main-nav,
.top-actions {
  display: flex;
  align-items: center;
  gap: var(--gap-18);
}

.top-actions {
  position: relative;
}

.main-nav a {
  font-size: var(--fs-18);
  font-weight: 600;
  color: #ffffff99;
}

.top-actions a,
.top-actions button {
  font-size: var(--fs-18);
  font-weight: 400;
  color: #ffffff;
}
.main-nav a.active {
  font-weight: 700;
  color: #ffffff;
}

.wallet,
.currency {
  display: inline-flex;
  align-items: center;
  gap: var(--gap-7);
  padding: 0;
  background: transparent;
}

.avatar,
.flag {
  width: clamp(0.805rem, 0.7817rem + 0.1037vw, 0.875rem);
  height: clamp(0.805rem, 0.7817rem + 0.1037vw, 0.875rem);
  border-radius: 50%;
  display: inline-block;
}

.avatar {
  background: radial-gradient(circle at 35% 35%, #c7ecff, #2f6bf2);
  border: 1px solid rgba(255, 255, 255, 0.65);
}

.menu-btn {
  display: inline-flex;
  flex-direction: column;
  gap: var(--gap-2);
  padding: 0;
  background: transparent;
}

.menu-btn span {
  width: clamp(0.1781rem, 0.175rem + 0.0139vw, 0.1875rem);
  height: clamp(0.1781rem, 0.175rem + 0.0139vw, 0.1875rem);
  border-radius: 50%;
  background: #fff;
}

.header-menu-popover {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  z-index: 35;
  min-width: 172px;
  padding: 10px;
  border: 1px solid rgba(219, 228, 241, 0.9);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 20px 40px rgba(18, 39, 80, 0.16);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition:
    opacity 0.2s ease,
    visibility 0.2s ease,
    transform 0.2s ease;
}

.header-menu-popover.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.header-menu-popover a,
.header-menu-popover button {
  display: block;
  width: 100%;
  padding: 12px 14px;
  border: 0;
  border-radius: 12px;
  color: #1f2937;
  font-size: 14px;
  font-weight: 600;
  font-family: inherit;
  text-align: left;
  background: transparent;
  cursor: pointer;
}

.header-menu-popover a:hover,
.header-menu-popover button:hover {
  background: #f3f6fb;
}

.hero-content {
  padding-top: clamp(0.345rem, 0.335rem + 0.0444vw, 0.375rem);
  margin-top: clamp(4.5rem, 3.9167rem + 2.5926vw, 6.25rem);
}

.hero-content h1 {
  margin: 0 0 clamp(0.77rem, 0.735rem + 0.1556vw, 0.875rem);
  text-align: center;
  font-size: var(--fs-48);
  font-weight: 700;
  font-family: "Poppins", sans-serif;
}

.search-panel {
  position: relative;
  max-width: 100%;
  background: rgba(255, 255, 255, 0.985);
  border: 1px solid rgba(223, 229, 238, 0.78);
  border-radius: 16px;
  box-shadow: 0 20px 44px rgba(13, 21, 43, 0.14);
  color: var(--text);
  overflow: visible;
  margin: 0px 20px;
}

.mobile-service-panel,
.mobile-search-head,
.mobile-trip-tabs {
  display: none;
}

.hotel-index-search-panel {
  display: none;
}

.responsive-group-booking-btn {
  display: none;
}

.mobile-service-panel {
  margin: 0 20px 12px;
  padding: 24px;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 20px 44px rgba(13, 21, 43, 0.14);
}

.mobile-service-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.mobile-service-tile {
  min-height: 96px;
  display: grid;
  place-items: center;
  gap: 6px;
  padding: 16px 10px;
  border-radius: 16px;
  background: #0e3fad1a;
  color: #00000099;
}

.mobile-service-tile svg {
  width: 28px;
  height: 28px;
  color: #00000099;
}

.mobile-service-tile span {
  font-size: 15px;
  font-weight: 500;
}

.mobile-service-tile.is-active {
  background: #e8f0ff;
}

.mobile-search-head {
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.mobile-search-head h2 {
  margin: 0;
  font-family: "Poppins", sans-serif;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 700;
  color: #111827;
}

.mobile-search-back,
.mobile-search-dismiss {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.7);
  color: #4b5563;
}

.mobile-search-back svg,
.mobile-search-dismiss svg {
  width: 18px;
  height: 18px;
}

.mobile-trip-tabs {
  gap: 10px;
}

.mobile-trip-tab {
  min-height: 32px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.5);
  color: #7d8799;
  font-size: 12px;
  font-weight: 700;
}

.mobile-trip-tab.is-active {
  background: #1550cf;
  color: #ffffff;
}

.trip-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: clamp(0.375rem, 0.341rem + 0.1481vw, 0.5rem)
    clamp(1.435rem, 1.33rem + 0.4667vw, 1.75rem)
    clamp(0.25rem, 0.216rem + 0.1481vw, 0.375rem)
    clamp(1.64rem, 1.52rem + 0.5333vw, 2rem);
  min-height: clamp(2.25rem, 2.182rem + 0.2963vw, 2.5rem);
  border-bottom: 1px solid #edf1f6;
  background-color: #f2f4f6;
  border-radius: 16px 16px 0 0;
}

.trip-type,
.currency-pill {
  background: transparent;
  color: #121927;
  font-size: var(--fs-13);
  padding: 0;
}

.trip-type {
  display: inline-flex;
  align-items: center;
  gap: var(--gap-7);
  font-weight: 500;
  position: relative;
}

.trip-type svg {
  width: clamp(0.7475rem, 0.7258rem + 0.0963vw, 0.8125rem);
  height: clamp(0.7475rem, 0.7258rem + 0.0963vw, 0.8125rem);
  color: #111827;
}

.trip-type[aria-expanded="true"] .field-arrow,
.trip-type[aria-expanded="true"] svg:last-child {
  transform: rotate(180deg);
}

.currency-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--gap-6);
  font-weight: 700;
  color: #ff5100;
}

.currency-pill svg {
  width: clamp(0.69rem, 0.67rem + 0.0889vw, 0.75rem);
  height: clamp(0.69rem, 0.67rem + 0.0889vw, 0.75rem);
  color: #94a3b8;
}

.trip-type-menu {
  position: absolute;
  top: 62px;
  left: 26px;
  z-index: 33;
  width: 220px;
  padding: 10px;
  border: 1px solid #e3e9f2;
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 22px 44px rgba(18, 39, 80, 0.12);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition:
    opacity 0.2s ease,
    visibility 0.2s ease,
    transform 0.2s ease;
}

.trip-type-menu.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.trip-type-option {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 12px;
  background: transparent;
  color: #1f2937;
  font-size: 14px;
  font-weight: 600;
  text-align: left;
}

.trip-type-option svg {
  width: 16px;
  height: 16px;
  color: #5b6472;
}

.trip-type-option:hover,
.trip-type-option.is-selected {
  background: #f3f6fb;
}

.trip-type-option-accent {
  color: #1550cf;
}

.trip-type-option-accent svg {
  color: #1550cf;
}

.search-grid {
  position: relative;
  display: grid;
  grid-template-columns:
    minmax(0, 1.15fr) minmax(0, 1.15fr) minmax(0, 1fr)
    minmax(0, 1fr) minmax(0, 1.09fr) 150px;
  gap: 0;
  padding: clamp(0.75rem, 0.682rem + 0.2963vw, 1rem)
    clamp(1.125rem, 0.1037rem + 1.5957vw, 1.5rem);
}

.standard-route-swap {
  width: 38px;
  height: 38px;
  position: absolute;
  grid-column: 1 / 3;
  align-self: center;
  justify-self: center;
  border: 1px solid #dce5f1;
  border-radius: 999px;
  background: #ffffff;
  color: var(--primary);
  display: inline-grid;
  place-items: center;
  box-shadow: 0 8px 18px rgba(15, 80, 207, 0.12);
  z-index: 2;
}

.standard-route-swap svg {
  width: 18px;
  height: 18px;
  stroke-width: 2.4;
}

.standard-route-swap:hover {
  background: #eef5ff;
  border-color: #b9cff5;
}

.search-card {
  min-height: clamp(4.1rem, 3.964rem + 0.5926vw, 4.6rem);
  padding: clamp(0.25rem, 0.216rem + 0.1481vw, 0.375rem)
    clamp(0.625rem, -1.0771rem + 2.6596vw, 1.25rem);
  border-right: 1px solid #edf1f6;
  min-width: 0;
}

.search-card.muted strong {
  color: #ced8e6;
}

.search-card.feature-card {
  border-right: 0;
}

.search-card.passenger-card {
  border-right: 0;
}

.date-card {
  position: relative;
}

.airport-card {
  position: relative;
}

.airport-trigger {
  width: 100%;
  text-align: left;
}

.airport-trigger .field-arrow {
  transition:
    transform 0.2s ease,
    color 0.2s ease;
}

.airport-trigger[aria-expanded="true"] .field-arrow {
  color: var(--primary);
  transform: rotate(180deg);
}

.date-trigger {
  width: 100%;
  text-align: left;
}

.date-trigger .field-arrow {
  transition:
    transform 0.2s ease,
    color 0.2s ease;
}

.date-trigger[aria-expanded="true"] .field-arrow {
  color: var(--primary);
  transform: rotate(180deg);
}

.feature-trigger,
.passenger-trigger {
  width: 100%;
  text-align: left;
}

.feature-trigger .field-arrow,
.passenger-trigger .field-arrow {
  transition:
    transform 0.2s ease,
    color 0.2s ease;
}

.feature-trigger[aria-expanded="true"] .field-arrow,
.passenger-trigger[aria-expanded="true"] .field-arrow {
  color: var(--primary);
  transform: rotate(180deg);
}

.field-label {
  display: block;
  margin-bottom: clamp(0.375rem, 0.341rem + 0.1481vw, 0.5rem);
  font-size: var(--fs-12);
  font-weight: 700;
  text-transform: uppercase;
  color: #4d5768;
  letter-spacing: 0.12em;
}

.field-shell {
  min-height: clamp(2.55rem, 2.482rem + 0.2963vw, 2.8rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-10);
  padding: 0 clamp(0.77rem, 0.735rem + 0.1556vw, 0.875rem) 0
    clamp(0.66rem, 0.63rem + 0.1333vw, 0.75rem);
  background: #f1f3f6;
  border-radius: 11px;
}

.field-main {
  display: flex;
  gap: var(--gap-6);
  align-items: center;
  min-width: 0;
  width: 100%;
}

.field-icon {
  min-width: clamp(1.54rem, 1.47rem + 0.3111vw, 1.75rem);
  height: clamp(1.54rem, 1.47rem + 0.3111vw, 1.75rem);
  display: inline-grid;
  place-items: center;
  padding: 0;
  border-radius: 0;
  background: transparent;
  text-align: center;
  color: var(--primary);
  flex-shrink: 0;
  line-height: 1;
}

.field-icon svg {
  width: clamp(1.2938rem, 1.2458rem + 0.213vw, 1.4375rem);
  height: clamp(1.2938rem, 1.2458rem + 0.213vw, 1.4375rem);
  stroke-width: 2;
}

.muted-icon svg {
  color: #c7d3e2;
}

.feature-icon svg {
  width: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  height: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  color: #1d2433;
}

.field-main strong {
  display: block;
  font-size: var(--fs-15);
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.field-search-input {
  display: block;
  width: 100%;
  min-width: 0;
  padding: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  font-size: var(--fs-15);
  line-height: 1.15;
  font-weight: 700;
}

.field-search-input::-webkit-search-cancel-button {
  display: none;
}

.field-main div {
  min-width: 0;
}

.field-main small {
  display: block;
  width: 100%;

  margin-top: clamp(0.1725rem, 0.1675rem + 0.0222vw, 0.1875rem);
  font-size: var(--fs-11);
  color: #596579;

  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.field-arrow {
  width: clamp(0.805rem, 0.7817rem + 0.1037vw, 0.875rem);
  height: clamp(0.805rem, 0.7817rem + 0.1037vw, 0.875rem);
  color: #95a2b4;
  flex-shrink: 0;
}

.promo-chip {
  display: inline-flex !important;
  align-items: center;
  min-height: clamp(1.35rem, 1.3rem + 0.2222vw, 1.5rem);
  margin-top: clamp(0.345rem, 0.335rem + 0.0444vw, 0.375rem);
  padding: 0 clamp(0.55rem, 0.525rem + 0.1111vw, 0.625rem);
  border-radius: 999px;
  background: #ffe5d4;
  color: #b85b1a;
  font-size: var(--fs-11);
  font-weight: 600;
}

.search-btn {
  align-self: center;
  justify-self: end;
  width: 100%;
  max-width: clamp(9.3425rem, 8.2483rem + 4.863vw, 12.625rem);
  height: clamp(2.65rem, 2.548rem + 0.4444vw, 3.025rem);
  margin-left: clamp(0.9225rem, 0.855rem + 0.3vw, 1.125rem);
  border-radius: 999px;
  background: linear-gradient(180deg, #1c5de2, #1550cf);
  color: #fff;
  font-size: var(--fs-16);
  font-weight: 500;
  box-shadow: none;
}

.flight-search-foot {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: clamp(1.25rem, 0.8667rem + 1.7037vw, 2.4rem);
  padding: clamp(0.375rem, 0.307rem + 0.2963vw, 0.625rem)
    clamp(1.125rem, 0.1037rem + 1.5957vw, 1.5rem)
    clamp(0.375rem, 0.307rem + 0.2963vw, 0.625rem);
  margin-top: clamp(-0.85rem, -0.748rem - 0.4444vw, -0.475rem);
  background-color: #f4f8fd;
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
}

.flight-advanced-link,
.nonstop-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #111827;
  font-size: var(--fs-12);
  font-weight: 500;
  background: transparent;
}

.flight-advanced-link svg {
  width: 14px;
  height: 14px;
}

.flight-advanced-link[aria-expanded="true"] svg:last-child {
  transform: rotate(180deg);
}

.nonstop-toggle {
  cursor: pointer;
}

.nonstop-toggle input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.nonstop-box {
  width: 18px;
  height: 18px;
  display: inline-grid;
  place-items: center;
  border: 1px solid #cfd8e5;
  border-radius: 4px;
  background: #ffffff;
}
.nonstop-box svg {
  width: 14px;
  height: 14px;
  color: #ffffff;
}

.nonstop-toggle input:checked + .nonstop-box {
  border-color: var(--primary);
  background: var(--primary);
}

.search-panel.trip-one-way [data-return-search-card] {
  display: block;
}

.search-panel.trip-one-way [data-return-search-card].is-one-way-disabled {
  opacity: 0.56;
}

.search-panel.trip-one-way
  [data-return-search-card].is-one-way-disabled
  .field-shell {
  cursor: pointer;
}

.search-panel.trip-one-way
  [data-return-search-card].is-one-way-disabled
  .field-icon,
.search-panel.trip-one-way
  [data-return-search-card].is-one-way-disabled
  .field-arrow {
  color: #a5afbf;
}

.search-panel.trip-multi-city [data-standard-search] {
  display: none;
}

.search-panel.trip-multi-city .flight-search-foot {
  display: none;
}

.multi-city-panel {
  display: none;
  padding: 12px 18px 0;
  color: #161d29;
}

.search-panel.trip-multi-city .multi-city-panel {
  display: block;
}

.multi-city-toolbar-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0;
  background: transparent;
  color: #202737;
  font-size: 13px;
  font-weight: 500;
}

.multi-city-toolbar-btn svg {
  width: 14px;
  height: 14px;
}

.multi-city-sheet {
  padding: 18px 16px 0;
}

.multi-city-sheet h2 {
  margin: 0 0 4px;
  font-family: "Poppins", sans-serif;
  font-size: 20px;
  line-height: 1.3;
  font-weight: 700;
  color: #1d2433;
}

.multi-city-rows {
  display: grid;
}

.multi-city-row {
  display: grid;
  grid-template-columns:
    minmax(0, 1fr) 0px minmax(0, 1fr) minmax(0, 1.04fr)
    minmax(0, 1.05fr) 30px;
  align-items: stretch;
  position: relative;
}

.multi-city-row + .multi-city-row {
  margin-top: 4px;
}

.multi-city-badge {
  position: absolute;
  top: 10px;
  left: 12px;
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  background: #edf4ff;
  color: #1550cf;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.multi-city-cell {
  min-width: 0;
  padding: 42px 14px 18px;
  border-right: 1px solid #edf1f6;
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: left;
}

button.multi-city-cell {
  cursor: pointer;
}

button.multi-city-cell:hover,
button.multi-city-cell[aria-expanded="true"] {
  background: #f8fbff;
}

.passenger-cell {
  text-align: left;
}

.passenger-cell[aria-expanded="true"] .multi-city-date svg {
  color: var(--primary);
}

.multi-city-swap {
  align-self: center;
  justify-self: center;
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border: 1px solid #c5d0e4;
  border-radius: 50%;
  color: #1550cf;
  background: #ffffff;
  z-index: 1;
}

.multi-city-swap svg {
  width: 14px;
  height: 14px;
}

.multi-city-flight,
.multi-city-date {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  min-height: clamp(2.55rem, 2.482rem + 0.2963vw, 2.8rem);
  padding: 0 clamp(0.77rem, 0.735rem + 0.1556vw, 0.875rem) 0
    clamp(0.66rem, 0.63rem + 0.1333vw, 0.75rem);
  border-radius: 11px;
  background: #f1f3f6;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.multi-city-flight > div,
.multi-city-date > div {
  min-width: 0;
  width: 100%;
}

.multi-city-flight svg,
.multi-city-date svg {
  width: 22px;
  height: 22px;
  color: #1550cf;
  flex-shrink: 0;
}

.multi-city-flight strong,
.multi-city-date strong {
  display: block;
  font-size: var(--fs-15);
  line-height: 1.15;
  font-weight: 700;
  color: #212733;
  text-overflow: ellipsis;
}

.multi-city-flight .field-search-input {
  font-size: var(--fs-15);
}

.multi-city-flight small,
.multi-city-date small {
  display: block;
  margin-top: 2px;
  font-size: var(--fs-11);
  line-height: 1.25;
  color: #596579;
  text-overflow: ellipsis;
}

.multi-city-cell.muted strong {
  color: #cfd8e8;
}

.multi-city-cell.muted svg {
  color: #c7d3e2;
}

.multi-city-cell .promo-chip {
  width: fit-content;
}

.multi-city-delete {
  align-self: center;
  justify-self: center;
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  background: transparent;
  color: #ef2f2f;
}

.multi-city-delete[hidden] {
  display: none;
}

.multi-city-delete svg {
  width: 18px;
  height: 18px;
}

.multi-city-add {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 14px 0 20px 0;
  padding: 0;
  background: transparent;
  color: #1550cf;
  font-size: 15px;
  font-weight: 700;
}

.multi-city-add svg {
  width: 18px;
  height: 18px;
}

.multi-city-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 14px 0 20px;
}

.multi-city-footer {
  display: flex;
  justify-content: center;
  padding: 0 0 20px;
}

.multi-city-search-btn {
  min-width: 140px;
  height: 36px;
  padding: 0 24px;
  border-radius: 999px;
  background: linear-gradient(180deg, #1c5de2, #1550cf);
  color: #ffffff;
  font-size: 15px;
  font-weight: 500;
}

.group-booking-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.24s ease,
    visibility 0.24s ease;
}

.group-booking-modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.group-booking-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(13, 20, 34, 0.42);
  backdrop-filter: blur(3px);
}

.group-booking-dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 850px);
  max-height: calc(100vh - 40px);
  overflow: auto;
  border-radius: 30px;
  background: #ffffff;
  box-shadow: 0 32px 80px rgba(14, 24, 40, 0.28);
}

.group-booking-close {
  position: absolute;
  top: 3px;
  right: 10px;
  z-index: 2;
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: transparent;
  color: #202635;
}

.group-booking-close svg {
  width: 22px;
  height: 22px;
  stroke-width: 2.2;
}

.group-booking-sheet {
  padding: 30px;
}

.group-booking-panel {
  border: 1px solid #edf1f6;
  border-radius: 15px;
  background: #ffffff;
  padding: 24px 26px 27px;
}

.group-section-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 22px;
}

.group-section-head h2 {
  margin: 0;
  font-size: 15px;
  line-height: 1.2;
  font-weight: 700;
  color: #212733;
}

.group-section-head-light h2 {
  color: #ffffff;
}

.group-section-icon {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  flex-shrink: 0;
}

.group-section-icon svg {
  width: 17px;
  height: 17px;
  stroke-width: 2.2;
}

.soft-blue {
  background: #e9f1ff;
  color: #1550cf;
}

.soft-peach {
  background: #fff0e6;
  color: #b45c1d;
}

.soft-slate {
  background: #eef2ff;
  color: #7a87a9;
}

.glass-blue {
  background: rgba(255, 255, 255, 0.14);
  color: #ffffff;
}

.group-contact-grid,
.group-trip-grid,
.group-preferences-grid {
  display: grid;
  gap: 18px;
}

.group-contact-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.group-booking-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) 300px;
  gap: 18px;
  margin-top: 22px;
}

.group-trip-card {
  min-height: 380px;
}

.group-passengers-card {
  border-radius: 12px;
  background: linear-gradient(180deg, #1a58c9 0%, #0f4fcb 100%);
  padding: 22px 24px 24px;
  box-shadow: 0 16px 34px rgba(18, 73, 184, 0.28);
}

.group-field {
  display: block;
}

.group-field > span,
.group-field-title {
  display: block;
  margin-bottom: 9px;
  font-size: 11px;
  line-height: 1.2;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #545d6f;
}

.group-field input,
.group-field select,
.group-field textarea {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: #202737;
  font-family: inherit;
  font-size: 12px;
}

.group-field input::placeholder,
.group-field textarea::placeholder {
  color: #8a93a6;
}

.group-field > input {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 10px;
  background: #f1f4f8;
}

.group-input-shell {
  min-height: 34px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 12px;
  border-radius: 10px;
  background: #f1f4f8;
}

.group-input-shell svg {
  width: 16px;
  height: 16px;
  color: #7f889c;
  flex-shrink: 0;
}

.group-segment-switch {
  display: inline-grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  width: 329px;
  margin-bottom: 20px;
  padding: 3px;
  border-radius: 11px;
  background: #eff3f8;
}

.segment-pill {
  min-height: 32px;
  border-radius: 8px;
  background: transparent;
  color: #373f4e;
  font-size: 12px;
  font-weight: 500;
}

.segment-pill.is-active {
  background: #ffffff;
  color: #1550cf;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
  font-weight: 700;
}

.group-trip-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  row-gap: 22px;
}

.group-trip-grid.is-multi-city {
  grid-template-columns: 1fr;
  gap: 14px;
}

.group-multi-city-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  padding: 14px;
  border: 1px solid #edf1f6;
  border-radius: 12px;
  background: #fbfcff;
}

.group-multi-city-head {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 28px;
}

.group-multi-city-head span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  background: #edf4ff;
  color: #1550cf;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.group-multi-delete {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #fff1f1;
  color: #ef2f2f;
}

.group-multi-delete[hidden] {
  display: none;
}

.group-multi-delete svg {
  width: 15px;
  height: 15px;
}

.group-multi-add {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 10px;
  background: #edf4ff;
  color: #1550cf;
  font-size: 12px;
  font-weight: 800;
}

.group-multi-add svg {
  width: 15px;
  height: 15px;
}

.passenger-stack {
  display: grid;
  gap: 18px;
}

.passenger-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 16px 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.1);
}

.passenger-copy strong,
.passenger-copy span {
  display: block;
  color: #ffffff;
}

.passenger-copy strong {
  font-size: 12px;
  font-weight: 700;
}

.passenger-copy span {
  margin-top: 3px;
  font-size: 9px;
  color: rgba(255, 255, 255, 0.72);
}

.passenger-stepper {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #ffffff;
}

.passenger-stepper button {
  width: 27px;
  height: 27px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.26);
  background: transparent;
  color: #ffffff;
  font-size: 16px;
  line-height: 1;
}

.passenger-stepper strong {
  min-width: 24px;
  text-align: center;
  font-size: 15px;
}

.upload-passenger-wrap {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.16);
}

.upload-passenger-btn {
  width: 100%;
  min-height: 39px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 12px;
  background: #ffffff;
  color: #1550cf;
  font-size: 12px;
  font-weight: 700;
}

.upload-passenger-btn svg {
  width: 15px;
  height: 15px;
}

.upload-passenger-wrap p {
  margin: 11px 0 0;
  font-size: 9px;
  line-height: 1.4;
  text-align: center;
  color: rgba(255, 255, 255, 0.7);
}

.group-preferences-card {
  margin-top: 24px;
  border: 2px dashed #c3c6d7;
  border-radius: 14px;
  background-color: #f2f4f680;
}

.group-preferences-grid {
  grid-template-columns: 1.08fr 1.06fr 1.12fr;
  align-items: start;
}

.preferences-block {
  min-width: 0;
}

.choice-chip,
.check-option {
  display: flex;
  align-items: center;
  gap: 10px;
}

.choice-chip {
  min-height: 35px;
  padding: 0 12px;
  border: 1px solid #eef1f5;
  border-radius: 10px;
  background: #ffffff;
}

.choice-chip + .choice-chip {
  margin-top: 8px;
}

.choice-chip input,
.check-option input {
  appearance: none;
  margin: 0;
}

.choice-chip input {
  width: 14px;
  height: 14px;
  border: 1.5px solid #96a0b5;
  border-radius: 50%;
}

.choice-chip.is-selected input,
.choice-chip input:checked {
  border-color: #1550cf;
  box-shadow: inset 0 0 0 3.5px #1550cf;
}

.choice-chip span,
.check-option span {
  font-size: 12px;
  line-height: 1.2;
  color: #272d39;
}

.group-select-field .group-input-shell {
  padding-right: 10px;
}

.group-field select {
  padding-right: 18px;
  background-repeat: no-repeat;
}

.preference-note {
  margin-top: 12px;
  padding: 14px 13px;
  border-radius: 10px;
  background: #f3f5f8;
  color: #6d7485;
  font-size: 11px;
  line-height: 1.6;
}

.checkbox-row {
  display: flex;
  gap: 26px;
  margin-bottom: 15px;
}

.check-option {
  gap: 8px;
}

.check-option input {
  width: 13px;
  height: 13px;
  border: 1.4px solid #98a2b3;
  border-radius: 3px;
  background: #ffffff;
}

.check-option input:checked {
  background: #1550cf;
  border-color: #1550cf;
  box-shadow: inset 0 0 0 2px #ffffff;
}

.group-textarea-field textarea {
  min-height: 62px;
  padding: 12px 14px;
  border-radius: 10px;
  background: #f3f5f8;
  resize: none;
  line-height: 1.45;
}

.group-booking-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 34px;
  padding-top: 26px;
  border-top: 1px solid #edf1f6;
}

.group-booking-footer p {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 11px;
  line-height: 1.4;
  color: #667084;
}

.group-booking-footer p svg {
  width: 13px;
  height: 13px;
  color: #1f2937;
  flex-shrink: 0;
}

.group-booking-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.footer-btn {
  min-width: 128px;
  height: 48px;
  padding: 0 26px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
}

.footer-btn-secondary {
  border: 1px solid #99a3b7;
  background: #ffffff;
  color: #495163;
}

.footer-btn-primary {
  background: #1550cf;
  color: #ffffff;
}

body.group-booking-open {
  overflow: hidden;
}

body.mobile-search-open {
  overflow: hidden;
}

.airport-popover {
  position: absolute;
  top: calc(100% + 14px);
  left: 0;
  z-index: 31;
  width: 470px;
  max-width: min(470px, calc(100vw - 48px));
  border: 1px solid #d8dde7;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 24px 50px rgba(15, 23, 42, 0.18);
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition:
    opacity 0.22s ease,
    transform 0.22s ease,
    visibility 0.22s ease;
}

.airport-popover.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.airport-current-location {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 16px 18px;
  border-bottom: 1px solid #eef2f7;
}

.airport-current-icon {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: #eef4ff;
  color: #1558d6;
  flex-shrink: 0;
}

.airport-current-icon svg {
  width: 20px;
  height: 20px;
  stroke-width: 2.2;
}

.airport-current-copy strong {
  display: block;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.2;
  color: #1f2937;
}

.airport-current-copy span {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  line-height: 1.35;
  color: #6b7280;
}

.airport-results-block {
  padding: 16px 8px 14px;
  background: #edf3fc;
}

.airport-panel-section {
  padding: 18px 16px 14px;
}

.airport-section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 14px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #4b5563;
}

.airport-results-block .airport-section-title {
  padding-inline: 8px;
  color: #1558d6;
}

.airport-section-title svg {
  width: 14px;
  height: 14px;
  stroke-width: 2.1;
}

.airport-result-card,
.airport-result-row,
.airport-destination-card,
.airport-simple-item,
.airport-nearby-item {
  width: 100%;
  text-align: left;
  background: transparent;
}

.airport-result-card.featured {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin: 0 0 14px;
  padding: 12px 12px 12px 14px;
  border: 1px solid #b9cff8;
  border-radius: 16px;
  background: #ffffff;
}

.airport-result-row {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 0 18px 18px 22px;
}

.airport-result-icon {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  color: #64748b;
  flex-shrink: 0;
}

.airport-result-icon.active {
  border-radius: 50%;
  background: #edf4ff;
  color: #1558d6;
}

.airport-result-icon svg {
  width: 22px;
  height: 22px;
  stroke-width: 1.9;
}

.airport-result-copy {
  min-width: 0;
  flex: 1;
}

.airport-result-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.airport-result-copy strong {
  display: block;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.2;
  color: #111827;
}

.airport-result-copy p {
  margin: 4px 0 6px;
  font-size: 12px;
  line-height: 1.35;
  color: #4b5563;
}

.airport-result-copy small {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  line-height: 1.2;
  color: #94a3b8;
}

.airport-result-copy small svg {
  width: 12px;
  height: 12px;
  stroke-width: 2;
}

.airport-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 10px;
  border-radius: 6px;
  background: #edf4ff;
  color: #1558d6;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}

.airport-destination-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.airport-destination-card {
  min-height: 48px;
  padding: 10px 12px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #ffffff;
}

.airport-destination-card strong,
.airport-nearby-copy strong {
  display: block;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.2;
  color: #1f2937;
}

.airport-destination-card span,
.airport-nearby-copy small {
  display: block;
  margin-top: 2px;
  font-size: 12px;
  line-height: 1.3;
  color: #6b7280;
}

.airport-simple-list {
  display: grid;
  gap: 14px;
}

.airport-simple-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 16px;
  font-weight: 500;
  color: #1f2937;
}

.airport-simple-icon {
  width: 22px;
  height: 22px;
  display: grid;
  place-items: center;
  border: 2px solid #94a3b8;
  border-radius: 50%;
  color: #94a3b8;
  flex-shrink: 0;
}

.airport-simple-icon svg {
  width: 12px;
  height: 12px;
  stroke-width: 2.2;
}

.airport-nearby-list {
  display: grid;
  gap: 18px;
  padding-bottom: 18px;
}

.airport-nearby-item {
  display: flex;
  align-items: center;
  gap: 12px;
}

.airport-nearby-icon {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  color: #94a3b8;
  flex-shrink: 0;
}

.airport-nearby-icon svg {
  width: 22px;
  height: 22px;
  stroke-width: 1.9;
}

.airport-nearby-copy {
  min-width: 0;
  flex: 1;
}

.airport-nearby-distance {
  font-size: 12px;
  font-weight: 700;
  color: #1558d6;
}

.airport-popover-tip {
  padding: 12px 16px 14px;
  background: #070707;
  color: #ffffff;
  font-size: 12px;
  line-height: 1.35;
  text-align: center;
}

.calendar-popover {
  position: absolute;
  top: calc(100% + 14px);
  left: 0;
  z-index: 29;
  width: 940px;
  max-width: min(940px, calc(100vw - 48px));
  padding: 20px;
  border: 1px solid #e7ebf2;
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition:
    opacity 0.22s ease,
    transform 0.22s ease,
    visibility 0.22s ease;
}

.calendar-popover.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.calendar-popover-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.calendar-month-card {
  min-width: 0;
}

.calendar-month-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.calendar-month-head h3 {
  margin: 0;
  color: #111827;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.25;
}

.calendar-nav {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.calendar-nav button {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  padding: 0;
  border-radius: 50%;
  background: #eef5ff;
  color: #1550cf;
}

.calendar-nav svg {
  width: 15px;
  height: 15px;
  stroke-width: 2.2;
}

.calendar-weekdays,
.calendar-days {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.calendar-weekdays {
  gap: 7px;
  margin-bottom: 8px;
}

.calendar-weekdays span {
  color: #8792a4;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
  text-transform: uppercase;
}

.calendar-days {
  gap: 7px;
}

.calendar-day {
  min-height: 45px;
  display: grid;
  place-items: center;
  gap: 2px;
  padding: 5px 3px;
  border-radius: 9px;
  background: #f6f8fb;
  color: #111827;
}

.calendar-day span {
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.calendar-day small {
  font-size: 9px;
  font-weight: 800;
  line-height: 1;
  color: #004ac6;
}

.calendar-day .fare-red {
  color: #e11d48;
}

.calendar-day .fare-blue {
  color: #004ac6;
}

.calendar-day.muted span {
  color: #cbd5e1;
}

.calendar-day.muted small {
  display: none;
}

.calendar-day.muted {
  background: transparent;
}

.calendar-day:hover,
.calendar-day.selected {
  background: #1558d6;
  color: #ffffff;
}

.calendar-day:hover small,
.calendar-day.selected small {
  color: #ffffff;
}

.advanced-filters-popover {
  position: absolute;
  top: calc(100% + 14px);
  right: 0;
  z-index: 30;
  width: 950px;
  max-width: min(950px, calc(100vw - 48px));
  padding: 20px 20px 22px 24px;
  border-radius: 16px;
  border: 1px solid #e2e8f0;
  background: #f2f4f6;
  box-shadow: 0 20px 48px rgba(15, 23, 42, 0.14);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition:
    opacity 0.22s ease,
    transform 0.22s ease,
    visibility 0.22s ease;
}

.advanced-filters-popover.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.advanced-filters-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 18px;
}

.advanced-filters-title {
  display: flex;
  align-items: center;
  gap: 10px;
}

.advanced-filters-title h2 {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.25;
  color: #191c1e;
}

.advanced-filters-title-icon {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  color: #373f50;
}

.advanced-filters-title-icon svg {
  width: 18px;
  height: 18px;
  stroke-width: 2.1;
}

.advanced-switch-row,
.advanced-toggle-row {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.advanced-switch-row {
  font-size: 12px;
  font-weight: 600;
  color: #4b5563;
}

.advanced-toggle-row {
  width: 100%;
  margin-top: 18px;
  font-size: 12px;
  font-weight: 500;
  color: #1f2937;
}

.advanced-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 42px;
  height: 24px;
  flex-shrink: 0;
}

.advanced-switch.compact {
  width: 34px;
  height: 18px;
}

.advanced-switch input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.advanced-switch-slider {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 999px;
  background: #d9dfeb;
  transition: background 0.2s ease;
}

.advanced-switch-slider::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #ffffff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.18);
  transition: transform 0.2s ease;
}

.advanced-switch.compact .advanced-switch-slider::before {
  top: 2px;
  left: 2px;
  width: 14px;
  height: 14px;
}

.advanced-switch input:checked + .advanced-switch-slider {
  background: #1558d6;
}

.advanced-switch input:checked + .advanced-switch-slider::before {
  transform: translateX(18px);
}

.advanced-switch.compact input:checked + .advanced-switch-slider::before {
  transform: translateX(16px);
}

.advanced-filters-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 26px;
  align-items: start;
}

.advanced-filters-main {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-areas:
    "airlines stops"
    "baggage class";
  column-gap: 27px;
  row-gap: 22px;
  align-content: start;
}

.advanced-filter-group {
  min-width: 0;
}

.advanced-filter-airlines {
  grid-area: airlines;
}

.advanced-filter-stops {
  grid-area: stops;
}

.advanced-filter-refund {
  margin-bottom: 16px;
}

.advanced-filter-baggage {
  grid-area: baggage;
}

.advanced-filter-class {
  grid-area: class;
}

.advanced-group-label,
.advanced-sub-label {
  margin: 0 0 16px;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #434655;
}

.advanced-group-label-child {
  margin-top: 20px;
}

.advanced-sub-label {
  margin-top: 16px;
  margin-bottom: 18px;
  color: #c4c9d4;
}

.advanced-input {
  width: 100%;
  padding: 8px 14px;
  border: 1px solid #e1e5ee;
  border-radius: 8px;
  background: #eceff3;
  color: #b7bfcb;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 11px;
  font-weight: 500;
  text-align: left;
}

.advanced-input.compact {
  min-height: 30px;
  margin-top: 14px;
  padding-inline: 11px;
  background: #f0f2f5;
  color: #4b5563;
  font-size: 11px;
}

.advanced-input svg {
  width: 13px;
  height: 13px;
  color: #6b7280;
}

.advanced-airline-search {
  position: relative;
}

.advanced-airline-field {
  cursor: text;
}

.advanced-airline-field input {
  min-width: 0;
  flex: 1;
  border: 0;
  outline: 0;
  background: transparent;
  color: #1f2937;
  font: inherit;
}

.advanced-airline-field input::placeholder {
  color: #9aa3b2;
}

.advanced-airline-options {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  z-index: 8;
  max-height: 180px;
  overflow-y: auto;
  padding: 6px;
  border: 1px solid #e1e5ee;
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.12);
}

.advanced-airline-options[hidden] {
  display: none;
}

.advanced-airline-options button {
  width: 100%;
  min-height: 34px;
  padding: 0 10px;
  border-radius: 8px;
  background: transparent;
  color: #1f2937;
  font-size: 12px;
  font-weight: 700;
  text-align: left;
}

.advanced-airline-options button:hover {
  background: #edf4ff;
  color: #1558d6;
}

.advanced-chip-row {
  display: flex;
  gap: 8px;
  margin-bottom: 17px;
}

.advanced-chip {
  min-width: 70px;
  padding: 8px 16px;
  border: 1px solid #c3c6d7;
  border-radius: 8px;
  background: #f7f8fb;
  color: #191c1e;
  font-size: 14px;
  font-weight: 700;
}

.advanced-chip.active {
  border-color: #1558d6;
  background: #1558d6;
  color: #ffffff;
}

.advanced-slider-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  font-size: 12px;
  font-weight: 700;
  color: #1f2937;
}

.advanced-slider-head strong {
  color: #1558d6;
}

.advanced-slider-track {
  position: relative;
  width: 100%;
  height: 5px;
  border-radius: 999px;
  background: #e3e7ec;
}

.advanced-slider-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: calc(100% - 66px);
  border-radius: inherit;
  background: #1558d6;
}

.advanced-slider-thumb {
  position: absolute;
  top: 50%;
  right: 60px;
  width: 15px;
  height: 15px;
  border: 2px solid #1558d6;
  border-radius: 50%;
  background: #ffffff;
  transform: translateY(-50%);
}

.advanced-option-card {
  width: 100%;
  min-height: 84px;
  padding: 16px;
  border: 1px solid #e5e9f0;
  border-radius: 14px;
  background: #f8fafc;
  text-align: left;
}

.advanced-option-card + .advanced-option-card {
  margin-top: 16px;
}

.advanced-option-card strong {
  display: block;
  margin-bottom: 12px;
  font-size: 14px;
  font-weight: 700;
  color: #191c1e;
}

.advanced-option-card span {
  display: block;
  font-size: 12px;
  line-height: 1.32;
  color: #434655;
}

.advanced-option-card.active {
  border-color: #1558d6;
  background: #fbfcff;
}

.advanced-check-row {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 500;
  color: #191c1e;
}

.advanced-check-row + .advanced-check-row {
  margin-top: 12px;
}

.advanced-check-row input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.advanced-check-box {
  position: relative;
  width: 16px;
  height: 16px;
  border: 1.5px solid #cdd5e1;
  border-radius: 4px;
  background: #f8fafc;
  flex-shrink: 0;
}

.advanced-check-row.active .advanced-check-box,
.advanced-check-row input:checked + .advanced-check-box {
  border-color: #1558d6;
  background: #1558d6;
}

.advanced-check-row.active .advanced-check-box::before,
.advanced-check-row input:checked + .advanced-check-box::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border: solid #ffffff;
  border-width: 0 1.8px 1.8px 0;
  transform: rotate(45deg);
}

.advanced-travellers-card {
  padding: 20px;
  border-radius: 14px;
  background: #ffffff;
}

.advanced-filters-layout-new {
  grid-template-columns: minmax(0, 1fr) 288px;
}

.advanced-filters-layout-new .advanced-filters-main {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr);
  grid-template-areas:
    "airlines stops"
    "baggage departure"
    "number departure";
  column-gap: 32px;
  row-gap: 26px;
}

.advanced-filter-departure {
  grid-area: departure;
}

.advanced-filter-number {
  grid-area: number;
}

.advanced-filter-class,
.advanced-travellers-card {
  display: none;
}

.advanced-selected-airlines {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
}

.advanced-airline-pill {
  position: relative;
  min-width: 106px;
  min-height: 36px;
  padding: 0 34px 0 24px;
  border-radius: 999px;
  background: #075bd8;
  color: #ffffff;
  font-size: 13px;
  font-weight: 500;
}

.advanced-airline-pill svg {
  position: absolute;
  top: -10px;
  right: -7px;
  width: 24px;
  height: 24px;
  padding: 5px;
  border-radius: 50%;
  background: #ffffff;
  color: #075bd8;
}

.advanced-time-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.advanced-time-card {
  display: grid;
  place-items: center;
  gap: 5px;
  padding: 16px 12px;
  border-radius: 10px;
  background: #ffffff;
  color: #1f2937;
  text-align: center;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}

.advanced-time-card svg {
  width: 18px;
  height: 18px;
  color: #757684;
}

.advanced-time-card strong {
  font-size: 16px;
  font-weight: 400;
}

.advanced-time-card span {
  font-size: 10px;
  color: #444653;
}

.advanced-flight-number-field {
  cursor: text;
}

.advanced-flight-number-field input {
  min-width: 0;
  flex: 1;
  border: 0;
  outline: 0;
  background: transparent;
  color: #1f2937;
  font: inherit;
}

.advanced-flight-number-field input::placeholder {
  color: #9aa3b2;
}

.advanced-time-card.active {
  background: #2949b8;
  color: #ffffff;
  box-shadow: inset 0 0 0 2px #ffffff;
}

.advanced-time-card.active svg,
.advanced-time-card.active span {
  color: #ffffff;
}

.advanced-filter-number .advanced-input {
  max-width: 278px;
}

.advanced-sidebar {
  min-width: 0;
}

.passenger-popover {
  position: absolute;
  top: calc(100% + 14px);
  right: 20px;
  left: auto;
  z-index: 31;
  width: 360px;
  max-width: min(360px, calc(100vw - 32px));
  overflow: hidden;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 20px 48px rgba(15, 23, 42, 0.16);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition:
    opacity 0.22s ease,
    transform 0.22s ease,
    visibility 0.22s ease;
}

.passenger-popover.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.passenger-dropdown-body {
  display: grid;
  gap: 18px;
  padding: 24px;
}

.passenger-popover .traveller-row {
  grid-template-columns: 52px minmax(0, 1fr) 40px 32px 40px;
  gap: 14px;
  padding: 0;
  border: 0;
}

.passenger-popover .traveller-icon {
  width: 40px;
  height: 40px;
}

/* .passenger-popover .traveller-step {
  width: 40px;
  height: 40px;
  border-radius: 9px;
  font-size: 20px;
} */

/* .passenger-popover .traveller-count {
  font-size: 22px;
} */

.passenger-extra-seat {
  min-height: 42px;
  margin: 4px 0 8px;
  border: 0;
  background: #f0f2f5;
  color: #3f4654;
  font-size: 14px;
  font-weight: 700;
}

.passenger-cabin-grid {
  grid-template-columns: repeat(4, max-content);
  gap: 10px;
}

.passenger-cabin-grid .mini-chip {
  min-height: 36px;
  padding: 0 16px;
  border-radius: 999px;
}

.passenger-fare-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.passenger-fare-grid .fare-chip {
  min-height: 40px;
  justify-content: flex-start;
  border: 1px solid #c8d0e1;
  border-radius: 9px;
  background: #ffffff;
  color: #1f2937;
  font-weight: 700;
}

.passenger-dropdown-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px;
  border-top: 1px solid #c3c6d74d;
  background: #eceef0;
}

.passenger-dropdown-footer strong,
.passenger-dropdown-footer span {
  display: block;
}

.passenger-dropdown-footer strong {
  color: #111827;
  font-size: 14px;
  font-weight: 700;
}

.passenger-dropdown-footer span {
  margin-top: 3px;
  color: #4b5563;
  font-size: 12px;
}

.passenger-dropdown-footer button {
  min-width: 128px;
  padding: 10px 32px;
  border-radius: 999px;
  background: #075bd8;
  color: #ffffff;
  font-size: 16px;
  font-weight: 700;
  box-shadow: 0 6px 12px rgba(7, 91, 216, 0.24);
}

.traveller-row {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 28px 18px 28px;
  align-items: center;
  gap: 12px;
}

/* .traveller-row + .traveller-row {
  margin-top: 18px;
} */

.traveller-row-primary {
  margin-bottom: 10px;
}

.traveller-icon {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #f3f6fb;
  color: #1558d6;
}

.traveller-icon.muted {
  background: #f5f6f8;
  color: #4b5563;
}

.traveller-icon svg {
  width: 20px;
  height: 20px;
  stroke-width: 2;
}

.traveller-copy {
  min-width: 0;
}

.traveller-copy strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.1;
  color: #1f2937;
}

.traveller-copy span {
  display: block;
  margin-top: 2px;
  font-size: 10px;
  color: #6b7280;
}

.traveller-step {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: #e5e7eb;
  color: #374151;
  font-size: 17px;
  line-height: 1;
}

.traveller-step.muted {
  color: #adb3bd;
  background: #f0f1f3;
}

.traveller-step.active {
  background: #2e63e5;
  color: #ffffff;
}

.traveller-count {
  font-size: 15px;
  font-weight: 700;
  text-align: center;
  color: #1f2937;
}

.traveller-list {
  margin-top: 16px;
}

.advanced-mini-section {
  margin-top: 20px;
}

.mini-chip-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.mini-chip {
  padding: 10px 16px;
  border-radius: 999px;
  background: #e6e8ea;
  color: #434655;
  font-size: 10px;
  font-weight: 500;
}

.mini-chip.active {
  background: #2563eb;
  color: #ffffff;
}

.fare-chip-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 6px;
}

.fare-chip {
  padding: 8px 12px;
  border: 1px solid #cdd5e1;
  border-radius: 8px;
  background: #ffffff;
  color: #1f2937;
  font-size: 10px;
  font-weight: 700;
  text-align: left;
}

.fare-chip::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-right: 6px;
  border: 1px solid #b4bece;
  border-radius: 50%;
  vertical-align: middle;
}

.fare-chip.active {
  border-color: #1558d6;
  background: #edf4ff;
  color: #1558d6;
}

.fare-chip.active::before {
  border-color: #1558d6;
  box-shadow: inset 0 0 0 3px #1558d6;
}

.section {
  padding: clamp(3.06rem, 2.6633rem + 1.763vw, 4.25rem) 0 0;
}

.deals-section {
  padding-top: clamp(4.95rem, 4.3083rem + 2.8519vw, 6.875rem);
  margin-bottom: clamp(2.375rem, 2.125rem + 1.1111vw, 3.125rem);
}

.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-16);
  margin-bottom: clamp(1.64rem, 1.52rem + 0.5333vw, 2rem);
}

.section-head.column {
  justify-content: flex-start;
}

.section-head.centered {
  flex-direction: column;
  justify-content: center;
  text-align: center;
  margin-bottom: clamp(2.375rem, 2.125rem + 1.1111vw, 3.125rem);
}

.section-head h2 {
  margin: 0;
  font-size: var(--fs-30);
  font-weight: 700;
  line-height: 1.2;
  color: #191c1e;
  font-family: "Poppins", sans-serif;
}

.section-head p {
  margin: clamp(0.23rem, 0.2233rem + 0.0296vw, 0.25rem) 0 0;
  font-size: var(--fs-16);
  line-height: 1.4;
  color: #434655;
}

.carousel-controls {
  display: flex;
  gap: var(--gap-7);
}

.control-btn {
  padding: clamp(0.46rem, 0.4467rem + 0.0593vw, 0.5rem);
  border-radius: 50%;
  background: #fff;
  color: #000000;
  border: 1px solid #d9dfeb;
  font-size: var(--fs-15);
  line-height: 1;
  display: grid;
  place-items: center;
}

.control-btn svg {
  width: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  height: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
}

.deals-track {
  display: flex;
  gap: var(--gap-11);
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  scroll-snap-type: x proximity;
}

.deals-track::-webkit-scrollbar {
  display: none;
}

.deal-card {
  flex: 0 0 clamp(21.875rem, 19.5313rem + 6.25vw, 25rem);
  min-width: 320px;
  min-height: clamp(4.2rem, 3.85rem + 1.5556vw, 5.25rem);
  border-radius: 14px;
  background: #fff;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  overflow: hidden;
  border: 4px solid transparent;
  scroll-snap-align: start;
}

.deal-card.blue {
  border-color: #2563eb;
}

.deal-card.purple {
  border-color: #9340ff;
}

.deal-card.teal {
  border-color: #1b9ca9;
}

.deal-label-1 {
  color: #2563eb;
}
.deal-label-2 {
  color: #4f46e5;
}

.deal-label-3 {
  color: #0d9488;
}

.deal-copy {
  padding: clamp(1.23rem, 1.14rem + 0.4vw, 1.5rem);
}

.deal-copy span {
  display: block;
  margin-bottom: clamp(0.495rem, 0.4725rem + 0.1vw, 0.5625rem);
  font-size: var(--fs-12);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.deal-copy h3 {
  margin: 0 0 clamp(0.46rem, 0.4467rem + 0.0593vw, 0.5rem);
  font-size: var(--fs-24);
  line-height: 1.1;
  color: #191c1e;
  font-weight: 800;
}

.deal-code-row {
  display: flex;
  align-items: center;
  gap: var(--gap-6);
}

.deal-copy p {
  display: inline-flex;
  margin: 0;
  padding: clamp(0.115rem, 0.1117rem + 0.0148vw, 0.125rem)
    clamp(0.4025rem, 0.3908rem + 0.0519vw, 0.4375rem);
  border-radius: 4px;
  background: #f4f6f9;
  font-size: var(--fs-12);
  line-height: 1.4;
  color: #697588;
}

.deal-code-row svg {
  width: clamp(0.69rem, 0.67rem + 0.0889vw, 0.75rem);
  height: clamp(0.69rem, 0.67rem + 0.0889vw, 0.75rem);
  color: #a2adbc;
  stroke-width: 2.2;
}

.deal-thumb,
.destination-image {
  background-size: cover;
  background-position: center;
}

.deal-thumb {
  border-left: 1px solid rgba(223, 229, 238, 0.7);
}

.scenic-one {
  background-image:
    linear-gradient(
      180deg,
      rgba(23, 31, 60, 0) 10%,
      rgba(23, 31, 60, 0.18) 100%
    ),
    url("../images/agentdeals-1.png");
}

.scenic-two {
  background-image:
    linear-gradient(
      180deg,
      rgba(23, 31, 60, 0) 10%,
      rgba(23, 31, 60, 0.12) 100%
    ),
    url("../images/agentdeals-2.png");
}

.scenic-three {
  background-image:
    linear-gradient(
      180deg,
      rgba(23, 31, 60, 0) 10%,
      rgba(23, 31, 60, 0.14) 100%
    ),
    url("../images/agentdeals-3.png");
}

.dots {
  display: flex;
  justify-content: center;
  gap: var(--gap-6);
  margin-top: clamp(0.88rem, 0.84rem + 0.1778vw, 1rem);
}

.dot {
  width: clamp(0.2375rem, 0.2333rem + 0.0185vw, 0.25rem);
  height: clamp(0.2375rem, 0.2333rem + 0.0185vw, 0.25rem);
  border-radius: 999px;
  background: #c7d1df;
}

.dot.active {
  width: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  background: #004ac6;
}

.destinations-section {
  padding-top: clamp(2.7075rem, 2.4225rem + 1.2667vw, 3.5625rem);
}

.destinations-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--gap-28);
}

.destination-card {
  min-width: 0;
  position: relative;
}

.destination-image {
  position: relative;
  height: clamp(9.25rem, 8.1667rem + 4.8148vw, 12.5rem);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: inset 0 -46px 50px rgba(15, 23, 41, 0.42);
}

.bangkok {
  background-image:
    linear-gradient(180deg, rgba(16, 27, 49, 0.04), rgba(16, 27, 49, 0.62)),
    url("https://images.unsplash.com/photo-1508009603885-50cf7c579365?auto=format&fit=crop&w=500&q=80");
}

.dubai {
  background-image:
    linear-gradient(180deg, rgba(16, 27, 49, 0.04), rgba(16, 27, 49, 0.54)),
    url("https://images.unsplash.com/photo-1512453979798-5ea266f8880c?auto=format&fit=crop&w=500&q=80");
}

.mumbai {
  background-image:
    linear-gradient(180deg, rgba(16, 27, 49, 0.04), rgba(16, 27, 49, 0.52)),
    url("https://images.unsplash.com/photo-1595658658481-d53d3f999875?auto=format&fit=crop&w=500&q=80");
}

.goa {
  background-image:
    linear-gradient(180deg, rgba(16, 27, 49, 0.04), rgba(16, 27, 49, 0.46)),
    url("https://images.unsplash.com/photo-1564507592333-c60657eea523?auto=format&fit=crop&w=500&q=80");
}

.delhi {
  background-image:
    linear-gradient(180deg, rgba(16, 27, 49, 0.04), rgba(16, 27, 49, 0.46)),
    url("https://images.unsplash.com/photo-1587474260584-136574528ed5?auto=format&fit=crop&w=500&q=80");
}

.singapore {
  background-image:
    linear-gradient(180deg, rgba(16, 27, 49, 0.04), rgba(16, 27, 49, 0.48)),
    url("https://images.unsplash.com/photo-1525625293386-3f8f99389edd?auto=format&fit=crop&w=500&q=80");
}

.destination-info {
  position: relative;
  padding-top: clamp(0.66rem, 0.63rem + 0.1333vw, 0.75rem);
}

.destination-title {
  position: absolute;
  left: 15px;
  bottom: 60px;
  margin: 0;
  z-index: 0;
  font-size: var(--fs-16);
  font-weight: 700;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.28);
}

.destination-info span {
  display: block;
  font-size: var(--fs-10);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: #64748b;
}

.destination-info strong {
  display: block;
  margin-top: clamp(0.23rem, 0.2233rem + 0.0296vw, 0.25rem);
  font-size: var(--fs-18);
  line-height: 1.05;
  font-weight: 700;
  color: #004aca;
}

.features-section {
  margin-top: clamp(4.5rem, 3.9167rem + 2.5926vw, 6.25rem);
  padding: clamp(4.5rem, 3.9167rem + 2.5926vw, 6.25rem) 0
    clamp(4.5rem, 3.9167rem + 2.5926vw, 6.25rem);
  background: var(--page-bg);
}

.group-booking-section {
  padding: clamp(3.6rem, 3.1333rem + 2.0741vw, 5rem) 0
    clamp(1.9rem, 1.7rem + 0.8889vw, 2.5rem);
}

.group-booking-card {
  position: relative;
  min-height: clamp(11.6088rem, 10.2492rem + 6.0426vw, 15.6875rem);
  padding: clamp(2.185rem, 1.955rem + 1.0222vw, 2.875rem)
    clamp(1.71rem, 1.53rem + 0.8vw, 2.25rem)
    clamp(1.71rem, 1.53rem + 0.8vw, 2.25rem);
  border-radius: 32px;
  overflow: hidden;
  background: url("../images/travel.png");

  background-repeat: no-repeat;
  background-position: top center;

  /* THIS */
  background-size: 100%;
}

.group-booking-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4); /* overlay color */
  z-index: 1;
}

/* Content overlay ke upar rahe */
.group-booking-card * {
  position: relative;
  z-index: 2;
}

.group-booking-copy {
  position: relative;
  z-index: 2;
  max-width: clamp(19.8875rem, 17.5583rem + 10.3519vw, 26.875rem);
}

.group-booking-copy h2 {
  margin: 0;
  font-size: var(--fs-30);
  line-height: 1.06;
  font-weight: 700;
  color: #ffffff;
}

.group-booking-copy p {
  margin: clamp(0.9225rem, 0.855rem + 0.3vw, 1.125rem) 0
    clamp(1.1275rem, 1.045rem + 0.3667vw, 1.375rem);
  max-width: clamp(17.8525rem, 15.7617rem + 9.2926vw, 24.125rem);
  font-size: var(--fs-16);
  line-height: 1.45;
  font-weight: 600;
  color: #ffffff;
}

.group-booking-btn {
  min-width: clamp(6.45rem, 5.9125rem + 2.3889vw, 8.0625rem);
  padding: clamp(0.66rem, 0.63rem + 0.1333vw, 0.75rem)
    clamp(1.64rem, 1.52rem + 0.5333vw, 2rem);
  border-radius: 999px;
  background-color: #004aca;
  color: #fff;
  font-size: var(--fs-16);
  font-weight: 600;
  box-shadow: 0 10px 18px rgba(0, 76, 201, 0.25);
}

.group-booking-art {
  position: absolute;
  right: 136px;
  bottom: 0;
  width: clamp(31.08rem, 27.44rem + 16.1778vw, 42rem);
  height: clamp(11.6088rem, 10.2492rem + 6.0426vw, 15.6875rem);
  pointer-events: none;
}

.sky-cloud {
  position: absolute;
  background: rgba(255, 255, 255, 0.82);
  filter: blur(1px);
}

.sky-cloud::before,
.sky-cloud::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  background: inherit;
}

.cloud-one {
  top: 70px;
  left: 145px;
  width: clamp(6.3rem, 5.775rem + 2.3333vw, 7.875rem);
  height: clamp(1.54rem, 1.47rem + 0.3111vw, 1.75rem);
  border-radius: 999px;
}

.cloud-one::before {
  left: 16px;
  top: -14px;
  width: clamp(2.31rem, 2.1633rem + 0.6519vw, 2.75rem);
  height: clamp(2.2rem, 2.1rem + 0.4444vw, 2.5rem);
}

.cloud-one::after {
  right: 12px;
  top: -10px;
  width: clamp(2.09rem, 1.995rem + 0.4222vw, 2.375rem);
  height: clamp(1.87rem, 1.785rem + 0.3778vw, 2.125rem);
}

.cloud-two {
  top: 66px;
  right: 92px;
  width: clamp(4.8rem, 4.4rem + 1.7778vw, 6rem);
  height: clamp(1.35rem, 1.3rem + 0.2222vw, 1.5rem);
  border-radius: 999px;
}

.cloud-two::before {
  left: 10px;
  top: -12px;
  width: clamp(1.87rem, 1.785rem + 0.3778vw, 2.125rem);
  height: clamp(1.65rem, 1.575rem + 0.3333vw, 1.875rem);
}

.cloud-two::after {
  right: 10px;
  top: -8px;
  width: clamp(1.54rem, 1.47rem + 0.3111vw, 1.75rem);
  height: clamp(1.43rem, 1.365rem + 0.2889vw, 1.625rem);
}

.group-plane {
  position: absolute;
  right: 184px;
  top: 94px;
  width: clamp(1.35rem, 1.3rem + 0.2222vw, 1.5rem);
  height: clamp(0.575rem, 0.5583rem + 0.0741vw, 0.625rem);
  background: #7c8188;
  clip-path: polygon(
    0 60%,
    46% 60%,
    74% 0,
    82% 0,
    72% 60%,
    100% 68%,
    100% 88%,
    70% 81%,
    61% 100%,
    51% 100%,
    57% 79%,
    0 80%
  );
  transform: rotate(-10deg);
  opacity: 0.82;
}

.earth-rim {
  position: absolute;
  left: 56px;
  bottom: -78px;
  width: clamp(22.6625rem, 20.0083rem + 11.7963vw, 30.625rem);
  height: clamp(7.6312rem, 6.7375rem + 3.9722vw, 10.3125rem);
  border-radius: 50%;
  background: radial-gradient(
    circle at 49% 18%,
    rgba(255, 255, 255, 0.96),
    rgba(255, 255, 255, 0.82) 38%,
    rgba(229, 236, 243, 0.96) 56%,
    rgba(60, 112, 163, 0.95) 70%,
    #13345f 100%
  );
  box-shadow: inset 0 -20px 22px rgba(17, 42, 74, 0.45);
}

.earth-rim::before {
  content: "";
  position: absolute;
  inset: 15px 42px 32px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 40% 80%, #8ebf55 0 9%, transparent 10%),
    radial-gradient(circle at 52% 72%, #61963b 0 8%, transparent 9%),
    radial-gradient(circle at 70% 74%, #9ccd54 0 10%, transparent 11%),
    radial-gradient(circle at 28% 66%, #6ea543 0 12%, transparent 13%),
    radial-gradient(circle at 64% 62%, #ffffff 0 42%, transparent 43%);
  opacity: 0.95;
}

.luggage-base {
  position: absolute;
  left: 262px;
  bottom: 45px;
  width: clamp(5.4rem, 4.95rem + 2vw, 6.75rem);
  height: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  border-radius: 50%;
  background: rgba(42, 31, 44, 0.18);
  filter: blur(6px);
}

.luggage-shell {
  position: absolute;
  left: 275px;
  bottom: 58px;
  width: clamp(4.5rem, 4.125rem + 1.6667vw, 5.625rem);
  height: clamp(2.09rem, 1.995rem + 0.4222vw, 2.375rem);
  border-radius: 10px 10px 12px 12px;
  background: linear-gradient(180deg, #fd8b69 0%, #dc5739 100%);
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, 0.35),
    0 8px 18px rgba(164, 67, 42, 0.24);
}

.luggage-shell::before {
  content: "";
  position: absolute;
  top: -7px;
  left: 14px;
  right: 14px;
  height: clamp(0.5175rem, 0.5025rem + 0.0667vw, 0.5625rem);
  border-radius: 7px 7px 0 0;
  background: linear-gradient(180deg, #fc9a7c, #f17658);
}

.luggage-shell::after {
  content: "";
  position: absolute;
  top: 6px;
  bottom: 6px;
  left: 43px;
  width: clamp(0.2375rem, 0.2333rem + 0.0185vw, 0.25rem);
  border-radius: 999px;
  background: rgba(161, 54, 36, 0.55);
  box-shadow:
    -22px 0 0 rgba(161, 54, 36, 0.55),
    22px 0 0 rgba(161, 54, 36, 0.55);
}

.traveler {
  position: absolute;
  left: 244px;
  bottom: 76px;
  width: clamp(9.1575rem, 8.085rem + 4.7667vw, 12.375rem);
  height: clamp(7.6312rem, 6.7375rem + 3.9722vw, 10.3125rem);
}

.traveler-head {
  position: absolute;
  top: 0;
  left: 76px;
  width: clamp(2.145rem, 2.0475rem + 0.4333vw, 2.4375rem);
  height: clamp(2.145rem, 2.0475rem + 0.4333vw, 2.4375rem);
  border-radius: 50%;
  background: #ffd7b3;
  z-index: 3;
}

.traveler-hair {
  position: absolute;
  top: -3px;
  left: 69px;
  width: clamp(2.8875rem, 2.7042rem + 0.8148vw, 3.4375rem);
  height: clamp(1.705rem, 1.6275rem + 0.3444vw, 1.9375rem);
  border-radius: 52% 48% 36% 42%;
  background: #54362f;
  z-index: 4;
}

.traveler-hair::after {
  content: "";
  position: absolute;
  right: 5px;
  top: -6px;
  width: clamp(0.9562rem, 0.9208rem + 0.1574vw, 1.0625rem);
  height: clamp(0.9562rem, 0.9208rem + 0.1574vw, 1.0625rem);
  border-radius: 50%;
  background: #54362f;
}

.traveler-body {
  position: absolute;
  left: 50px;
  top: 29px;
  width: clamp(5.55rem, 5.0875rem + 2.0556vw, 6.9375rem);
  height: clamp(2.835rem, 2.655rem + 0.8vw, 3.375rem);
  border-radius: 44px 44px 30px 30px;
  background: #d39a22;
  transform: rotate(-8deg);
}

.traveler-arm {
  position: absolute;
  top: 44px;
  width: clamp(3.7275rem, 3.4908rem + 1.0519vw, 4.4375rem);
  height: clamp(0.9562rem, 0.9208rem + 0.1574vw, 1.0625rem);
  border-radius: 999px;
  background: #d39a22;
  z-index: 2;
}

.arm-left {
  left: 1px;
  transform: rotate(-25deg);
}

.arm-right {
  right: -1px;
  transform: rotate(24deg);
}

.traveler-arm::after {
  content: "";
  position: absolute;
  width: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  height: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  border-radius: 50%;
  background: #ffd7b3;
  top: -1px;
}

.arm-left::after {
  left: -6px;
}

.arm-right::after {
  right: -7px;
}

.traveler-leg {
  position: absolute;
  top: 82px;
  width: clamp(4.7rem, 4.3083rem + 1.7407vw, 5.875rem);
  height: clamp(1.125rem, 1.0833rem + 0.1852vw, 1.25rem);
  border-radius: 999px;
  background: #cce1f7;
}

.leg-left {
  left: 37px;
  transform: rotate(21deg);
}

.leg-right {
  right: 10px;
  transform: rotate(-15deg);
}

.traveler-leg::after {
  content: "";
  position: absolute;
  right: -1px;
  top: 8px;
  width: clamp(1.54rem, 1.47rem + 0.3111vw, 1.75rem);
  height: clamp(0.575rem, 0.5583rem + 0.0741vw, 0.625rem);
  border-radius: 999px;
  background: #ffffff;
}

.monument {
  position: absolute;
  bottom: 64px;
}

.statue {
  left: 124px;
  width: clamp(3.045rem, 2.8517rem + 0.8593vw, 3.625rem);
  height: clamp(3.99rem, 3.7367rem + 1.1259vw, 4.75rem);
  background: linear-gradient(180deg, #98b787 0%, #6e9468 100%);
  clip-path: polygon(
    42% 0,
    53% 17%,
    60% 23%,
    59% 42%,
    70% 55%,
    67% 66%,
    74% 87%,
    28% 87%,
    34% 68%,
    28% 58%,
    38% 42%,
    37% 24%
  );
  transform: rotate(-16deg);
  opacity: 0.92;
}

.tower {
  left: 210px;
  width: clamp(2.835rem, 2.655rem + 0.8vw, 3.375rem);
  height: clamp(4.7rem, 4.3083rem + 1.7407vw, 5.875rem);
  background: linear-gradient(180deg, #d9ba78 0%, #a48140 100%);
  clip-path: polygon(
    44% 0,
    57% 0,
    65% 30%,
    82% 30%,
    73% 42%,
    67% 100%,
    33% 100%,
    28% 42%,
    19% 30%,
    36% 30%
  );
  transform: rotate(6deg);
}

.eiffel {
  right: 74px;
  width: clamp(5.8rem, 5.3167rem + 2.1481vw, 7.25rem);
  height: clamp(5.4rem, 4.95rem + 2vw, 6.75rem);
  background: linear-gradient(180deg, #f4b242 0%, #af6f14 100%);
  clip-path: polygon(
    48% 0,
    54% 0,
    63% 16%,
    76% 45%,
    92% 100%,
    81% 100%,
    68% 66%,
    59% 49%,
    57% 100%,
    43% 100%,
    41% 49%,
    32% 66%,
    19% 100%,
    8% 100%,
    24% 45%,
    37% 16%
  );
  transform: rotate(13deg);
}

.palm {
  width: clamp(2.31rem, 2.1633rem + 0.6519vw, 2.75rem);
  height: clamp(4.095rem, 3.835rem + 1.1556vw, 4.875rem);
}

.palm::before {
  content: "";
  position: absolute;
  left: 21px;
  bottom: 0;
  width: clamp(0.2375rem, 0.2333rem + 0.0185vw, 0.25rem);
  height: clamp(2.52rem, 2.36rem + 0.7111vw, 3rem);
  border-radius: 999px;
  background: #8c5d2d;
}

.palm::after {
  content: "";
  position: absolute;
  left: 8px;
  top: 8px;
  width: clamp(1.54rem, 1.47rem + 0.3111vw, 1.75rem);
  height: clamp(1.54rem, 1.47rem + 0.3111vw, 1.75rem);
  border-radius: 60% 40% 60% 40%;
  background: #34a65a;
  box-shadow:
    -10px 4px 0 #2f9e52,
    10px 4px 0 #2f9e52,
    -8px 18px 0 #37b05f,
    8px 18px 0 #37b05f;
}

.palm-left {
  left: 150px;
  bottom: 52px;
  transform: scale(0.8);
}

.palm-right {
  right: 52px;
  bottom: 55px;
  transform: scale(0.82);
}

.group-booking-avatars {
  position: absolute;
  top: 140px;
  right: 36px;
  z-index: 2;
  display: flex;
  align-items: center;
}

.avatar-chip,
.avatar-count {
  width: clamp(2.73rem, 2.5567rem + 0.7704vw, 3.25rem);
  height: clamp(2.73rem, 2.5567rem + 0.7704vw, 3.25rem);
  margin-left: clamp(-0.46rem, -0.4467rem + -0.0593vw, -0.5rem);
  border-radius: 50%;
  border: 3px solid #37b6e6;
  box-shadow: 0 6px 12px rgba(12, 72, 142, 0.18);
}

.avatar-chip:first-child {
  margin-left: 0;
}

.avatar-chip {
  position: relative;
  background:
    radial-gradient(circle at 50% 34%, #ffd4b1 0 18%, transparent 19%),
    radial-gradient(circle at 50% 72%, #2f6aa3 0 26%, transparent 27%),
    linear-gradient(180deg, #ffbe44 0%, #f2a630 100%);
}

.avatar-chip::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 12px;
  width: clamp(1.2938rem, 1.2458rem + 0.213vw, 1.4375rem);
  height: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  border-radius: 14px 14px 8px 8px;
  background: #5c3d2b;
}

.avatar-chip::after {
  content: "";
  position: absolute;
  top: 18px;
  left: 15px;
  width: clamp(0.9562rem, 0.9208rem + 0.1574vw, 1.0625rem);
  height: clamp(0.2969rem, 0.2917rem + 0.0231vw, 0.3125rem);
  border-radius: 999px;
  background: rgba(39, 43, 52, 0.2);
}

.avatar-b {
  background:
    radial-gradient(circle at 50% 34%, #ffd8bb 0 18%, transparent 19%),
    radial-gradient(circle at 50% 72%, #5d8cc0 0 26%, transparent 27%),
    linear-gradient(180deg, #ffcd56 0%, #f0b03a 100%);
}

.avatar-b::before {
  background: #4f4238;
}

.avatar-b::after {
  top: 13px;
  left: 11px;
  width: clamp(1.43rem, 1.365rem + 0.2889vw, 1.625rem);
  height: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  border-radius: 0;
  background:
    linear-gradient(
      90deg,
      transparent 0 5px,
      #374151 5px 7px,
      transparent 7px 19px,
      #374151 19px 21px,
      transparent 21px 100%
    ),
    radial-gradient(
      circle at 7px 8px,
      transparent 0 5px,
      #374151 5px 6px,
      transparent 6px
    ),
    radial-gradient(
      circle at 19px 8px,
      transparent 0 5px,
      #374151 5px 6px,
      transparent 6px
    );
}

.avatar-c {
  background:
    radial-gradient(circle at 50% 34%, #ffd9b7 0 18%, transparent 19%),
    radial-gradient(circle at 50% 72%, #3d9469 0 26%, transparent 27%),
    linear-gradient(180deg, #d59a43 0%, #b3781e 100%);
}

.avatar-c::before {
  background: #63482f;
}

.avatar-count {
  display: grid;
  place-items: center;
  margin-left: clamp(-0.46rem, -0.4467rem + -0.0593vw, -0.5rem);
  background: linear-gradient(180deg, #1f63eb 0%, #184fca 100%);
  color: #fff;
  font-size: var(--fs-15);
  font-weight: 600;
}

.app-booking-section {
  padding: clamp(4.725rem, 4.1125rem + 2.7222vw, 6.5625rem) 0
    clamp(2.66rem, 2.38rem + 1.2444vw, 3.5rem);
}

.app-booking-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 430px);
  align-items: start;
  gap: var(--gap-34);
}

.app-booking-layout > div:first-child {
  min-width: 0;
  align-items: center;
  display: inline-flex;
  justify-content: center;
}

.app-booking-layout > div:first-child img {
  display: block;
  width: 100%;
  max-width: clamp(18.75rem, 0rem + 50vw, 43.75rem);
  height: clamp(18.75rem, 11.7188rem + 18.75vw, 28.125rem);
}

.app-visual {
  position: relative;
  min-height: clamp(17.575rem, 15.5167rem + 9.1481vw, 23.75rem);
}

.app-floor {
  position: absolute;
  left: 42px;
  height: clamp(0.1188rem, 0.1167rem + 0.0093vw, 0.125rem);
  background: #4dbce8;
}

.line-one {
  bottom: 76px;
  width: clamp(22.2925rem, 19.6817rem + 11.6037vw, 30.125rem);
}

.line-two {
  bottom: 54px;
  width: clamp(15.725rem, 13.8833rem + 8.1852vw, 21.25rem);
}

.app-glow {
  position: absolute;
  left: 180px;
  bottom: 32px;
  width: clamp(11.9325rem, 10.535rem + 6.2111vw, 16.125rem);
  height: clamp(3.885rem, 3.6383rem + 1.0963vw, 4.625rem);
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(149, 145, 255, 0.28),
    rgba(149, 145, 255, 0)
  );
}

.backdrop-blob {
  position: absolute;
  background: #ffc4d8;
  opacity: 0.95;
}

.blob-left {
  left: 86px;
  bottom: 72px;
  width: clamp(8.325rem, 7.35rem + 4.3333vw, 11.25rem);
  height: clamp(6.9rem, 6.325rem + 2.5556vw, 8.625rem);
  border-radius: 42% 58% 40% 60%;
}

.blob-right {
  left: 254px;
  bottom: 82px;
  width: clamp(8.9725rem, 7.9217rem + 4.6704vw, 12.125rem);
  height: clamp(5.5rem, 5.0417rem + 2.037vw, 6.875rem);
  border-radius: 53% 47% 44% 56%;
  transform: rotate(-8deg);
}

.leaf-spray {
  position: absolute;
  bottom: 78px;
  width: clamp(4.3rem, 3.9417rem + 1.5926vw, 5.375rem);
  height: clamp(7.4rem, 6.7833rem + 2.7407vw, 9.25rem);
}

.leaf-spray::before,
.leaf-spray::after {
  content: "";
  position: absolute;
  left: 42px;
  bottom: 0;
  width: clamp(0.2375rem, 0.2333rem + 0.0185vw, 0.25rem);
  height: clamp(6.2rem, 5.6833rem + 2.2963vw, 7.75rem);
  border-radius: 999px;
  background: #88b23f;
}

.leaf-spray::after {
  width: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  height: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  left: 0;
  bottom: 118px;
  border-radius: 50%;
  background: #a9c94f;
  box-shadow: none;
}

.leaf-spray.spray-left {
  left: 176px;
}

.leaf-spray.spray-right {
  left: 404px;
}

.leaf-spray.spray-left::before,
.leaf-spray.spray-right::before {
  box-shadow:
    -18px -10px 0 8px #8fbe44,
    16px -26px 0 8px #7aac36,
    -16px -52px 0 8px #99c655,
    18px -72px 0 8px #80b33a,
    -8px -96px 0 7px #8ab93f;
}

.phone-frame {
  position: absolute;
  left: 229px;
  bottom: 84px;
  width: clamp(6.85rem, 6.2792rem + 2.537vw, 8.5625rem);
  height: clamp(12.0712rem, 10.6575rem + 6.2833vw, 16.3125rem);
  border: 5px solid #163f69;
  border-radius: 16px;
  background: #d9e4ff;
  box-shadow: 0 8px 18px rgba(49, 82, 140, 0.12);
  z-index: 3;
}

.phone-notch {
  position: absolute;
  left: 50%;
  top: 0;
  width: clamp(2.415rem, 2.2617rem + 0.6815vw, 2.875rem);
  height: clamp(0.575rem, 0.5583rem + 0.0741vw, 0.625rem);
  border-radius: 0 0 12px 12px;
  background: #163f69;
  transform: translateX(-50%);
}

.phone-screen {
  position: absolute;
  inset: 24px 11px 11px;
  border-radius: 12px;
  background: linear-gradient(180deg, #f2f6ff 0%, #fefeff 100%);
  overflow: hidden;
}

.globe-card {
  position: absolute;
  left: 17px;
  top: 12px;
  width: clamp(3.255rem, 3.0483rem + 0.9185vw, 3.875rem);
  height: clamp(3.255rem, 3.0483rem + 0.9185vw, 3.875rem);
  border-radius: 50%;
  background:
    radial-gradient(circle at 38% 34%, #ffffff 0 9%, transparent 10%),
    radial-gradient(circle at 48% 49%, #ffffff 0 15%, transparent 16%),
    radial-gradient(circle at 68% 64%, #ffffff 0 10%, transparent 11%),
    linear-gradient(180deg, #4bc2ea 0%, #36a9dd 100%);
}

.globe-card::after {
  content: "";
  position: absolute;
  left: 9px;
  bottom: -34px;
  width: clamp(4.095rem, 3.835rem + 1.1556vw, 4.875rem);
  height: clamp(4.4rem, 4.0333rem + 1.6296vw, 5.5rem);
  background: linear-gradient(180deg, #3e92d3, #2d6bb4);
  clip-path: polygon(
    52% 0,
    73% 12%,
    89% 39%,
    83% 64%,
    74% 100%,
    30% 100%,
    18% 72%,
    12% 47%,
    19% 22%,
    34% 5%
  );
}

.boarding-line {
  position: absolute;
  left: 10px;
  height: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  border-radius: 4px;
  background: #ffffff;
}

.board-one {
  bottom: 42px;
  width: clamp(4.095rem, 3.835rem + 1.1556vw, 4.875rem);
}

.board-two {
  bottom: 15px;
  width: clamp(2.73rem, 2.5567rem + 0.7704vw, 3.25rem);
}

.board-three {
  right: 10px;
  left: auto;
  bottom: 15px;
  width: clamp(1.76rem, 1.68rem + 0.3556vw, 2rem);
}

.figure {
  position: absolute;
  z-index: 4;
}

.figure-head {
  position: absolute;
  width: clamp(1.595rem, 1.5225rem + 0.3222vw, 1.8125rem);
  height: clamp(1.595rem, 1.5225rem + 0.3222vw, 1.8125rem);
  border-radius: 50%;
  background: #ffd8bd;
}

.figure-hair {
  position: absolute;
  width: clamp(2.415rem, 2.2617rem + 0.6815vw, 2.875rem);
  height: clamp(1.43rem, 1.365rem + 0.2889vw, 1.625rem);
  background: #444447;
}

.figure-body {
  position: absolute;
}

.figure-arm,
.figure-leg {
  position: absolute;
  border-radius: 999px;
}

.seated-figure {
  left: 72px;
  bottom: 18px;
  width: clamp(8.51rem, 7.5133rem + 4.4296vw, 11.5rem);
  height: clamp(8.9725rem, 7.9217rem + 4.6704vw, 12.125rem);
}

.seated-figure .figure-head {
  left: 50px;
  top: 8px;
}

.seated-figure .figure-hair {
  left: 28px;
  top: 0;
  border-radius: 40px 20px 26px 26px;
}

.seated-figure .figure-body {
  left: 30px;
  top: 46px;
  width: clamp(4.5rem, 4.125rem + 1.6667vw, 5.625rem);
  height: clamp(4.095rem, 3.835rem + 1.1556vw, 4.875rem);
  border-radius: 34px 34px 22px 22px;
  background: #ffd65c;
}

.seated-figure .left-arm {
  left: 10px;
  top: 78px;
  width: clamp(2.94rem, 2.7533rem + 0.8296vw, 3.5rem);
  height: clamp(0.8625rem, 0.8375rem + 0.1111vw, 0.9375rem);
  background: #ffd8bd;
  transform: rotate(21deg);
}

.seated-figure .right-arm {
  left: 80px;
  top: 74px;
  width: clamp(2.835rem, 2.655rem + 0.8vw, 3.375rem);
  height: clamp(0.805rem, 0.7817rem + 0.1037vw, 0.875rem);
  background: #ffd8bd;
  transform: rotate(-18deg);
}

.seated-figure .left-leg {
  left: 60px;
  top: 118px;
  width: clamp(1.35rem, 1.3rem + 0.2222vw, 1.5rem);
  height: clamp(4.85rem, 4.4458rem + 1.7963vw, 6.0625rem);
  background: #ffd3a7;
  transform: rotate(-2deg);
}

.seated-figure .right-leg {
  left: 84px;
  top: 116px;
  width: clamp(1.43rem, 1.365rem + 0.2889vw, 1.625rem);
  height: clamp(5.2rem, 4.7667rem + 1.9259vw, 6.5rem);
  background: #ffc187;
  transform: rotate(19deg);
}

.seated-figure .left-leg::after,
.seated-figure .right-leg::after {
  content: "";
  position: absolute;
  bottom: -2px;
  width: clamp(1.1813rem, 1.1375rem + 0.1944vw, 1.3125rem);
  height: clamp(0.4156rem, 0.4083rem + 0.0324vw, 0.4375rem);
  border-radius: 999px;
  background: #4f4f50;
}

.seated-figure .left-leg::after {
  left: -3px;
}

.seated-figure .right-leg::after {
  right: -5px;
}

.laptop {
  position: absolute;
  left: 70px;
  top: 82px;
  width: clamp(4.095rem, 3.835rem + 1.1556vw, 4.875rem);
  height: clamp(2.73rem, 2.5567rem + 0.7704vw, 3.25rem);
  border-radius: 6px 6px 4px 4px;
  background: linear-gradient(180deg, #fbfbfc 0%, #dfe4eb 100%);
  transform: skew(-8deg);
  box-shadow: 0 6px 10px rgba(74, 86, 113, 0.12);
}

.laptop::before {
  content: "";
  position: absolute;
  inset: 16px 32px auto auto;
  width: clamp(0.7475rem, 0.7258rem + 0.0963vw, 0.8125rem);
  height: clamp(0.7475rem, 0.7258rem + 0.0963vw, 0.8125rem);
  border-radius: 50%;
  background: #eef1f4;
}

.standing-figure {
  left: 302px;
  bottom: 64px;
  width: clamp(7.2rem, 6.6rem + 2.6667vw, 9rem);
  height: clamp(11.1rem, 9.8rem + 5.7778vw, 15rem);
}

.standing-figure .figure-head {
  left: 54px;
  top: 0;
}

.standing-figure .figure-hair {
  left: 44px;
  top: -5px;
  width: clamp(3.99rem, 3.7367rem + 1.1259vw, 4.75rem);
  height: clamp(2.205rem, 2.065rem + 0.6222vw, 2.625rem);
  border-radius: 28px 44px 26px 42px;
}

.standing-figure .figure-hair::after {
  content: "";
  position: absolute;
  right: -18px;
  top: 12px;
  width: clamp(2.31rem, 2.1633rem + 0.6519vw, 2.75rem);
  height: clamp(1.87rem, 1.785rem + 0.3778vw, 2.125rem);
  border-radius: 40% 60% 56% 44%;
  background: #444447;
}

.standing-figure .figure-body {
  left: 44px;
  top: 36px;
  width: clamp(3.57rem, 3.3433rem + 1.0074vw, 4.25rem);
  height: clamp(6rem, 5.5rem + 2.2222vw, 7.5rem);
  border-radius: 26px 26px 12px 12px;
  background: #1173b9;
}

.standing-figure .left-arm {
  left: 18px;
  top: 60px;
  width: clamp(3.36rem, 3.1467rem + 0.9481vw, 4rem);
  height: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  background: #1173b9;
  transform: rotate(35deg);
}

.standing-figure .right-arm {
  left: 76px;
  top: 72px;
  width: clamp(2.835rem, 2.655rem + 0.8vw, 3.375rem);
  height: clamp(0.9562rem, 0.9208rem + 0.1574vw, 1.0625rem);
  background: #1173b9;
  transform: rotate(-26deg);
}

.standing-figure .left-arm::after,
.standing-figure .right-arm::after {
  content: "";
  position: absolute;
  right: -5px;
  top: -1px;
  width: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  height: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  border-radius: 50%;
  background: #ffd8bd;
}

.standing-figure .left-leg {
  left: 48px;
  top: 142px;
  width: clamp(1.35rem, 1.3rem + 0.2222vw, 1.5rem);
  height: clamp(4.9rem, 4.4917rem + 1.8148vw, 6.125rem);
  background: #0f4c7b;
  transform: rotate(3deg);
}

.standing-figure .right-leg {
  left: 78px;
  top: 142px;
  width: clamp(1.35rem, 1.3rem + 0.2222vw, 1.5rem);
  height: clamp(4.9rem, 4.4917rem + 1.8148vw, 6.125rem);
  background: #0f4c7b;
  transform: rotate(-8deg);
}

.mini-kite {
  position: absolute;
  left: 452px;
  top: 50px;
  width: clamp(2.2rem, 2.1rem + 0.4444vw, 2.5rem);
  height: clamp(2.2rem, 2.1rem + 0.4444vw, 2.5rem);
  border: 2px solid #f4c95d;
  transform: rotate(34deg);
  opacity: 0.9;
}

.ground-bush {
  position: absolute;
  bottom: 60px;
  background: #a6d348;
  border-radius: 999px 999px 0 0;
}

.bush-one {
  left: 218px;
  width: clamp(2.31rem, 2.1633rem + 0.6519vw, 2.75rem);
  height: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
}

.bush-two {
  left: 390px;
  width: clamp(2.205rem, 2.065rem + 0.6222vw, 2.625rem);
  height: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
}

.bush-three {
  left: 434px;
  width: clamp(1.87rem, 1.785rem + 0.3778vw, 2.125rem);
  height: clamp(0.805rem, 0.7817rem + 0.1037vw, 0.875rem);
}

.app-booking-copy {
  padding-top: clamp(0.115rem, 0.1117rem + 0.0148vw, 0.125rem);
}

.app-booking-copy h2 {
  margin: 0;
  max-width: clamp(16.8812rem, 14.9042rem + 8.787vw, 22.8125rem);
  font-family: "Poppins", sans-serif;
  font-size: var(--fs-30);
  line-height: 1.12;
  font-weight: 700;
  letter-spacing: -0.04em;
  color: #202328;
}

.app-booking-copy p {
  margin: clamp(1.435rem, 1.33rem + 0.4667vw, 1.75rem) 0
    clamp(1.3325rem, 1.235rem + 0.4333vw, 1.625rem);
  max-width: clamp(18.87rem, 16.66rem + 9.8222vw, 25.5rem);
  font-size: var(--fs-16);
  line-height: 1.65;
  color: #475569;
}

.app-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--gap-24);
  max-width: clamp(18.5rem, 16.3333rem + 9.6296vw, 25rem);
  padding-top: clamp(1.435rem, 1.33rem + 0.4667vw, 1.75rem);
  border-top: 1px solid #f1f5f9;
}

.app-stat strong {
  display: block;
  margin-bottom: clamp(0.23rem, 0.2233rem + 0.0296vw, 0.25rem);
  color: #004aca;
  font-size: var(--fs-30);
  line-height: 1;
  font-weight: 800;
}

.app-stat span {
  display: block;
  font-size: var(--fs-16);
  color: #64748b;
}

.site-header--results {
  background: #ffffff;
  border-bottom: 1px solid #edf1f7;
}

.site-header--results .site-header-container {
  min-height: 76px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.site-header--hero .site-header-container {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-20);
}

.site-brand {
  font-family: "Poppins", sans-serif;
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.04em;
}

.site-header--hero .site-brand {
  font-size: var(--fs-30);
  font-weight: 700;
  letter-spacing: 0;
}

.site-nav,
.site-actions {
  display: flex;
  align-items: center;
}

.site-nav {
  flex: 1;
  gap: 28px;
  margin-left: 44px;
}

.site-header--hero .site-nav {
  flex: initial;
  gap: var(--gap-18);
  margin-left: 0;
}

.site-nav a {
  font-family: "Poppins", sans-serif;
  color: #666666;
  font-size: 14px;
  font-weight: 600;
}

.site-header--hero .site-nav a {
  font-size: var(--fs-18);
  color: #ffffff99;
}

.site-nav a.is-active {
  color: #111111;
}

.site-header--hero .site-nav a.active {
  color: #ffffff;
  font-weight: 700;
}

.site-actions {
  position: relative;
  gap: 16px;
  color: #1d1d1d;
  font-size: 13px;
}

.site-header--hero .site-actions {
  gap: var(--gap-18);
  color: #ffffff;
}

.site-actions > a {
  font-size: 13px;
  font-weight: 500;
}

.site-header--hero .site-actions > a,
.site-header--hero .site-actions button {
  color: #ffffff;
  font-size: var(--fs-18);
  font-weight: 400;
}

.site-wallet,
.site-currency,
.site-menu-button {
  border: 0;
  background: transparent;
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: inherit;
}

.site-header--hero .site-wallet,
.site-header--hero .site-currency {
  gap: var(--gap-7);
}

.site-avatar,
.site-flag {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
  overflow: hidden;
}

.site-flag img,
.site-menu-button img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.site-header--hero .site-avatar,
.site-header--hero .site-flag {
  width: clamp(0.805rem, 0.7817rem + 0.1037vw, 0.875rem);
  height: clamp(0.805rem, 0.7817rem + 0.1037vw, 0.875rem);
}

.site-avatar {
  background:
    radial-gradient(circle at 55% 32%, #ffd9c8 0 20%, transparent 21%),
    radial-gradient(circle at 50% 48%, #87b4e8 0 41%, #2557b8 42% 100%);
}

.site-header--hero .site-avatar {
  background: radial-gradient(circle at 35% 35%, #c7ecff, #2f6bf2);
  border: 1px solid rgba(255, 255, 255, 0.65);
}

.site-header--hero .site-flag {
  border-color: rgba(255, 255, 255, 0.65);
}

.site-menu-button {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  overflow: hidden;
}

.site-header--hero .site-menu-button {
  gap: var(--gap-2);
}

.site-menu-button span {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #111111;
}

.site-header--hero .site-menu-button span {
  width: clamp(0.1781rem, 0.175rem + 0.0139vw, 0.1875rem);
  height: clamp(0.1781rem, 0.175rem + 0.0139vw, 0.1875rem);
  background: #ffffff;
}

@media (max-width: 1180px) {
  .site-header--results .site-nav {
    gap: 18px;
    margin-left: 24px;
  }
}

@media (max-width: 1024px) {
  .site-header--results .site-header-container {
    min-height: 62px;
  }

  .site-header--results .site-brand {
    font-size: 22px;
  }

  .site-header--results .site-nav,
  .site-header--results .site-actions > a {
    display: none;
  }

  .site-header--results .site-actions {
    gap: 12px;
  }

  .site-header--results .site-wallet,
  .site-header--results .site-currency {
    font-size: 13px;
    font-weight: 700;
  }

  .site-header--results .site-wallet span:last-child {
    max-width: 74px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .site-header--results .site-menu-button {
    display: inline-flex;
  }
}

.site-footer {
  padding: clamp(2.755rem, 2.465rem + 1.2889vw, 3.625rem) 0
    clamp(2.97rem, 2.585rem + 1.7111vw, 4.125rem);
  background: #ffffff;
}

.footer-container {
  width: min(
    100% - clamp(2.2rem, 2.1rem + 0.4444vw, 2.5rem),
    clamp(66.6rem, 58.8rem + 34.6667vw, 90rem)
  );
}

.footer-mobile-accordion,
.footer-legal {
  display: none;
}

.footer-top,
.footer-middle {
  display: grid;
}

.footer-top {
  grid-template-columns: 1.02fr 1.05fr 1fr 1fr 1fr;
  gap: var(--gap-56);
  padding-bottom: clamp(2.09rem, 1.87rem + 0.9778vw, 2.75rem);
}

.footer-middle {
  grid-template-columns: 1fr 1fr 1.05fr 1.08fr;
  gap: var(--gap-56);
  padding: clamp(1.805rem, 1.615rem + 0.8444vw, 2.375rem) 0
    clamp(1.9rem, 1.7rem + 0.8889vw, 2.5rem);
  border-top: 1px solid #eef1f4;
}

.footer-bottom {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--gap-24);
  padding-top: clamp(1.5375rem, 1.425rem + 0.5vw, 1.875rem);
  border-top: 1px solid #eef1f4;
}

.footer-column h3,
.footer-column h4 {
  margin: 0;
  font-family: "Poppins", sans-serif;
  color: #14171c;
}

.footer-column h3 {
  margin-bottom: clamp(0.715rem, 0.6825rem + 0.1444vw, 0.8125rem);
  font-size: var(--fs-16);
  line-height: 1.2;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.footer-column h4 {
  margin-top: clamp(0.88rem, 0.84rem + 0.1778vw, 1rem);
  margin-bottom: clamp(0.55rem, 0.525rem + 0.1111vw, 0.625rem);
  font-size: var(--fs-13);
  line-height: 1.25;
  font-weight: 700;
  text-transform: uppercase;
}

.footer-column a {
  display: block;
  margin-bottom: clamp(0.55rem, 0.525rem + 0.1111vw, 0.625rem);
  font-size: var(--fs-14);
  line-height: 1.25;
  color: #777777;
}

.footer-column p {
  margin: 0 0 clamp(0.9225rem, 0.855rem + 0.3vw, 1.125rem);
  max-width: clamp(14.615rem, 12.9033rem + 7.6074vw, 19.75rem);
  font-size: var(--fs-14);
  line-height: 1.55;
  color: #777777;
}

.footer-airlines .airlines-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: var(--gap-24);
}

.store-buttons {
  display: flex;
  align-items: center;
  gap: var(--gap-10);
  flex-wrap: wrap;
}

.store-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--gap-10);
  min-width: clamp(5.05rem, 4.6292rem + 1.8704vw, 6.3125rem);
  padding: clamp(0.345rem, 0.335rem + 0.0444vw, 0.375rem)
    clamp(0.605rem, 0.5775rem + 0.1222vw, 0.6875rem)
    clamp(0.345rem, 0.335rem + 0.0444vw, 0.375rem)
    clamp(0.55rem, 0.525rem + 0.1111vw, 0.625rem);
  border-radius: 4px;
  background: #040404;
  color: #ffffff;
}

.store-icon {
  position: relative;
  width: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
  height: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
  flex-shrink: 0;
}

.store-icon.apple::before {
  content: "";
  position: absolute;
  left: 3px;
  top: 2px;
  width: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  height: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  background: #fff;
  border-radius: 44% 44% 46% 46% / 48% 48% 40% 40%;
  clip-path: polygon(
    52% 0,
    70% 10%,
    82% 27%,
    82% 63%,
    70% 88%,
    48% 100%,
    26% 91%,
    14% 67%,
    15% 36%,
    30% 12%
  );
}

.store-icon.apple::after {
  content: "";
  position: absolute;
  left: 11px;
  top: -1px;
  width: clamp(0.4156rem, 0.4083rem + 0.0324vw, 0.4375rem);
  height: clamp(0.3562rem, 0.35rem + 0.0278vw, 0.375rem);
  background: #fff;
  border-radius: 100% 0 100% 0;
  transform: rotate(-33deg);
}

.store-icon.play::before {
  content: "";
  position: absolute;
  left: 1px;
  top: 2px;
  width: 0;
  height: 0;
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
  border-left: 16px solid #00d95f;
}

.store-icon.play::after {
  content: "";
  position: absolute;
  left: 0;
  top: 2px;
  width: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  height: clamp(1.0125rem, 0.975rem + 0.1667vw, 1.125rem);
  background:
    linear-gradient(45deg, transparent 44%, #ffd234 45% 58%, transparent 59%),
    linear-gradient(-45deg, transparent 42%, #ff5c5c 43% 57%, transparent 58%),
    linear-gradient(180deg, transparent 32%, #34a1ff 33% 69%, transparent 70%);
  clip-path: polygon(0 0, 100% 50%, 0 100%, 18% 50%);
}

.store-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.store-text small {
  font-size: var(--fs-8);
  color: rgba(255, 255, 255, 0.82);
}

.store-text strong {
  margin-top: clamp(0.115rem, 0.1117rem + 0.0148vw, 0.125rem);
  font-size: var(--fs-16);
  font-weight: 500;
  letter-spacing: -0.02em;
}

.footer-meta p {
  margin: clamp(0.77rem, 0.735rem + 0.1556vw, 0.875rem) 0 0;
  font-size: var(--fs-13);
  line-height: 1.35;
  color: #161616;
}

.footer-social-text {
  display: flex;
  align-items: center;
  gap: var(--gap-21);
}

.footer-social-text a {
  font-size: var(--fs-17);
  line-height: 1;
  color: #171717;
}

.footer-social-icons {
  display: flex;
  align-items: center;
  gap: var(--gap-14);
}

.footer-social-icons a {
  width: clamp(1.54rem, 1.47rem + 0.3111vw, 1.75rem);
  height: clamp(1.54rem, 1.47rem + 0.3111vw, 1.75rem);
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  background: #ffffff;
  color: #ffffff;
}

.footer-legal {
  border-top: 1px solid #d8dce3;
}

.footer-legal p {
  margin: 0;
  text-align: center;
}

.footer-social-icons svg {
  width: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  height: clamp(0.92rem, 0.8933rem + 0.1185vw, 1rem);
  stroke-width: 2.2;
}

.narrow {
  width: min(
    100% - clamp(1.76rem, 1.68rem + 0.3556vw, 2rem),
    clamp(59.2rem, 52.2667rem + 30.8148vw, 80rem)
  );
}

.features-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap-32);
}

.feature-box {
  padding: clamp(1.64rem, 1.52rem + 0.5333vw, 2rem);
  background: #fff;
  border: 1px solid #f1f5f9;
  border-radius: 14px;
  text-align: center;
  box-shadow: 0 12px 25px rgba(25, 43, 80, 0.04);
}

.feature-icon {
  width: clamp(2.31rem, 2.1633rem + 0.6519vw, 2.75rem);
  height: clamp(2.31rem, 2.1633rem + 0.6519vw, 2.75rem);
  margin: 0 auto;
  display: grid;
  place-items: center;
  border-radius: 10px;
  font-size: var(--fs-14);
  font-weight: 700;
}

.blue-icon {
  color: #2a63ff;
  background: #eff6ff;
}
.blue-icon svg {
  color: #2563eb;
  width: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
  height: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
}

.green-icon svg {
  color: #1baf5d;
  width: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
  height: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
}

.orange-icon svg {
  color: #ff7d21;
  width: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
  height: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
}

.purple-icon svg {
  color: #9747ff;
  width: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
  height: clamp(1.2375rem, 1.1917rem + 0.2037vw, 1.375rem);
}
.green-icon {
  color: #16a34a;
  background: #f0fdf4;
}

.orange-icon {
  color: #ea580c;
  background: #fff7ed;
}

.purple-icon {
  color: #9333ea;
  background: #faf5ff;
}

.feature-box h3 {
  margin: clamp(0.77rem, 0.735rem + 0.1556vw, 0.875rem) 0
    clamp(0.55rem, 0.525rem + 0.1111vw, 0.625rem);
  font-size: var(--fs-16);
  font-weight: 700;
}

.feature-box p {
  margin: 0;
  font-size: var(--fs-12);
  line-height: 1.65;
  color: #64748b;
}

@media (max-width: 1024px) {
  .main-nav {
    display: none;
  }
  body.mobile-search-open {
    overflow: hidden;
  }

  .calendar-popover-grid .calendar-month-card:nth-child(2) {
    display: none;
  }

  .mobile-service-panel {
    display: block;
    margin: 0 0 16px;
    padding: 24px 18px;
    border-radius: 18px;
  }

  .mobile-service-grid {
    gap: 14px;
  }

  .mobile-service-tile {
    min-height: 82px;
    gap: 8px;
    padding: 12px 8px;
    border-radius: 14px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
  }

  .mobile-service-tile svg {
    width: 24px;
    height: 24px;
  }

  .mobile-service-tile span {
    font-size: 13px;
  }

  .search-panel {
    position: fixed;
    inset: 0;
    z-index: 80;
    margin: 0;
    border-radius: 0;
    border: 0;
    background: linear-gradient(180deg, #d7e5fb 0%, #cff1e9 100%);
    box-shadow: none;
    overflow-y: auto;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-100%);
    transition:
      transform 0.34s ease,
      opacity 0.24s ease,
      visibility 0.24s ease;
  }

  .search-panel.is-mobile-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  .hotel-index-search-panel {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: block;
    background: linear-gradient(180deg, #d7e5fb 0%, #cff1e9 100%);
    box-shadow: none;
    overflow-y: auto;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-100%);
    transition:
      transform 0.34s ease,
      opacity 0.24s ease,
      visibility 0.24s ease;
  }

  .hotel-index-search-panel.is-mobile-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  .hotel-index-search-panel .mobile-search-head {
    display: flex;
    position: sticky;
    top: 0;
    z-index: 3;
    padding: 18px 18px 14px;
    background: linear-gradient(
      180deg,
      rgba(215, 229, 251, 0.98) 0%,
      rgba(210, 240, 237, 0.96) 100%
    );
  }

  .hotel-index-search-body {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    padding: 30px 18px 28px;
  }

  .hotel-index-search-card {
    display: grid;
    gap: 0px;
    padding: 14px;
    border-radius: 16px;
  }

  .hotel-index-search-card .field-shell {
    min-height: 50px;
    border-radius: 12px;
  }

  .hotel-index-options,
  .hotel-index-calendar-popover {
    position: fixed;
    z-index: 120;
    display: none;
    width: min(360px, calc(100vw - 24px));
    max-height: min(520px, calc(100vh - 24px));
    overflow-y: auto;
    margin-top: 0;
    padding: 14px;
    border: 1px solid #dfe6ef;
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 14px 34px rgba(40, 60, 104, 0.12);
  }

  .hotel-index-options.is-open,
  .hotel-index-calendar-popover.is-open {
    display: grid;
  }

  .hotel-index-calendar-popover {
    width: min(420px, calc(100vw - 24px));
    max-width: none;
    transform: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .hotel-index-calendar-popover .calendar-popover-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .hotel-index-destination-panel,
  .hotel-index-guests-panel,
  .hotel-index-price-panel {
    gap: 10px;
  }

  .hotel-index-destination-panel .hotel-popup-search {
    display: flex;
    align-items: center;
    gap: 9px;
    height: 42px;
    padding: 0 12px;
    border: 1px solid #dfe6ef;
    border-radius: 9px;
    background: #f6f8fb;
  }

  .hotel-index-destination-panel .hotel-popup-search svg {
    width: 16px;
    height: 16px;
    color: #627085;
  }

  .hotel-index-destination-panel .hotel-popup-search input {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: #111827;
    font-size: 13px;
  }

  .hotel-index-destination-panel .hotel-destination-list {
    display: grid;
    gap: 6px;
  }

  .hotel-index-destination-panel .hotel-destination-list button {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 54px;
    padding: 0 10px;
    border-radius: 9px;
    color: #111827;
    background: transparent;
    text-align: left;
  }

  .hotel-index-destination-panel .hotel-destination-list button:hover {
    background: #eef5ff;
  }

  .hotel-index-destination-panel .hotel-destination-list svg {
    width: 17px;
    height: 17px;
    color: #1550cf;
  }

  .hotel-index-destination-panel .hotel-destination-list strong,
  .hotel-index-guests-panel .hotel-stepper-row strong {
    display: block;
    color: #111827;
    font-size: 13px;
    font-weight: 800;
  }

  .hotel-index-destination-panel .hotel-destination-list small,
  .hotel-index-guests-panel .hotel-stepper-row small {
    display: block;
    margin-top: 3px;
    color: #6d7688;
    font-size: 11px;
    font-weight: 600;
  }

  .hotel-index-guests-panel .hotel-stepper-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 12px 0;
  }

  .hotel-index-guests-panel .hotel-stepper-row + .hotel-stepper-row {
    border-top: 1px solid #edf1f5;
  }

  .hotel-index-guests-panel .hotel-stepper-row > div {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .hotel-index-guests-panel .hotel-stepper-row button {
    display: grid;
    place-items: center;
    width: 30px;
    height: 30px;
    border: 1px solid #d8e0ea;
    border-radius: 50%;
    color: #1550cf;
    background: #fff;
    font-size: 16px;
    font-weight: 800;
  }

  .hotel-index-guests-panel .hotel-stepper-row b {
    min-width: 18px;
    color: #111827;
    font-size: 14px;
    text-align: center;
  }

  .hotel-index-price-panel .filter-section {
    margin: 0;
  }

  .hotel-index-price-panel .filter-section-title {
    min-height: 20px;
    margin-bottom: 11px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: #172033;
    font-size: 14px;
    font-weight: 500;
  }

  .hotel-index-price-panel .filter-section-title strong {
    min-height: 22px;
    padding: 0 12px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    background: #e8eefc;
    color: #1248c8;
    font-size: 11px;
    font-weight: 800;
  }

  .hotel-index-price-panel .filter-range {
    width: 100%;
    accent-color: #1550cf;
  }

  .hotel-index-price-panel .filter-range-labels {
    display: flex;
    justify-content: space-between;
    color: #7b8494;
    font-size: 11px;
    font-weight: 700;
  }

  .hotel-index-search-btn {
    grid-column: 1 / -1;
    width: 100%;
    min-height: 56px;
    border-radius: 999px;
    color: #fff;
    background: linear-gradient(180deg, #1c5de2, #1550cf);
    font-size: 16px;
    font-weight: 800;
    box-shadow: 0 14px 24px rgba(12, 85, 216, 0.22);
  }

  .mobile-search-head {
    display: flex;
    position: sticky;
    top: 0;
    z-index: 3;
    padding: 18px 18px 14px;
    background: linear-gradient(
      180deg,
      rgba(215, 229, 251, 0.98) 0%,
      rgba(210, 240, 237, 0.96) 100%
    );
  }

  .mobile-trip-tabs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 30px 18px 20px;
    padding: 5px;
    border-radius: 999px;
    background: rgba(21, 80, 207, 0.08);
  }

  .trip-row {
    padding: 0 18px 8px;
    min-height: auto;
    border-bottom: 0;
    background: transparent;
    border-radius: 0;
  }

  .responsive-group-booking-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0;
    background: transparent;
    color: #1550cf;
    font-size: 13px;
    font-weight: 700;
  }

  .responsive-group-booking-btn svg {
    width: 14px;
    height: 14px;
  }

  .trip-type {
    display: none;
  }

  .currency-pill {
    margin-left: auto;
    padding: 0;
    border: 0;
    background: transparent;
    color: #1550cf;
    font-size: 13px;
    font-weight: 700;
  }

  .trip-type-menu {
    top: 106px;
    left: 18px;
    right: 18px;
    width: auto;
    border-radius: 14px;
  }

  .search-panel.trip-one-way .search-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .multi-city-panel {
    padding: 0 18px 22px;
  }

  .multi-city-sheet {
    padding: 2px 0 0;
  }

  .multi-city-sheet h2 {
    margin-bottom: 12px;
    font-size: 18px;
  }

  .multi-city-row {
    position: relative;
    grid-template-columns: 1fr;
    gap: 0;
    margin-bottom: 14px;
    padding: 14px 14px 10px;
    border-bottom: 0;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 10px 28px rgba(70, 98, 150, 0.1);
  }

  .multi-city-row-compact {
    grid-template-columns: 1fr;
  }

  .multi-city-cell {
    padding: 0 0 12px;
    border-right: 0;
    border-bottom: 0;
  }

  .multi-city-badge {
    position: static;
    width: fit-content;
    margin: 0 0 12px;
  }

  .multi-city-flight,
  .multi-city-date {
    min-height: 52px;
    padding: 0 12px;
    border-radius: 10px;
    background: #ffffff;
    border: 1px solid #f1f5f9;
  }

  .multi-city-flight strong,
  .multi-city-date strong {
    font-size: 14px;
  }

  .multi-city-flight small,
  .multi-city-date small {
    font-size: 10px;
  }

  .multi-city-swap {
    display: none;
  }

  .multi-city-delete {
    position: absolute;
    top: 14px;
    right: 12px;
    width: 28px;
    height: 28px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: #fff5f5;
  }

  .multi-city-add {
    margin-top: 6px;
  }

  .multi-city-actions {
    margin-top: 6px;
  }

  .group-booking-dialog {
    width: min(100%, 920px);
  }

  .group-contact-grid,
  .group-preferences-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .group-booking-layout {
    grid-template-columns: 1fr;
  }

  .group-passengers-card {
    max-width: 360px;
  }

  .group-booking-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .group-booking-actions {
    justify-content: flex-end;
  }

  .page-shell {
    width: 100%;
    margin: 0;
  }

  .narrow {
    width: min(
      100% - clamp(1.76rem, 1.68rem + 0.3556vw, 2rem),
      clamp(36.075rem, 31.85rem + 18.7778vw, 48.75rem)
    );
  }

  .topbar {
    flex-wrap: wrap;
  }

  .search-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    padding: 0 18px 24px;
  }

  .standard-route-swap {
    display: none;
  }

  .search-card,
  .search-card.feature-card,
  .search-card.passenger-card {
    min-height: auto;
    padding: 0;
    border: 0;
    background: transparent;
  }

  .flight-search-foot {
    justify-content: space-between;
    gap: 12px;
    padding: 0 18px 24px;
    margin-top: -10px;
    background-color: transparent;
  }

  .search-panel {
    border-radius: 14px;
  }

  .advanced-filters-popover {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    width: 100%;
    max-width: none;
    margin: -2px 0 10px;
    padding: 16px 14px 18px;
    border-radius: 14px;
    box-shadow: 0 14px 34px rgba(40, 60, 104, 0.12);
    transform: none;
  }

  .calendar-popover {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    width: 100%;
    max-width: none;
    margin: -2px 0 10px;
    padding: 12px;
    border-radius: 14px;
    box-shadow: 0 14px 34px rgba(40, 60, 104, 0.12);
    transform: none;
  }

  .airport-popover {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    width: 100%;
    max-width: none;
    margin: -2px 0 10px;
    border-radius: 14px;
    box-shadow: 0 14px 34px rgba(40, 60, 104, 0.12);
    transform: none;
  }

  .passenger-popover {
    position: relative;
    top: auto;
    left: auto !important;
    right: auto !important;
    width: 100% !important;
    max-width: none;
    margin: -2px 0 10px;
    border-radius: 14px;
    box-shadow: 0 14px 34px rgba(40, 60, 104, 0.12);
    transform: none;
  }

  .airport-popover,
  .calendar-popover,
  .advanced-filters-popover,
  .passenger-popover {
    grid-column: 1 / -1;
    display: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .airport-popover.is-open,
  .calendar-popover.is-open,
  .advanced-filters-popover.is-open,
  .passenger-popover.is-open {
    display: block;
  }

  .calendar-popover-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .advanced-filters-layout,
  .advanced-filters-main {
    grid-template-columns: 1fr;
  }

  .advanced-filters-layout-new {
    grid-template-columns: 1fr;
  }

  .advanced-filters-main {
    grid-template-areas:
      "airlines"
      "stops"
      "baggage"
      "class";
    row-gap: 18px;
  }

  .advanced-filters-layout-new .advanced-filters-main {
    grid-template-columns: 1fr;
    grid-template-areas:
      "airlines"
      "stops"
      "baggage"
      "departure"
      "number";
  }

  .advanced-sidebar {
    display: grid;
    gap: 16px;
  }

  .advanced-filter-refund {
    margin-bottom: 0;
  }

  .advanced-filter-group {
    padding: 16px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 8px 24px rgba(70, 98, 150, 0.08);
  }

  .advanced-travellers-card {
    padding: 16px;
  }

  .advanced-chip-row {
    flex-wrap: wrap;
  }

  .advanced-chip {
    flex: 1 1 120px;
    min-width: 0;
    text-align: center;
  }

  .advanced-input {
    min-height: 42px;
    font-size: 12px;
  }

  .advanced-filter-number .advanced-input {
    max-width: none;
  }

  .traveller-row {
    grid-template-columns: 38px minmax(0, 1fr) 30px 22px 30px;
    gap: 10px;
  }

  .mini-chip-grid,
  .fare-chip-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .advanced-travellers-card {
    order: -1;
  }

  .trip-row {
    gap: 12px;
  }

  .search-card {
    min-height: auto;
  }

  .search-btn {
    width: 100%;
    max-width: none;
    height: 44px;
    margin: 4px 0 0;
    justify-self: stretch;
    border-radius: 999px;
    font-size: 16px;
  }

  .field-label {
    margin-bottom: 7px;
    font-size: 10px;
    color: #576274;
  }

  .field-shell {
    min-height: 52px;
    padding: 0 12px;
    border-radius: 8px;
    background: #ffffff;
  }

  .field-main strong {
    font-size: 14px;
    white-space: nowrap;
  }

  .field-main small {
    font-size: 10px;
    white-space: nowrap;
    width: fit-content;
  }

  .promo-chip {
    min-height: 18px;
    padding-inline: 8px;
    font-size: 10px;
  }

  .deals-track {
    grid-template-columns: 1fr;
  }

  .features-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .destinations-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .group-booking-card {
    min-height: auto;
    padding: clamp(1.615rem, 1.445rem + 0.7556vw, 2.125rem)
      clamp(1.23rem, 1.14rem + 0.4vw, 1.5rem);
    background-size: cover;
    background-position: center;
  }

  .group-booking-avatars {
    top: auto;
    right: 24px;
    bottom: 28px;
  }

  .app-booking-layout {
    grid-template-columns: 1fr;
  }

  .app-booking-layout > div:first-child {
    display: flex;
    justify-content: center;
  }

  .app-booking-layout > div:first-child img {
    width: min(100%, clamp(29.6rem, 26.1333rem + 15.4074vw, 40rem));
  }

  .app-booking-copy h2 {
    max-width: none;
  }

  .app-booking-copy p,
  .app-stats {
    max-width: none;
  }

  .footer-top {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer-middle {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer-bottom {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 640px) {
  .hero {
    padding-bottom: 32px;
    background-size: cover;
    background-position: center top;
  }

  .destinations-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .hero-overlay {
    background: linear-gradient(
      180deg,
      rgba(10, 12, 17, 0.3) 0%,
      rgba(10, 12, 17, 0.16) 38%,
      rgba(10, 12, 17, 0.05) 100%
    );
  }

  .container {
    width: min(100% - 24px, 100%);
  }

  .topbar {
    justify-content: space-between;
    gap: 10px;
    padding: 20px 0 8px;
    flex-wrap: nowrap;
    position: relative;
  }

  .nav-toggle-btn {
    position: absolute;
    left: 0;
    top: 22px;
    width: 28px;
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding: 0;
    background: transparent;
  }

  .nav-toggle-btn span {
    height: 3px;
    border-radius: 999px;
    background: #ffffff;
  }

  .nav-toggle-btn span:nth-child(1) {
    width: 22px;
  }

  .nav-toggle-btn span:nth-child(2) {
    width: 16px;
  }

  .nav-toggle-btn span:nth-child(3) {
    width: 10px;
  }

  .top-actions {
    gap: 14px;
    flex-wrap: nowrap;
    position: relative;
    z-index: 4;
  }

  .top-actions a {
    display: none;
  }

  .wallet {
    gap: 8px;
    font-size: 17px;
    font-weight: 500;
  }

  .wallet .avatar {
    width: 20px;
    height: 20px;
  }

  .currency {
    gap: 8px;
    font-size: 17px;
    font-weight: 700;
  }

  .currency .flag {
    width: 20px;
    height: 20px;
  }

  .menu-btn {
    gap: 4px;
    align-items: center;
    margin-left: 2px;
  }

  .menu-btn span {
    width: 4px;
    height: 4px;
    border-radius: 50%;
  }

  .header-menu-popover {
    top: calc(100% + 10px);
    right: 0;
    min-width: 156px;
  }

  .hero-content {
    margin-top: 94px;
    padding-top: 0;
  }

  .hero-content h1 {
    margin: 0 auto 26px;
  }

  .mobile-service-panel {
    display: block;
    margin: 0 0 14px;
    padding: 24px 18px;
    border-radius: 18px;
  }

  .mobile-service-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
  }

  .mobile-service-tile {
    min-height: 78px;
    gap: 8px;
    padding: 12px 8px;
    border-radius: 12px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
  }

  .mobile-service-tile svg {
    width: 24px;
    height: 24px;
  }

  .mobile-service-tile span {
    font-size: 13px;
  }

  .search-panel {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 80;
    margin: 0;
    border-radius: 0;
    border: 0;
    background: linear-gradient(180deg, #d7e5fb 0%, #cff1e9 100%);
    box-shadow: none;
    overflow-y: auto;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-100%);
    transition:
      transform 0.34s ease,
      opacity 0.24s ease,
      visibility 0.24s ease;
  }

  .search-panel.is-mobile-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  .mobile-search-head {
    display: flex;
    position: sticky;
    top: 0;
    z-index: 3;
    padding: 18px 18px 14px;
    background: linear-gradient(
      180deg,
      rgba(215, 229, 251, 0.98) 0%,
      rgba(210, 240, 237, 0.96) 100%
    );
  }

  .mobile-search-back,
  .mobile-search-dismiss {
    width: 30px;
    height: 30px;
  }

  .mobile-trip-tabs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 0 18px 20px;
    padding: 5px;
    border-radius: 999px;
    background: rgba(21, 80, 207, 0.08);
  }

  .mobile-trip-tab {
    padding: 0 8px;
  }

  .trip-row {
    padding: 0 18px 8px;
    min-height: auto;
    border-bottom: 0;
    background: transparent;
    border-radius: 0;
  }

  .trip-type {
    display: none;
  }

  .currency-pill {
    margin-left: auto;
    padding: 0;
    border: 0;
    background: transparent;
    color: #1550cf;
    font-size: 13px;
    font-weight: 700;
  }

  .trip-type-menu {
    top: 106px;
    left: 18px;
    right: 18px;
    width: auto;
    border-radius: 14px;
  }

  .search-grid,
  .search-panel.trip-one-way .search-grid,
  .features-grid {
    grid-template-columns: 1fr;
  }

  .search-grid {
    gap: 12px;
    padding: 0 18px 24px;
  }

  .search-card,
  .search-card.feature-card,
  .search-card.passenger-card {
    min-height: auto;
    padding: 0;
    border: 0;
    background: transparent;
  }

  .flight-search-foot {
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 12px;
    padding: 0 18px 24px;
    margin-top: -10px;
  }

  .field-label {
    margin-bottom: 7px;
    font-size: 10px;
    color: #576274;
  }

  .field-shell {
    min-height: 52px;
    padding: 0 12px;
    border-radius: 8px;
    background: #ffffff;
  }

  .field-main strong {
    font-size: 14px;
    white-space: nowrap;
  }

  .field-main small {
    font-size: 10px;
    white-space: nowrap;
    width: fit-content;
  }

  .promo-chip {
    min-height: 18px;
    padding-inline: 8px;
    font-size: 10px;
  }

  .airport-popover,
  .calendar-popover,
  .advanced-filters-popover {
    position: static;
    width: 100%;
    max-width: none;
    margin: -2px 0 10px;
    border-radius: 14px;
    box-shadow: 0 14px 34px rgba(40, 60, 104, 0.12);
    transform: none;
  }

  .airport-popover,
  .calendar-popover,
  .advanced-filters-popover,
  .passenger-popover {
    display: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .airport-popover.is-open,
  .calendar-popover.is-open,
  .advanced-filters-popover.is-open,
  .passenger-popover.is-open {
    display: block;
  }

  .calendar-popover {
    padding: 12px;
  }

  .calendar-popover-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .calendar-popover-grid .calendar-month-card:nth-child(2) {
    display: none;
  }

  .calendar-month-card {
    padding: 14px 12px 12px;
  }

  .advanced-filters-popover {
    padding: 16px 14px 18px;
  }

  .airport-popover {
    padding: 0;
  }

  .passenger-popover {
    position: relative;
    top: auto;
    left: auto !important;
    right: auto !important;
    width: 100% !important;
    max-width: none;
    margin: -2px 0 10px;
    border-radius: 14px;
    transform: none;
  }

  .multi-city-panel {
    padding: 0 18px 22px;
  }

  .multi-city-sheet {
    padding: 2px 0 0;
  }

  .multi-city-sheet h2 {
    margin-bottom: 12px;
    font-size: 18px;
  }

  .multi-city-row {
    margin-bottom: 12px;
    padding: 14px 12px 10px;
  }

  .multi-city-row-compact {
    grid-template-columns: 1fr;
  }

  .multi-city-cell {
    padding: 0 0 12px;
  }

  .multi-city-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .multi-city-toolbar-btn,
  .multi-city-add {
    justify-content: center;
  }

  .multi-city-flight,
  .multi-city-date {
    min-height: 52px;
    padding: 0 12px;
    border-radius: 8px;
    background: #ffffff;
    border: 1px solid #f1f5f9;
  }

  .multi-city-flight strong,
  .multi-city-date strong {
    font-size: 14px;
  }

  .multi-city-flight small,
  .multi-city-date small {
    font-size: 10px;
  }

  .multi-city-add {
    margin-top: 6px;
  }

  .multi-city-delete {
    top: 12px;
    right: 10px;
    width: 26px;
    height: 26px;
  }

  .multi-city-search-btn,
  .search-btn {
    width: 100%;
    max-width: none;
    height: 44px;
    margin: 4px 0 0;
    border-radius: 999px;
    font-size: 16px;
  }

  .trip-row {
    gap: 12px;
  }

  .trip-type-menu {
    top: 76px;
    left: 18px;
    width: calc(100% - 36px);
  }

  .group-booking-modal {
    padding: 10px;
  }

  .group-booking-dialog {
    max-height: calc(80vh - 20px);
    border-radius: 24px;
  }

  .group-booking-sheet {
    padding: 18px 14px 16px;
  }

  .group-booking-panel,
  .group-passengers-card {
    padding: 18px 16px;
  }

  .group-contact-grid,
  .group-trip-grid,
  .group-preferences-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .group-segment-switch {
    width: 100%;
  }

  .group-passengers-card {
    max-width: none;
  }

  .group-multi-city-row {
    grid-template-columns: 1fr;
  }

  .checkbox-row,
  .group-booking-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .footer-btn {
    width: 100%;
  }

  .trip-row {
    flex-wrap: wrap;
  }

  .airport-current-location {
    padding: 14px;
  }

  .airport-results-block {
    padding: 14px 6px 12px;
  }

  .airport-panel-section {
    padding: 16px 14px 0;
  }

  .airport-destination-grid {
    grid-template-columns: 1fr;
  }

  .airport-result-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .calendar-month-head h3 {
    font-size: 15px;
  }

  .calendar-days {
    gap: 7px;
  }

  .calendar-day span {
    font-size: 12px;
  }

  .calendar-day.selected {
    width: auto;
    min-height: 45px;
  }

  .advanced-filters-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .advanced-switch-row {
    width: 100%;
  }

  .advanced-filters-popover {
    padding: 14px 12px 16px;
  }

  .advanced-filters-layout {
    gap: 14px;
  }

  .advanced-filters-layout-new {
    grid-template-columns: 1fr;
  }

  .advanced-filters-main {
    row-gap: 14px;
  }

  .advanced-filters-layout-new .advanced-filters-main {
    grid-template-columns: 1fr;
    grid-template-areas:
      "airlines"
      "stops"
      "baggage"
      "departure"
      "number";
  }

  .advanced-filter-group,
  .advanced-travellers-card {
    padding: 14px 12px;
    border-radius: 12px;
  }

  .advanced-group-label,
  .advanced-sub-label {
    margin-bottom: 12px;
    line-height: 1.4;
  }

  .advanced-input {
    min-height: 44px;
    padding: 10px 12px;
  }

  .advanced-chip-row,
  .mini-chip-grid,
  .fare-chip-grid {
    grid-template-columns: 1fr;
  }

  .advanced-chip-row {
    flex-wrap: wrap;
  }

  .advanced-chip {
    width: 100%;
    flex: 1 1 100%;
  }

  .advanced-selected-airlines {
    gap: 8px;
    margin-top: 14px;
  }

  .advanced-airline-pill {
    min-width: 0;
    max-width: 100%;
  }

  .advanced-time-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .advanced-time-card {
    min-width: 0;
    padding: 12px 8px;
  }

  .advanced-time-card strong {
    font-size: 13px;
  }

  .advanced-filter-number .advanced-input {
    max-width: none;
  }

  .advanced-slider-head {
    gap: 10px;
    align-items: flex-start;
    flex-direction: column;
  }

  .traveller-row {
    grid-template-columns: 32px minmax(0, 1fr) 28px 20px 28px;
    gap: 8px;
  }

  .traveller-copy strong {
    font-size: 13px;
  }

  .traveller-copy span {
    font-size: 9px;
  }

  .group-booking-card {
    min-height: 0;
    padding: clamp(1.1275rem, 1.045rem + 0.3667vw, 1.375rem)
      clamp(0.88rem, 0.84rem + 0.1778vw, 1rem)
      clamp(3.96rem, 3.4467rem + 2.2815vw, 5.5rem);
    border-radius: 18px;
    background-size: cover;
    background-position: 72% center;
  }

  .group-booking-avatars {
    right: 12px;
    bottom: 14px;
    transform: scale(0.72);
    transform-origin: right center;
  }

  .app-booking-layout > div:first-child img {
    width: 100%;
  }

  .app-stats {
    grid-template-columns: 1fr 1fr;
  }

  .site-footer {
    padding: 30px 0 28px;
    border-top: 1px solid #e4e6ea;
    margin-top: 40px;
  }

  .footer-container {
    width: min(100% - 40px, 100%);
  }

  .footer-mobile-accordion {
    display: block;
  }

  .footer-top,
  .footer-middle {
    display: none;
  }

  .footer-bottom {
    align-items: center;
    gap: 0;
    padding-top: 39px;
    border-top: 0;
    text-align: center;
  }

  .footer-meta {
    width: 100%;
  }

  .footer-social-text {
    justify-content: center;
    gap: 34px;
  }

  .footer-social-text a {
    font-size: 21px;
    font-weight: 400;
    letter-spacing: 0;
  }

  .footer-meta p {
    margin-top: 20px;
    font-size: 13px;
    line-height: 1.35;
    color: #161616;
  }

  .footer-social-icons {
    justify-content: center;
    gap: 20px;
    margin-top: 21px;
  }

  .footer-social-icons a {
    width: 32px;
    height: 32px;
  }

  .footer-legal {
    display: block;
    margin-top: 33px;
    padding-top: 18px;
  }

  .footer-legal p {
    font-size: 13px;
    line-height: 1.35;
    color: #8e9097;
  }

  .footer-accordion-item {
    border-bottom: 1px solid #e4e6ea;
  }

  .footer-accordion-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 15px 0 14px;
    border: 0;
    background: transparent;
    color: #191c22;
    text-align: left;
  }

  .footer-accordion-toggle span {
    font-family: "Poppins", sans-serif;
    font-size: 17px;
    line-height: 1.35;
    font-weight: 400;
  }

  .footer-accordion-toggle::after {
    content: "";
    width: 8px;
    height: 8px;
    margin-right: 2px;
    border-right: 2px solid #4a4f58;
    border-bottom: 2px solid #4a4f58;
    transform: rotate(45deg) translateY(-1px);
    transition: transform 0.2s ease;
    flex-shrink: 0;
  }

  .footer-accordion-toggle[aria-expanded="true"]::after {
    transform: rotate(-135deg) translateY(-1px);
  }

  .footer-accordion-panel {
    padding: 0 0 14px;
  }

  .footer-accordion-panel a {
    display: block;
    margin-bottom: 10px;
    font-size: 14px;
    line-height: 1.4;
    color: #777777;
  }

  .footer-accordion-panel a:last-child {
    margin-bottom: 0;
  }
}

@media (max-width: 1024px) {
  .hotel-index-search-panel .hotel-index-options,
  .hotel-index-search-panel .hotel-index-calendar-popover {
    position: fixed;
    z-index: 120;
    display: none;
    margin: 0;
  }

  .hotel-index-search-panel .hotel-index-options.is-open,
  .hotel-index-search-panel .hotel-index-calendar-popover.is-open {
    display: grid;
  }

  .hotel-index-search-panel .hotel-index-calendar-popover {
    width: min(420px, calc(100vw - 24px));
    max-width: none;
    transform: none;
  }
}

@media (max-width: 500px) {
  .hotel-index-search-body {
    grid-template-columns: 1fr;
  }

  .hotel-index-search-panel .hotel-index-options,
  .hotel-index-search-panel .hotel-index-calendar-popover {
    width: calc(100vw - 24px);
  }
}
body.site-mobile-drawer-open {
  overflow: hidden;
}

body.regional-modal-open {
  overflow: hidden;
}

.results-actions,
.hotel-results-actions {
  position: relative;
}

.site-profile-menu {
  position: absolute;
  top: calc(100% + 16px);
  right: 0;
  z-index: 2300;
  width: min(360px, calc(100vw - 28px));
  overflow: hidden;
  border: 1px solid #c3c6d74d;
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 24px 56px rgba(15, 23, 42, 0.18);
  color: #111827;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition:
    opacity 0.2s ease,
    visibility 0.2s ease,
    transform 0.2s ease;
}

.site-profile-menu.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.site-profile-menu *,
.site-mobile-drawer .site-profile-card * {
  box-sizing: border-box;
}

.site-profile-menu a,
.site-mobile-drawer .site-profile-card a {
  color: inherit;
  text-decoration: none;
}

.site-profile-menu button,
.site-mobile-drawer .site-profile-card button {
  font: inherit;
}

.site-profile-menu .site-profile-card,
.site-mobile-drawer .site-profile-card {
  display: grid;
  background: #ffffff;
  color: #111827;
  font-family: "Inter", sans-serif;
}

.site-profile-menu .site-profile-head,
.site-mobile-drawer .site-profile-head {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px;
  border-bottom: 1px solid #edf1f6;
}

.site-profile-menu .site-profile-avatar,
.site-mobile-drawer .site-profile-avatar {
  position: relative;
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  border-radius: 50%;
  background: #0b57d0;
  color: #ffffff;
  font-size: 24px;
  font-weight: 800;
}

.site-profile-menu .site-profile-avatar i,
.site-mobile-drawer .site-profile-avatar i {
  position: absolute;
  right: 1px;
  bottom: 2px;
  width: 16px;
  height: 16px;
  border: 3px solid #ffffff;
  border-radius: 50%;
  background: #21c45d;
}

.site-profile-menu .site-profile-head strong,
.site-profile-menu .site-profile-section a strong,
.site-profile-menu .site-profile-logout strong,
.site-mobile-drawer .site-profile-head strong,
.site-mobile-drawer .site-profile-section a strong,
.site-mobile-drawer .site-profile-logout strong {
  display: block;
  color: #191c1e;
  font-size: 16px;
  line-height: 1.2;
  font-weight: 700;
}

.site-profile-menu .site-profile-head small,
.site-profile-menu .site-profile-section a small,
.site-profile-menu .site-profile-logout small,
.site-mobile-drawer .site-profile-head small,
.site-mobile-drawer .site-profile-section a small,
.site-mobile-drawer .site-profile-logout small {
  display: block;
  margin-top: 4px;
  color: #737686;
  font-size: 12px;
  line-height: 1.25;
  font-weight: 600;
}

.site-profile-menu .site-profile-section,
.site-mobile-drawer .site-profile-section {
  display: grid;
  gap: 14px;
  padding: 20px;
}

.site-profile-menu .site-profile-section + .site-profile-section,
.site-mobile-drawer .site-profile-section + .site-profile-section {
  padding-top: 18px;
}

.site-profile-menu .site-profile-section > b,
.site-mobile-drawer .site-profile-section > b {
  display: block;
  color: #7b8192;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.site-profile-menu .site-profile-section a,
.site-profile-menu .site-profile-logout,
.site-mobile-drawer .site-profile-section a,
.site-mobile-drawer .site-profile-logout {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 18px;
  min-height: 70px;
  width: 100%;
  padding: 8px 0;
  border: 0;
  background: transparent;
  color: #111827;
  font-family: "Inter", sans-serif;
  text-align: left;
}

.site-profile-menu .site-profile-section a > svg:first-child,
.site-profile-menu .site-profile-logout > svg,
.site-mobile-drawer .site-profile-section a > svg:first-child,
.site-mobile-drawer .site-profile-logout > svg {
  display: block;
  flex: none;
  width: 46px;
  height: 46px;
  padding: 13px;
  border-radius: 9px;
  color: #0957d5;
  background: #edf6ff;
}

.site-profile-menu .site-profile-section a:nth-of-type(2) > svg:first-child,
.site-mobile-drawer .site-profile-section a:nth-of-type(2) > svg:first-child {
  color: #a328ff;
  background: #fbf1ff;
}

.site-profile-menu .site-profile-section:last-of-type a > svg:first-child,
.site-mobile-drawer .site-profile-section:last-of-type a > svg:first-child {
  color: #08a899;
  background: #e9fffb;
}

.site-profile-menu .site-profile-section a > svg:last-child,
.site-mobile-drawer .site-profile-section a > svg:last-child {
  display: block;
  flex: none;
  width: 18px;
  height: 18px;
  color: #b6bdca;
}

.site-profile-menu .site-profile-logout,
.site-mobile-drawer .site-profile-logout {
  grid-template-columns: 46px minmax(0, 1fr);
  padding: 24px 32px 28px;
  border-top: 1px solid #edf1f6;
  background: #f8fafc;
  cursor: pointer;
}

.site-profile-menu .site-profile-logout > svg,
.site-mobile-drawer .site-profile-logout > svg {
  color: #d11a1a;
  background: #fff0f0;
}

.site-profile-menu .site-profile-logout strong,
.site-mobile-drawer .site-profile-logout strong {
  color: #c40f0f;
}

.site-wallet-dropdown {
  position: absolute;
  top: calc(100% + 18px);
  right: 42px;
  z-index: 2200;
  width: 256px;
  padding: 20px;
  border: 1px solid #eef1f6;
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 22px 56px rgba(15, 23, 42, 0.18);
}

.site-wallet-dropdown[hidden] {
  display: none;
}

.site-wallet-dropdown div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  color: #000000;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.1;
  white-space: nowrap;
  padding: 12px;
}

.site-wallet-dropdown div + div {
  border-top: 1px solid #e6e8ed;
}

.site-wallet-dropdown span {
  font-weight: 500;
}

.site-wallet-dropdown strong {
  color: #0055d6;
  font-weight: 500;
}

.regional-modal {
  position: fixed;
  inset: 0;
  z-index: 3200;
  display: grid;
  place-items: center;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.2s ease,
    visibility 0.2s ease;
}

.regional-modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.regional-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.42);
}

.regional-modal-dialog {
  position: relative;
  width: min(574px, calc(100vw - 24px));
  max-height: calc(100vh - 28px);
  overflow-y: auto;
  padding: 30px;
  border-radius: 20px;
  background: #ffffff;
  box-shadow: 0 28px 70px rgba(15, 23, 42, 0.22);
}

.regional-modal-head {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) 40px;
  align-items: start;
  gap: 18px;
  margin-bottom: 28px;
}

.regional-modal-head > span,
.regional-modal-head > button {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #edf6ff;
  color: #1263e6;
}

.regional-modal-head > button {
  width: 40px;
  height: 40px;
  background: #f1f3f5;
  color: #4b5563;
}

.regional-modal-head svg {
  width: 20px;
  height: 20px;
}

.regional-modal-head h2 {
  margin: 0;
  color: #1a1d1f;
  font-size: 24px;
  line-height: 1.2;
  font-weight: 600;
}

.regional-modal-head p {
  margin: 14px 0 0;
  color: #6b7280;
  font-size: 14px;
  line-height: 1.4;
}

.regional-fields {
  display: grid;
  gap: 22px;
  padding-bottom: 30px;
  border-bottom: 1px solid #e7ebf2;
}

.regional-fields label {
  display: grid;
  gap: 9px;
}

.regional-fields strong {
  color: #1a1d1f;
  font-size: 14px;
  font-weight: 600;
}

.regional-fields small {
  color: #98a2b3;
  font-size: 12px;
}

.regional-fields button {
  min-height: 58px;
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 0 16px;
  border: 1px solid #dfe5ee;
  border-radius: 10px;
  background: #ffffff;
  color: #171b25;
  font-size: 16px;
  font-weight: 600;
  text-align: left;
}

.regional-fields button span {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: #d9faec;
  color: #129c64;
}

.regional-fields label:first-child button span {
  background: linear-gradient(
    180deg,
    #ff9933 0 33%,
    #ffffff 33% 66%,
    #128807 66% 100%
  );
  border: 1px solid #dfe5ee;
}

.regional-fields label:last-child button span {
  background: #efe7ff;
  color: #7c3aed;
}

.regional-fields button > svg:last-child {
  margin-left: auto;
  width: 18px;
  height: 18px;
  color: #667085;
}

.regional-apply {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 16px 20px;
  margin-top: 30px;
  border-radius: 32px;
  background: #0755d8;
  color: #ffffff;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  box-shadow: 0 12px 22px rgba(7, 85, 216, 0.22);
}

.regional-apply svg {
  width: 17px;
  height: 17px;
}

@media (max-width: 640px) {
  .site-wallet-dropdown {
    left: 12px;
    right: 12px;
    width: auto;
    padding: 16px 20px;
  }

  .site-wallet-dropdown div {
    min-height: 58px;
    font-size: 22px;
  }
}

@media (max-width: 1024px) {
  .site-wallet-dropdown {
    position: fixed;
    top: auto;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 3300;
    width: 100%;
    padding: 18px 20px max(20px, env(safe-area-inset-bottom));
    border: 0;
    border-radius: 22px 22px 0 0;
    box-shadow: 0 -18px 48px rgba(15, 23, 42, 0.22);
  }

  .site-wallet-dropdown div {
    min-height: 54px;
    padding: 10px 4px;
    font-size: 16px;
  }

  .regional-modal {
    align-items: end;
    justify-items: stretch;
    padding: 0;
  }

  .regional-modal-backdrop {
    background: rgba(15, 23, 42, 0.44);
  }

  .regional-modal-dialog {
    width: 100%;
    max-height: calc(100vh - 42px);
    padding: 24px 20px 22px;
    border-radius: 22px 22px 0 0;
    box-shadow: 0 -18px 48px rgba(15, 23, 42, 0.22);
    transform: translateY(102%);
    transition: transform 0.26s ease;
  }

  .regional-modal.is-open .regional-modal-dialog {
    transform: translateY(0);
  }

  .regional-modal-head {
    grid-template-columns: 42px minmax(0, 1fr) 38px;
    gap: 14px;
    margin-bottom: 22px;
  }

  .regional-modal-head > span {
    width: 42px;
    height: 42px;
  }

  .regional-modal-head > button {
    width: 38px;
    height: 38px;
  }

  .regional-modal-head h2 {
    font-size: 21px;
  }

  .regional-modal-head p {
    margin-top: 10px;
    font-size: 13px;
  }

  .regional-fields {
    gap: 18px;
    padding-bottom: 22px;
  }

  .regional-fields button {
    min-height: 56px;
    font-size: 15px;
  }

  .regional-apply {
    margin-top: 22px;
    border-radius: 18px;
  }
}

.site-mobile-drawer {
  position: fixed;
  inset: 0;
  z-index: 2500;
  display: none;
  pointer-events: none;
  visibility: hidden;
}

.site-mobile-drawer.is-open {
  pointer-events: auto;
  visibility: visible;
}

.site-mobile-drawer-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(15, 23, 42, 0.34);
  opacity: 0;
  transition: opacity 0.22s ease;
}

.site-mobile-drawer.is-open .site-mobile-drawer-backdrop {
  opacity: 1;
}

.site-mobile-drawer-panel {
  position: absolute;
  top: 0;
  right: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  width: min(86vw, 340px);
  height: 100%;
  padding: 18px;
  background: #ffffff;
  box-shadow: -24px 0 48px rgba(15, 23, 42, 0.18);
  transform: translateX(104%);
  transition: transform 0.24s ease;
}

.site-mobile-drawer-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 2;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #f1f3f5;
  color: #4b5563;
}

.site-mobile-drawer-close svg {
  width: 18px;
  height: 18px;
}

.site-mobile-drawer.is-open .site-mobile-drawer-panel {
  transform: translateX(0);
}

.site-mobile-drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid #edf1f7;
}

.site-mobile-drawer-head strong {
  font-family: "Poppins", sans-serif;
  font-size: 24px;
  font-weight: 800;
  color: #111827;
}

.site-mobile-drawer-head button {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid #dfe6f1;
  border-radius: 12px;
  background: #f8fafc;
  color: #172033;
}

.site-mobile-drawer-head svg {
  width: 18px;
  height: 18px;
}

.site-mobile-drawer-links {
  display: grid;
  align-content: start;
  gap: 8px;
  overflow-y: auto;
  padding: 18px 0;
  margin-top: 30px;
}

.site-mobile-drawer-links a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 48px;
  padding: 0 14px;
  border-radius: 14px;
  color: #263244;
  background: #f7f9fc;
  font-size: 14px;
  font-weight: 700;
}

.site-mobile-drawer-links a.is-active {
  color: #ffffff;
  background: #1454d4;
}

.site-mobile-drawer-links svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.site-mobile-drawer-panel {
  display: flex;
  flex-direction: column;
}

.site-mobile-drawer-links {
  flex: 1;
}

.site-mobile-drawer-logout {
  margin-top: auto;
  width: 100%;
  padding: 10px 20px !important;
}
@media (max-width: 1024px) {
  .site-profile-menu {
    display: none;
  }

  .site-mobile-drawer {
    display: block;
  }
}

.results-mobile-topbar {
  display: none;
}

@media (max-width: 1024px) {
  .results-mobile-topbar {
    min-height: 48px;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
    padding: 11px 12px;
    border-radius: 4px;
    background: #f1f2f4;
  }

  .results-back-link {
    width: 20px;
    height: 20px;
    display: inline-grid;
    place-items: center;
    color: #50596b;
    flex-shrink: 0;
  }

  .results-back-link svg {
    width: 17px;
    height: 17px;
  }

  .results-mobile-copy {
    display: grid;
    min-width: 0;
    gap: 2px;
  }

  .results-mobile-copy strong {
    overflow: hidden;
    color: #21252d;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .results-mobile-copy span {
    overflow: hidden;
    color: #8c94a1;
    font-size: 10px;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}

/* Shared flight search result variant */

.search-panel-results {
  margin: 0;
}

.search-panel-results .airport-popover,
.search-panel-results .calendar-popover,
.search-panel-results .advanced-filters-popover {
  z-index: 1600;
}

/* Shared hotel search panel */
.hotel-search-panel {
  position: relative;
  z-index: 5;
  overflow: visible;
  border: 1px solid #e0e5ed;
  border-radius: 10px;
  background: #fff;
  box-shadow: var(--hotel-shadow);
}

.hotel-search-topline {
  display: flex;
  align-items: center;
  justify-content: end;
  min-height: 42px;
  padding: 0 14px 0 31px;
  background: #eeeeef;
}

.hotel-trip-toggle,
.hotel-currency-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  color: #1f2734;
  font-size: 12px;
  font-weight: 700;
}

.hotel-trip-toggle svg,
.hotel-currency-pill svg {
  width: 13px;
  height: 13px;
}

.hotel-currency-pill {
  min-height: 29px;
  padding: 0 13px;
  border-radius: 7px;
  color: #0957d5;
  background: #fff;
}

.hotel-search-grid {
  display: grid;
  grid-template-columns: 1.28fr 1.11fr 1.11fr 1.15fr 1.25fr 166px;
  align-items: stretch;
}

.hotel-search-field {
  display: grid;
  gap: 7px;
  padding: 16px clamp(0.625rem, -2.0568rem + 3.6364vw, 1.125rem);
  border-right: 1px solid #edf1f5;
}

.hotel-search-field span {
  color: #434655;
  font-size: 10px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

.hotel-search-field button {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 43px;
  padding: 0 10px;
  border-radius: 7px;
  background: #f1f2f4;
  color: #141b2a;
  text-align: left;
}

.hotel-search-field button > svg:first-child {
  width: 18px;
  height: 18px;
  color: var(--hotel-blue);
}

.hotel-search-field button > svg:last-child {
  width: 14px;
  height: 14px;
  margin-left: auto;
  color: #7a879b;
}

.hotel-search-field strong {
  display: block;
  color: #151b27;
  font-size: 18px;
  line-height: 1.05;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.hotel-field-search-input {
  display: block;
  width: 100%;
  min-width: 0;
  padding: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: #151b27;
  font: inherit;
  font-size: 18px;
  line-height: 1.05;
  font-weight: 700;
}

.hotel-field-search-input::-webkit-search-cancel-button {
  display: none;
}

.hotel-search-field small {
  display: block;
  margin-top: 2px;
  color: #424d61;
  font-size: 10px;
  line-height: 1.2;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.hotel-search-field.price button {
  background: transparent;
}

.hotel-search-field.price strong,
.hotel-search-field.guests strong {
  font-size: 13px;
}

.hotel-modify-btn {
  align-self: center;
  justify-self: center;
  width: 150px;
  height: 44px;
  border-radius: 999px;
  color: #fff;
  background: var(--hotel-blue);
  font-size: 14px;
  font-weight: 700;
}

.hotel-search-popover {
  position: absolute;
  top: calc(100% + 10px);
  z-index: 20;
  display: none;
  width: min(340px, calc(100vw - 56px));
  padding: 14px;
  border: 1px solid #dfe6ef;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 22px 48px rgba(20, 38, 72, 0.15);
}

.hotel-search-popover.is-open {
  display: block;
}

.destination-popover {
  left: 18px;
}

.date-popover {
  left: min(6px, 28vw);
  width: min(940px, calc(100vw - 48px));
}

.checkout-popover {
  left: min(10px, 24vw);
}

.date-popover .calendar-popover-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.date-popover .calendar-month-card {
  min-width: 0;
}

.date-popover .calendar-month-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.date-popover .calendar-month-head h3 {
  margin: 0;
  color: #111827;
  font-size: 15px;
  font-weight: 800;
}

.date-popover .calendar-nav {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.date-popover .calendar-nav button {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: var(--hotel-blue);
  background: #eef5ff;
}

.date-popover .calendar-nav svg {
  width: 15px;
  height: 15px;
}

.date-popover .calendar-weekdays,
.date-popover .calendar-days {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.date-popover .calendar-weekdays {
  gap: 7px;
  margin-bottom: 8px;
}

.date-popover .calendar-weekdays span {
  color: #8792a4;
  font-size: 10px;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
}

.date-popover .calendar-days {
  gap: 7px;
}

.date-popover .calendar-day {
  min-height: 45px;
  display: grid;
  place-items: center;
  gap: 2px;
  padding: 5px 3px;
  border-radius: 9px;
  color: #111827;
  background: #f6f8fb;
  font-size: 12px;
  font-weight: 800;
}

.date-popover .calendar-day span {
  line-height: 1;
}

.date-popover .calendar-day small {
  font-size: 9px;
  line-height: 1;
  font-weight: 800;
}

.date-popover .calendar-day .fare-red {
  color: #e11d48;
}

.date-popover .calendar-day .fare-blue {
  color: var(--hotel-blue);
}

.date-popover .calendar-day.muted {
  background: transparent;
}

.date-popover .calendar-day.muted span {
  color: #c8d1df;
}

.date-popover .calendar-day:hover,
.date-popover .calendar-day.selected {
  color: #fff;
  background: var(--hotel-blue);
}

.date-popover .calendar-day.selected small,
.date-popover .calendar-day:hover small {
  color: #fff;
}

.guests-popover {
  right: 270px;
  width: 320px;
}

.price-popover {
  right: 170px;
  width: 280px;
}

.hotel-popup-search {
  display: flex;
  align-items: center;
  gap: 9px;
  height: 42px;
  padding: 0 12px;
  border: 1px solid #dfe6ef;
  border-radius: 9px;
  background: #f6f8fb;
}

.hotel-popup-search svg {
  width: 16px;
  height: 16px;
  color: #627085;
}

.hotel-popup-search input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: #111827;
  font-size: 13px;
}

.hotel-destination-list {
  display: grid;
  gap: 6px;
  margin-top: 10px;
}

.hotel-destination-list button {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 54px;
  padding: 0 10px;
  border-radius: 9px;
  color: #111827;
  background: transparent;
  text-align: left;
}

.hotel-destination-list button:hover,
.price-popover button:hover {
  background: #eef5ff;
}

.hotel-destination-list svg {
  width: 17px;
  height: 17px;
  color: var(--hotel-blue);
}

.hotel-destination-list strong,
.hotel-stepper-row strong {
  display: block;
  color: #111827;
  font-size: 13px;
  font-weight: 800;
}

.hotel-destination-list small,
.hotel-stepper-row small {
  display: block;
  margin-top: 3px;
  color: #6d7688;
  font-size: 11px;
  font-weight: 600;
}

.hotel-calendar-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.hotel-calendar-head strong {
  color: #111827;
  font-size: 15px;
  font-weight: 800;
}

.hotel-calendar-head span {
  color: #6d7688;
  font-size: 11px;
  font-weight: 700;
}

.hotel-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}

.hotel-calendar-grid span {
  color: #8792a4;
  font-size: 10px;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
}

.hotel-calendar-grid button {
  display: grid;
  place-items: center;
  aspect-ratio: 1;
  border-radius: 8px;
  color: #111827;
  background: #f6f8fb;
  font-size: 12px;
  font-weight: 800;
}

.hotel-calendar-grid button:hover,
.hotel-calendar-grid button.selected {
  color: #fff;
  background: var(--hotel-blue);
}

.hotel-stepper-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 12px 0;
}

.hotel-stepper-row + .hotel-stepper-row {
  border-top: 1px solid #edf1f5;
}

.hotel-stepper-row > div {
  display: flex;
  align-items: center;
  gap: 10px;
}

.hotel-stepper-row button {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid #d8e0ea;
  border-radius: 50%;
  color: var(--hotel-blue);
  background: #fff;
  font-size: 16px;
  font-weight: 800;
}

.hotel-stepper-row b {
  min-width: 18px;
  color: #111827;
  font-size: 14px;
  text-align: center;
}

.price-popover {
  display: none;
  gap: 7px;
}

.price-popover.is-open {
  display: grid;
}

.price-popover > button {
  display: none;
}

.price-popover .filter-section {
  margin: 0;
}

.price-popover .filter-section-title {
  min-height: 20px;
  margin-bottom: 11px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: #172033;
  font-size: 14px;
  font-weight: 500;
}

.price-popover .filter-section-title strong {
  min-height: 22px;
  padding: 0 12px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  background: #e8eefc;
  color: #1248c8;
  font-size: 11px;
  font-weight: 800;
}

.price-popover .filter-range {
  width: 100%;
  accent-color: var(--hotel-blue);
}

.price-popover .filter-range-labels {
  display: flex;
  justify-content: space-between;
  color: #7b8494;
  font-size: 11px;
  font-weight: 700;
}

.price-popover button {
  min-height: 40px;
  padding: 0 12px;
  border-radius: 8px;
  color: #111827;
  background: transparent;
  font-size: 13px;
  font-weight: 800;
  text-align: left;
}

/* Shared hotel search responsive rules */
@media (max-width: 1180px) {
  .hotel-search-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .hotel-search-field.price {
    border-right: 1px solid #edf1f5;
  }

  .hotel-modify-btn {
    width: calc(100% - 36px);
    margin: 18px;
  }
}

@media (max-width: 1024px) {
  .hotel-search-panel {
    display: none;
  }
}
