/* ===================================================
   Travelz Master — Redesigned UI
   Bootstrap 5 + Poppins
   =================================================== */

/* ===== CSS VARIABLES ===== */
:root {
  --primary:       #f97316;
  --primary-dark:  #ea580c;
  --primary-light: #fb923c;
  --secondary:     #2563eb;
  --secondary-dark:#1d4ed8;
  --white:         #ffffff;
  --light-bg:      #f8f9fa;
  --light-gray:    #f1f3f5;
  --card-bg:       #ffffff;
  --text-dark:     #1e293b;
  --text-mid:      #64748b;
  --text-light:    #94a3b8;
  --border:        #e2e8f0;
  --shadow:        0 2px 12px rgba(0,0,0,0.08);
  --shadow-lg:     0 8px 30px rgba(0,0,0,0.13);
  --shadow-xl:     0 20px 60px rgba(0,0,0,0.17);
  --radius:        8px;
  --radius-lg:     14px;
  --radius-xl:     22px;
  --ease:          cubic-bezier(.4,0,.2,1);
}


/* ════════════════════════════════════════════════════════════
   GSAP REVEAL HELPERS
   ════════════════════════════════════════════════════════════ */
.gsap-reveal { opacity: 0; transform: translateY(30px); }

/* ===== RESET ===== */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Poppins','Segoe UI',Arial,sans-serif;
  color:var(--text-dark);
  background:#fff;
  line-height:1.6;
  font-size:14px;
  -webkit-font-smoothing:antialiased;
}
a { text-decoration:none; color:inherit; }
ul { list-style:none; padding:0; margin:0; }
img { max-width:100%; display:block; }
.container { max-width:1200px; margin:0 auto; padding:0 20px; }

/* ===================================================
   TOP BAR
   =================================================== */
.top-bar {
  background:#1e293b;
  color:rgba(255,255,255,0.82);
  font-size:11px;
  font-weight:500;
  padding:5px 0;
}
.top-bar .container {
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.top-bar-left { display:flex; align-items:center; gap:18px; }
.top-bar-right { display:flex; align-items:center; gap:16px; }
.top-bar-right a { color:rgba(255,255,255,0.7); transition:color .2s; }
.top-bar-right a:hover { color:#fff; }

/* ===================================================
   NAVBAR
   =================================================== */
.site-navbar {
  background:#fff !important;
  border-bottom:1px solid var(--border);
  padding:8px 0;
  position:sticky;
  top:0;
  z-index:1000;
  box-shadow:0 2px 10px rgba(0,0,0,0.06);
}
.site-navbar .navbar-brand img {
  filter:none !important;
  height:46px;
  width:auto;
  object-fit:contain;
}
.site-navbar .nav-link {
  color:var(--text-dark) !important;
  font-weight:500;
  font-size:13.5px;
  padding:7px 13px !important;
  border-radius:6px;
  transition:color .2s,background .2s;
}
.site-navbar .nav-link:hover,
.site-navbar .nav-link.active {
  color:var(--primary) !important;
  background:#fff7ed;
}
.btn-phone-cta {
  background:var(--primary) !important;
  color:#fff !important;
  border:none;
  border-radius:7px;
  padding:9px 20px !important;
  font-weight:700;
  font-size:13px;
  display:inline-flex;
  align-items:center;
  gap:7px;
  transition:background .2s,transform .15s;
  box-shadow:0 4px 14px rgba(249,115,22,0.28);
}
.btn-phone-cta:hover {
  background:var(--primary-dark) !important;
  transform:translateY(-1px);
}
.phone-ring { animation:none; }

/* ===================================================
   HERO
   =================================================== */
.hero {
  position:relative;
  min-height:420px;
  display:flex;
  align-items:center;
  padding:64px 0 130px;
  background:url('assets/images/hero-bg.png') center/cover no-repeat !important;
  overflow:visible;
}
.hero::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(10,20,55,0.80) 0%,rgba(15,30,70,0.65) 55%,rgba(10,20,50,0.40) 100%);
}
.hero-parallax,.hero-clouds { display:none !important; }
#globe-wrap { display:none !important; }

.hero-content {
  position:relative;
  z-index:2;
  max-width:1100px;
  margin:0 auto;
  text-align:center;
}
.hero-content > p { margin-left:auto; margin-right:auto; }
.hero-badge {
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:rgba(255,255,255,0.14);
  border:1px solid rgba(255,255,255,0.24);
  color:#fff;
  padding:5px 14px;
  border-radius:20px;
  font-size:12px;
  font-weight:600;
  margin-bottom:16px;
  backdrop-filter:blur(8px);
}
.hero h1 {
  font-size:46px;
  font-weight:800;
  color:#fff;
  line-height:1.2;
  margin-bottom:14px;
  letter-spacing:-0.5px;
}
.hero h1 span { color:var(--primary); }
.hero-content > p {
  color:rgba(255,255,255,0.82);
  font-size:15px;
  margin-bottom:22px;
  max-width:540px;
}
.hero-features {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:24px;
}
.hero-feature {
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.2);
  color:rgba(255,255,255,0.88);
  padding:5px 12px;
  border-radius:20px;
  font-size:11.5px;
  font-weight:500;
  backdrop-filter:blur(6px);
}
.hero-metrics {
  display:flex;
  gap:28px;
  margin-top:14px;
  flex-wrap:wrap;
  justify-content:center;
}
.hero-metric { font-size:12px; color:rgba(255,255,255,0.6); }
.hero-metric strong { color:var(--primary); font-weight:700; }

/* ===================================================
   SEARCH CARD
   =================================================== */
.search-card {
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:0 12px 50px rgba(0,0,0,0.22);
  padding:24px 32px 22px;
  width:100%;
  max-width:1100px;
  margin:0 auto;
  text-align:left;
}
.trip-tabs {
  display:flex;
  gap:6px;
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.trip-tab {
  background:none;
  border:1.5px solid var(--border);
  color:var(--text-mid);
  padding:6px 18px;
  border-radius:6px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  transition:all .2s;
  font-family:inherit;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.trip-tab.active { background:var(--primary); border-color:var(--primary); color:#fff; }
.trip-tab:not(.active):hover { background:#fff7ed; color:var(--primary); border-color:var(--primary); }

.search-row {
  display:grid;
  grid-template-columns:1fr 38px 1fr 1fr 1fr;
  gap:12px;
  align-items:end;
  margin-bottom:12px;
}
.search-row-2 {
  display:grid;
  grid-template-columns:1.5fr 1fr auto;
  gap:12px;
  align-items:end;
}
.form-group { position:relative; }
.form-label {
  display:block;
  font-size:10.5px;
  font-weight:700;
  color:var(--text-mid);
  text-transform:uppercase;
  letter-spacing:0.6px;
  margin-bottom:5px;
}
.form-control,
.passenger-display {
  width:100%;
  padding:9px 12px;
  border:1.5px solid var(--border);
  border-radius:8px;
  font-size:13.5px;
  color:var(--text-dark);
  background:#fff;
  font-family:inherit;
  transition:border-color .2s,box-shadow .2s;
  outline:none;
  appearance:auto;
}
.form-control:focus,
.passenger-display:focus-within {
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(249,115,22,0.12);
}
.swap-btn {
  background:var(--light-bg);
  border:1.5px solid var(--border);
  border-radius:8px;
  width:38px;
  height:38px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:var(--text-mid);
  transition:all .2s;
  flex-shrink:0;
  align-self:flex-end;
}
.swap-btn:hover { background:var(--primary); border-color:var(--primary); color:#fff; }
.search-btn {
  background:var(--primary);
  color:#fff;
  border:none;
  border-radius:8px;
  padding:10px 28px;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  font-family:inherit;
  transition:background .2s,transform .15s;
  display:inline-flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
  height:40px;
}
.search-btn:hover { background:var(--primary-dark); transform:translateY(-1px); }

/* Passenger dropdown */
.passenger-select { position:relative; }
.passenger-display {
  display:flex;
  align-items:center;
  justify-content:space-between;
  cursor:pointer;
  user-select:none;
}
.passenger-dropdown {
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:12px;
  box-shadow:var(--shadow-lg);
  padding:16px;
  z-index:100;
  min-width:260px;
  display:none;
}
.passenger-dropdown.open { display:block; }
.pax-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:9px 0;
  border-bottom:1px solid var(--border);
}
.pax-row:last-of-type { border-bottom:none; }
.pax-type { font-weight:600; font-size:13px; color:var(--text-dark); }
.pax-age { font-size:11px; color:var(--text-light); }
.pax-counter { display:flex; align-items:center; gap:12px; }
.pax-btn {
  width:28px; height:28px;
  border-radius:50%;
  border:1.5px solid var(--border);
  background:#fff;
  font-size:16px;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  color:var(--text-dark);
  transition:all .2s;
}
.pax-btn:hover { background:var(--primary); border-color:var(--primary); color:#fff; }
.pax-count { font-weight:700; font-size:14px; min-width:20px; text-align:center; }
.pax-dropdown-done {
  width:100%;
  padding:10px;
  background:var(--primary);
  color:#fff;
  border:none;
  border-radius:8px;
  font-weight:700;
  font-size:13px;
  cursor:pointer;
  margin-top:14px;
  font-family:inherit;
  transition:background .2s;
}
.pax-dropdown-done:hover { background:var(--primary-dark); }

/* Autocomplete */
.autocomplete-list {
  position:fixed;
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:12px;
  box-shadow:var(--shadow-lg);
  z-index:99999;
  display:none;
  max-height:360px;
  overflow-y:auto;
  padding:6px 0;
}
.autocomplete-item {
  padding:9px 14px;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:12px;
  border-bottom:1px solid rgba(0,0,0,0.04);
  transition:background .15s;
}
.autocomplete-item:hover { background:#f8f9fa; }
.ac-icon { width:32px; height:32px; background:#fff7ed; border-radius:7px; display:flex; align-items:center; justify-content:center; color:var(--primary); flex-shrink:0; font-size:12px; }
.ac-content { flex:1; min-width:0; }
.ac-top { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.ac-city-query { font-size:13px; font-weight:700; color:var(--text-dark); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ac-airport-name { font-size:11px; color:var(--text-light); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ac-code-pill { font-size:11px; font-weight:800; color:var(--primary); }

/* ===================================================
   TRUST SECTION
   =================================================== */
.trust-section {
  background:#fff;
  padding:32px 0;
  border-bottom:1px solid var(--border);
}
.trust-inner {
  display:flex;
  justify-content:center;
  gap:48px;
  flex-wrap:wrap;
}
.trust-item {
  display:flex;
  align-items:center;
  gap:12px;
  font-size:13px;
  font-weight:600;
  color:var(--text-dark);
}
.trust-icon { font-size:22px; color:var(--primary); }

/* ===================================================
   SECTION HEADERS
   =================================================== */
.section-header { text-align:center; margin-bottom:40px; }
.section-label {
  display:inline-block;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:var(--primary);
  margin-bottom:8px;
}
.section-title {
  font-size:30px;
  font-weight:800;
  color:var(--text-dark);
  margin-bottom:10px;
}
.section-title span { color:var(--primary); }
.section-desc { color:var(--text-mid); font-size:14px; max-width:520px; margin:0 auto; }

/* ===================================================
   FEATURES SECTION
   =================================================== */
.features-section { background:var(--light-bg); padding:60px 0; }
.features-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.feature-card {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:28px 20px;
  text-align:center;
  box-shadow:var(--shadow);
  border:1px solid var(--border);
  transition:transform .25s,box-shadow .25s;
}
.feature-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.feature-icon { font-size:30px; margin-bottom:14px; }
.feature-title { font-size:15px; font-weight:700; color:var(--text-dark); margin-bottom:8px; }
.feature-desc { font-size:13px; color:var(--text-mid); line-height:1.6; }

/* ===================================================
   DEALS / DESTINATION SECTION
   =================================================== */
.deals-section { background:#fff; padding:60px 0; }
.deals-title {
  font-size:30px;
  font-weight:800;
  color:var(--text-dark);
  text-align:center;
  margin-bottom:10px;
}
.deals-disclaimer {
  font-size:12px;
  color:var(--text-light);
  text-align:center;
  max-width:780px;
  margin:0 auto 36px;
  line-height:1.6;
}
.deals-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.deal-card {
  background:#fff;
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform .25s,box-shadow .25s;
  display:flex;
  flex-direction:column;
}
.deal-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.deal-img {
  height:150px;
  background-size:cover;
  background-position:center;
  background-color:var(--light-bg);
}
.deal-info { padding:14px 16px 10px; flex:1; }
.deal-city { font-size:14px; font-weight:700; color:var(--text-dark); margin-bottom:3px; }
.deal-route { font-size:11px; color:var(--text-mid); margin-bottom:3px; }
.deal-dates { font-size:11px; color:var(--text-light); }
.deal-footer {
  padding:12px 16px;
  border-top:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:var(--light-bg);
}
.deal-price { font-size:20px; font-weight:800; color:var(--primary); }
.deal-type { font-size:10px; color:var(--text-light); font-weight:600; text-transform:uppercase; }
.deal-btn {
  background:var(--primary);
  color:#fff;
  padding:7px 16px;
  border-radius:6px;
  font-size:12px;
  font-weight:700;
  transition:background .2s;
  display:inline-block;
}
.deal-btn:hover { background:var(--primary-dark); color:#fff; }
.deals-note {
  font-size:11px;
  color:var(--text-light);
  text-align:center;
  margin-top:28px;
}

/* ===================================================
   TESTIMONIALS
   =================================================== */
.testimonials-section { background:var(--light-bg); padding:60px 0; }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.review-card {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:24px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  transition:transform .25s,box-shadow .25s;
}
.review-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.review-stars { color:#f59e0b; margin-bottom:10px; font-size:14px; }
.review-text { color:var(--text-mid); font-size:13px; line-height:1.7; margin-bottom:16px; }
.reviewer { display:flex; align-items:center; gap:12px; }
.reviewer-avatar {
  width:38px; height:38px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:15px; color:#fff;
  flex-shrink:0;
}
.av-blue  { background:var(--secondary); }
.av-green { background:#10b981; }
.av-orange{ background:var(--primary); }
.reviewer-name { font-weight:700; font-size:13px; color:var(--text-dark); }
.reviewer-trip { font-size:11px; color:var(--text-light); }

/* ===================================================
   CTA BANNER
   =================================================== */
.cta-banner {
  position:relative;
  padding:90px 0;
  text-align:center;
  background-image:url('https://images.unsplash.com/photo-1436491865332-7a61a109cc05?w=1920&q=85&auto=format&fit=crop');
  background-size:cover;
  background-position:center 40%;
  background-attachment:fixed;
  overflow:hidden;
}
.cta-banner::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(10,18,50,0.88) 0%,rgba(234,88,12,0.55) 100%);
}
.cta-banner .container { position:relative; z-index:1; }
.cta-banner h2 { font-size:34px; font-weight:800; color:#fff; margin-bottom:14px; letter-spacing:-0.3px; }
.cta-banner p { color:rgba(255,255,255,0.85); font-size:15px; margin-bottom:32px; }
.cta-btns { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }
.cta-btn-primary {
  background:var(--primary);
  color:#fff;
  padding:13px 32px;
  border-radius:8px;
  font-weight:700;
  font-size:14px;
  transition:background .2s,transform .15s;
  display:inline-flex; align-items:center; gap:8px;
}
.cta-btn-primary:hover { background:var(--primary-dark); transform:translateY(-2px); }
.cta-btn-secondary {
  background:rgba(255,255,255,0.15);
  color:#fff;
  border:2px solid rgba(255,255,255,0.4);
  padding:13px 32px;
  border-radius:8px;
  font-weight:700;
  font-size:14px;
  transition:all .2s;
  display:inline-flex; align-items:center; gap:8px;
}
.cta-btn-secondary:hover { background:rgba(255,255,255,0.25); transform:translateY(-2px); }

/* ===================================================
   FOOTER
   =================================================== */
footer { background:#2d2d2d; border-top:none; }
.footer-top { padding:52px 0 36px; }
.footer-grid {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px;
}
.footer-brand img { filter:brightness(0) invert(1) !important; height:48px; width:auto; }
.footer-desc { font-size:13px; color:rgba(255,255,255,0.55); line-height:1.7; margin:14px 0 18px; }
.footer-contact-item {
  display:flex; align-items:flex-start; gap:10px;
  font-size:13px; color:rgba(255,255,255,0.55); margin-bottom:10px;
}
.footer-contact-icon { color:var(--primary); font-size:14px; margin-top:2px; flex-shrink:0; }
.footer-contact-item a { color:rgba(255,255,255,0.55); transition:color .2s; }
.footer-contact-item a:hover { color:var(--primary); }
.footer-col-title {
  font-size:14px; font-weight:700; color:#fff;
  margin-bottom:16px;
  padding-bottom:8px;
  border-bottom:2px solid var(--primary);
  display:inline-block;
}
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-links a {
  font-size:13px; color:rgba(255,255,255,0.55);
  transition:color .2s,padding-left .2s;
  display:flex; align-items:center; gap:6px;
}
.footer-links a:hover { color:var(--primary); padding-left:4px; }
.footer-bottom {
  background:#1a1a1a;
  padding:14px 0;
}
.footer-bottom .container {
  display:flex; align-items:center;
  justify-content:space-between; flex-wrap:wrap; gap:12px;
}
.footer-copyright { font-size:12px; color:rgba(255,255,255,0.45); }
.footer-payment { display:flex; align-items:center; gap:8px; }
.payment-label { font-size:12px; color:rgba(255,255,255,0.4); }
.payment-badge {
  background:rgba(255,255,255,0.08);
  padding:3px 9px;
  border-radius:4px;
  font-size:11px;
  font-weight:600;
  color:rgba(255,255,255,0.65);
}

/* ===================================================
   SCROLL TO TOP
   =================================================== */
.scroll-top {
  position:fixed; bottom:24px; right:24px;
  width:40px; height:40px;
  background:var(--primary); color:#fff;
  border:none; border-radius:8px;
  cursor:pointer; font-size:14px;
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none;
  transition:opacity .3s,transform .3s;
  z-index:999;
  box-shadow:0 4px 14px rgba(249,115,22,0.4);
}
.scroll-top.visible { opacity:1; pointer-events:all; }
.scroll-top:hover { transform:translateY(-2px); }

/* ===================================================
   INNER PAGES (about, contact, legal)
   =================================================== */
.inner-page-hero,
.page-hero {
  background:linear-gradient(135deg,rgba(10,18,50,0.96) 0%,rgba(234,88,12,0.85) 100%),
             url('assets/images/hero-bg.png') center/cover no-repeat;
  padding:56px 0;
  color:#fff;
  text-align:center;
}
.inner-page-hero h1,
.page-hero h1 { font-size:32px; font-weight:800; margin-bottom:8px; }
.inner-page-hero p,
.page-hero p { color:rgba(255,255,255,0.78); font-size:15px; }
.inner-page-body { padding:56px 0; background:#fff; }
.inner-page-body h2 { font-size:22px; font-weight:700; color:var(--text-dark); margin:28px 0 12px; padding-bottom:8px; border-bottom:2px solid var(--primary); display:inline-block; }

/* ===================================================
   POLICY PAGES (privacy, terms, cookies, etc.)
   =================================================== */
.policy-section { padding:50px 0; background:var(--light-bg); }
.policy-card {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:32px;
  box-shadow:var(--shadow);
  border:1px solid var(--border);
  max-width:1060px;
  margin:0 auto;
}
.policy-card h2 { font-size:1.3rem; font-weight:800; color:var(--primary); margin:30px 0 12px; }
.policy-card h2:first-child { margin-top:0; }
.policy-card p, .policy-card li { font-size:14px; color:var(--text-mid); line-height:1.8; margin-bottom:10px; }
.policy-card ul { padding-left:20px; margin-bottom:14px; }
.policy-card li { list-style:disc; }
.last-updated { font-size:13px; color:var(--text-light); font-style:italic; border-bottom:1px solid var(--border); padding-bottom:18px; margin-bottom:24px; }
@media (max-width:768px) { .policy-section { padding:36px 0; } }
@media (max-width:600px) { .policy-card { padding:18px; } }
.inner-page-body h3 { font-size:17px; font-weight:700; color:var(--text-dark); margin:20px 0 8px; }
.inner-page-body p { color:var(--text-mid); font-size:14px; line-height:1.85; margin-bottom:14px; }
.inner-page-body ul { margin-bottom:16px; padding-left:0; }
.inner-page-body ul li { color:var(--text-mid); font-size:14px; line-height:1.8; padding-left:18px; position:relative; margin-bottom:6px; }
.inner-page-body ul li::before { content:'→'; position:absolute; left:0; color:var(--primary); font-size:12px; }

/* Contact form */
.contact-form-wrap {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:32px;
  box-shadow:var(--shadow-lg);
  border:1px solid var(--border);
}
.contact-form-wrap .form-group { margin-bottom:18px; }
.contact-form-wrap label { display:block; font-size:12px; font-weight:700; color:var(--text-mid); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:6px; }
.contact-form-wrap input,
.contact-form-wrap select,
.contact-form-wrap textarea {
  width:100%; padding:10px 14px;
  border:1.5px solid var(--border);
  border-radius:8px; font-size:14px;
  color:var(--text-dark); font-family:inherit;
  outline:none; transition:border-color .2s;
}
.contact-form-wrap input:focus,
.contact-form-wrap select:focus,
.contact-form-wrap textarea:focus { border-color:var(--secondary); box-shadow:0 0 0 3px rgba(37,99,235,0.1); }
.contact-submit-btn {
  background:var(--primary); color:#fff;
  padding:12px 32px; border-radius:8px;
  font-size:14px; font-weight:700;
  border:none; cursor:pointer;
  font-family:inherit; transition:background .2s;
}
.contact-submit-btn:hover { background:var(--primary-dark); }

/* ===================================================
   SEARCH RESULTS PAGE — LAYOUT
   =================================================== */
.search-results-wrap,
.results-page { background:var(--light-bg); min-height:60vh; padding:28px 0 48px; }
.results-layout {
  display:grid;
  grid-template-columns:270px 1fr;
  gap:22px;
  align-items:start;
}

/* Filter Sidebar */
.filter-sidebar { position:sticky; top:80px; }
.filter-card {
  background:#fff;
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  overflow:hidden;
  margin-bottom:16px;
}
.filter-title {
  font-size:13px; font-weight:700; color:var(--text-dark);
  padding:14px 18px;
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:8px;
}
.filter-group {
  padding:14px 18px;
  border-bottom:1px solid var(--border);
}
.filter-group:last-child { border-bottom:none; }
.filter-group-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.filter-group-label { font-size:12px; font-weight:700; color:var(--text-dark); text-transform:uppercase; letter-spacing:0.4px; }
.filter-select-all { font-size:11px; color:var(--secondary); font-weight:600; cursor:pointer; }
.filter-select-all:hover { text-decoration:underline; }
.filter-option-row { display:flex; align-items:center; justify-content:space-between; padding:5px 0; }
.filter-option { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-mid); cursor:pointer; }
.filter-option input[type="checkbox"] { accent-color:var(--primary); width:14px; height:14px; cursor:pointer; }
.filter-only-btn { font-size:11px; color:var(--secondary); font-weight:600; cursor:pointer; white-space:nowrap; padding:2px 6px; border-radius:4px; transition:background .15s; }
.filter-only-btn:hover { background:#eff6ff; }
.price-slider { width:100%; accent-color:var(--primary); margin:10px 0 6px; cursor:pointer; }
.price-vals { display:flex; justify-content:space-between; font-size:12px; color:var(--text-mid); font-weight:600; }
.price-max { color:var(--primary); }

/* Call widget in sidebar */
.call-card {
  background:linear-gradient(135deg,var(--secondary),#1e40af);
  border-radius:var(--radius-lg);
  padding:20px 18px;
  color:#fff;
  text-align:center;
}
.call-card h3 { font-size:15px; font-weight:800; margin-bottom:6px; }
.call-card p { font-size:12px; opacity:.8; margin-bottom:12px; line-height:1.5; }
.call-card a { display:inline-block; background:#fff; color:var(--secondary); font-size:13px; font-weight:800; padding:8px 20px; border-radius:8px; transition:opacity .2s; }
.call-card a:hover { opacity:.9; }

/* Mobile filter toggle */
.mobile-filter-btn {
  display:none;
  align-items:center; gap:8px;
  background:var(--secondary); color:#fff;
  border:none; border-radius:8px;
  padding:9px 18px; font-size:13px; font-weight:700;
  cursor:pointer; font-family:inherit; margin-bottom:16px;
}
.filter-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,0.45); z-index:199;
}

/* Results top bar */
.results-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; flex-wrap:wrap; gap:10px; }
.results-count { font-size:13px; color:var(--text-mid); font-weight:500; }
.results-count strong { color:var(--text-dark); font-weight:700; }
.sort-wrap { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-mid); }
.sort-select { border:1.5px solid var(--border); border-radius:6px; padding:5px 10px; font-size:13px; font-family:inherit; color:var(--text-dark); outline:none; cursor:pointer; }
.sort-select:focus { border-color:var(--secondary); }

/* No results */
.no-results { text-align:center; padding:60px 20px; }
.no-results h3 { font-size:20px; font-weight:700; color:var(--text-dark); margin:16px 0 8px; }
.no-results p { font-size:14px; color:var(--text-mid); margin-bottom:20px; }

/* Mobile responsive for filter */
@media (max-width:900px) {
  .results-layout { grid-template-columns:1fr; }
  .filter-sidebar {
    position:fixed; top:0; left:0; height:100%; width:280px;
    z-index:200; background:#fff; overflow-y:auto;
    transform:translateX(-100%); transition:transform .3s var(--ease);
    box-shadow:4px 0 20px rgba(0,0,0,0.15);
  }
  .filter-sidebar.active { transform:translateX(0); }
  .filter-overlay.active { display:block; }
  .mobile-filter-btn { display:inline-flex; }
}

/* ===================================================
   FLIGHT CARDS
   =================================================== */
.flight-card {
  background:#fff;
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  margin-bottom:10px;
  transition:transform .18s, box-shadow .18s;
  overflow:hidden;
}
.flight-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.flight-card-inner {
  display:grid;
  grid-template-columns:48px 1fr auto;
  gap:14px;
  align-items:center;
  padding:12px 18px;
}

/* Airline logo */
.airline-logo-wrap {
  display:flex; align-items:center; justify-content:center;
  width:44px; height:44px;
  border-radius:8px; border:1px solid var(--border);
  overflow:hidden; background:var(--light-bg); flex-shrink:0;
}
.airline-logo-img { width:100%; height:100%; object-fit:contain; padding:3px; }
.airline-logo-fallback {
  font-size:11px; font-weight:800; color:var(--secondary);
  display:none; align-items:center; justify-content:center;
  width:100%; height:100%; text-align:center;
}
.airline-logo-fallback.show { display:flex; }

/* Flight main area */
.flight-main { display:flex; align-items:center; gap:16px; flex:1; min-width:0; }
.airline-detail { min-width:160px; max-width:220px; flex-shrink:0; }
.a-name { font-size:13px; font-weight:700; color:var(--text-dark); }
.a-num { font-size:11px; color:var(--text-mid); margin:1px 0; }
.a-meta { font-size:10.5px; color:var(--text-light); line-height:1.4; }

/* Route display */
.flight-route { display:flex; align-items:center; gap:8px; flex:1; min-width:180px; }
.route-point { text-align:center; flex-shrink:0; }
.route-time { font-size:18px; font-weight:800; color:var(--text-dark); line-height:1; }
.route-code { font-size:10px; color:var(--text-mid); font-weight:600; margin-top:2px; }
.route-path { flex:1; display:flex; flex-direction:column; align-items:center; gap:3px; }
.path-dur { font-size:10.5px; color:var(--text-light); font-weight:600; }
.path-line-wrap { display:flex; align-items:center; width:100%; }
.path-line-wrap .line { flex:1; height:1px; background:var(--border); }
.path-line-wrap .pl { font-size:12px; color:var(--primary); padding:0 3px; }
.stops-pill { font-size:10px; font-weight:700; padding:2px 8px; border-radius:10px; }
.sp-0 { background:#dcfce7; color:#16a34a; }
.sp-1 { background:#fef9c3; color:#a16207; }
.sp-2 { background:#fee2e2; color:#dc2626; }

/* Price column */
.flight-price-col { text-align:right; flex-shrink:0; min-width:130px; }
.now-price { font-size:24px; font-weight:800; color:var(--primary); line-height:1; }
.per-person { font-size:10px; color:var(--text-light); margin:2px 0 8px; }
.select-flight-btn {
  background:var(--primary); color:#fff;
  padding:9px 16px; border-radius:8px;
  font-size:12px; font-weight:700;
  border:none; cursor:pointer;
  font-family:inherit; transition:background .2s;
  display:inline-flex; align-items:center; gap:5px;
  white-space:nowrap; text-decoration:none;
}
.select-flight-btn:hover { background:var(--primary-dark); color:#fff; }

@media (max-width:768px) {
  .flight-card-inner { grid-template-columns:40px 1fr; gap:10px; padding:10px 14px; }
  .flight-price-col { grid-column:1/-1; text-align:left; padding-top:8px; border-top:1px solid var(--border); }
  .flight-main { flex-wrap:wrap; gap:10px; }
  .route-time { font-size:15px; }
  .now-price { font-size:18px; }
}

/* ===================================================
   BOOKING PAGE
   =================================================== */
.booking-hero {
  background:linear-gradient(135deg,var(--secondary) 0%,#1e40af 100%);
  padding:36px 0 28px;
  color:#fff;
  text-align:center;
}
.booking-hero h1 { font-size:26px; font-weight:800; margin-bottom:6px; }
.booking-hero p { font-size:14px; color:rgba(255,255,255,0.78); }

/* Progress Steps */
.steps-bar {
  display:flex; align-items:center; gap:0;
  padding:16px 0 20px; flex-wrap:wrap; gap:4px;
}
.step {
  display:flex; align-items:center; gap:8px;
  font-size:13px; font-weight:600; color:var(--text-light);
}
.step-num {
  width:28px; height:28px; border-radius:50%;
  background:var(--border); color:var(--text-light);
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:800; flex-shrink:0;
}
.step.done .step-num { background:#10b981; color:#fff; }
.step.done { color:#10b981; }
.step.active .step-num { background:var(--primary); color:#fff; }
.step.active { color:var(--text-dark); }
.step-arrow { color:var(--border); font-size:11px; padding:0 8px; }

/* Layout */
.booking-section { background:var(--light-bg); padding-bottom:48px; }
.booking-layout { display:grid; grid-template-columns:1fr 440px; gap:36px; padding:24px 0; }
.booking-section .container,
.booking-hero .container { max-width:1700px; padding:0 40px; }

/* Form cards */
.booking-form-card {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:24px;
  box-shadow:var(--shadow);
  border:1px solid var(--border);
}
.section-gap { margin-bottom:18px; }
.form-section-title {
  font-size:15px; font-weight:700; color:var(--text-dark);
  margin-bottom:18px; padding-bottom:12px;
  border-bottom:2px solid var(--border);
  display:flex; align-items:center; gap:8px;
}
.form-error-msg {
  background:#fef2f2; border:1px solid #fecaca; color:#dc2626;
  border-radius:8px; padding:10px 14px; font-size:13px;
  margin-bottom:16px; display:none;
}
.form-error-msg.show { display:block; }

/* Passenger cards */
.passenger-section { display:flex; flex-direction:column; gap:16px; }
.pax-card {
  border:1.5px solid var(--border);
  border-radius:var(--radius-lg);
  padding:18px;
  background:var(--light-bg);
}
.pax-card-title {
  font-size:13px; font-weight:700; color:var(--text-dark);
  margin-bottom:14px; display:flex; align-items:center; justify-content:space-between;
}
.primary-pax-label {
  display:inline-flex; align-items:center; gap:6px;
  font-size:11.5px; font-weight:600; color:var(--secondary);
  cursor:pointer;
}
.primary-pax-label input { accent-color:var(--secondary); cursor:pointer; }

/* Form fields */
.form-field { margin-bottom:0; }
.form-field label,
.required-field {
  display:block; font-size:11.5px; font-weight:700;
  color:var(--text-mid); margin-bottom:5px;
}
.required-field::after { content:' *'; color:var(--primary); }
.form-input {
  width:100%; padding:10px 14px;
  border:1.5px solid var(--border); border-radius:8px;
  font-size:13px; color:var(--text-dark);
  font-family:inherit; outline:none;
  transition:border-color .2s, box-shadow .2s;
  background:#f0f4ff;
}
.form-input:focus { border-color:var(--secondary); box-shadow:0 0 0 3px rgba(37,99,235,0.09); background:#fff; }
.form-grid-pax { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.form-grid-4  { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.form-grid-billing { display:grid; grid-template-columns:2fr 1fr 0.8fr 0.8fr 1.4fr; gap:14px; }
@media (max-width:860px) {
  .form-grid-billing { grid-template-columns:1fr 1fr; }
  .form-grid-4 { grid-template-columns:repeat(2,1fr); }
}
.card-input-wrap { position:relative; display:flex; align-items:center; }
.card-prefix {
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  font-size:16px; color:var(--text-mid); pointer-events:none; z-index:1;
  display:flex; align-items:center;
}
.card-number-input { padding-left:40px !important; }
.use-for-all-btn {
  background:none; border:1.5px solid var(--secondary); color:var(--secondary);
  border-radius:6px; padding:6px 12px; font-size:11.5px; font-weight:700;
  cursor:pointer; font-family:inherit; transition:all .2s;
}
.use-for-all-btn:hover { background:var(--secondary); color:#fff; }
.consent-box { font-size:12.5px; color:var(--text-mid); line-height:1.7; margin-bottom:16px; }
.consent-box a { color:var(--secondary); }

/* Submit button */
.submit-booking-btn {
  background:var(--primary); color:#fff;
  padding:14px; border-radius:8px;
  font-size:15px; font-weight:700;
  border:none; cursor:pointer;
  font-family:inherit; width:100%;
  transition:background .2s;
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.submit-booking-btn:hover { background:var(--primary-dark); }
.submit-booking-btn:disabled { opacity:.6; cursor:not-allowed; }

/* Flight summary sidebar */
.flight-summary-card {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:20px; box-shadow:var(--shadow);
  border:1px solid var(--border);
  position:sticky; top:80px;
}
.fs-title,.summary-title {
  font-size:14px; font-weight:700; color:var(--text-dark);
  margin-bottom:14px; padding-bottom:10px;
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:6px;
}
.fs-route { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.fs-airline-logo {
  width:46px; height:46px; border-radius:8px;
  border:1px solid var(--border); overflow:hidden;
  background:var(--light-bg); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:800; color:var(--secondary);
}
.fs-airline-logo img { width:100%; height:100%; object-fit:contain; padding:3px; }
.fs-airline-name { font-size:14px !important; font-weight:700; color:var(--text-dark); line-height:1.2; }
.fs-flight-num { font-size:11px !important; color:var(--text-light); margin-top:2px; }
.fs-via-text { font-size:11px; color:#0059b3; font-weight:700; margin-top:4px; line-height:1.4; }

/* Times row */
.fs-times {
  display:flex; align-items:center;
  justify-content:space-between; margin-bottom:12px;
  background:rgba(37,99,235,0.06);
  border-radius:10px; padding:12px 14px;
  border:1px solid rgba(37,99,235,0.1);
}
.fs-time-block { text-align:center; }
.fs-time { font-size:22px !important; font-weight:800; color:var(--text-dark); line-height:1; }
.fs-code { font-size:11px !important; color:var(--text-mid); font-weight:700; margin-top:4px; }
.fs-arrow { color:var(--text-light); font-size:14px; }

/* Detail rows */
.fs-details { display:flex; flex-direction:column; }
.fs-detail-row {
  display:flex; justify-content:space-between; align-items:flex-start;
  padding:7px 0; border-bottom:1px solid var(--border);
}
.fs-detail-row:last-child { border-bottom:none; }
.fs-detail-row .lbl { font-size:11px !important; color:var(--text-light); font-weight:600; }
.fs-detail-row .val { font-size:11px !important; color:var(--text-dark); font-weight:600; text-align:right; max-width:65%; }

/* Price summary box */
.fs-price-summary {
  background:#f8faff; border-radius:10px;
  padding:14px; border:1px solid #eef2f6; margin-top:14px;
}
.fs-ps-title { font-size:13px; font-weight:700; color:var(--text-dark); margin-bottom:10px; }
.fs-ps-row { display:flex; justify-content:space-between; font-size:12px; margin-bottom:6px; color:var(--text-mid); }
.fs-ps-total {
  display:flex; justify-content:space-between; align-items:center;
  font-size:15px; font-weight:800; color:var(--text-dark);
  border-top:2px solid var(--border); padding-top:10px; margin-top:6px;
}
.fs-ps-total .amount { color:var(--primary); font-size:18px; }

/* Trust badges */
.trust-mini { display:flex; flex-wrap:wrap; gap:16px; margin-top:16px; justify-content:center; }
.trust-mini-item { display:flex; align-items:center; gap:6px; font-size:11px; color:var(--text-mid); font-weight:600; }
.trust-mini-item i { color:var(--primary); font-size:13px; }

/* Legacy aliases */
.booking-card { background:#fff; border-radius:var(--radius-lg); padding:28px; box-shadow:var(--shadow); border:1px solid var(--border); margin-bottom:20px; }
.booking-section-title { font-size:16px; font-weight:700; color:var(--text-dark); margin-bottom:20px; padding-bottom:12px; border-bottom:2px solid var(--border); display:flex; align-items:center; gap:8px; }
.booking-section-title i { color:var(--primary); }
.field-group { margin-bottom:16px; }
.field-group label { display:block; font-size:11.5px; font-weight:700; color:var(--text-mid); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:6px; }
.field-group input, .field-group select { width:100%; padding:10px 14px; border:1.5px solid var(--border); border-radius:8px; font-size:14px; color:var(--text-dark); font-family:inherit; outline:none; transition:border-color .2s; background:#fff; }
.field-group input:focus, .field-group select:focus { border-color:var(--secondary); box-shadow:0 0 0 3px rgba(37,99,235,0.1); }
.summary-row { display:flex; justify-content:space-between; font-size:13px; margin-bottom:8px; }
.summary-row .label { color:var(--text-mid); }
.summary-row .value { font-weight:600; color:var(--text-dark); }
.summary-total { display:flex; justify-content:space-between; font-size:16px; font-weight:800; color:var(--text-dark); border-top:2px solid var(--border); padding-top:12px; margin-top:8px; }
.summary-total .amount { color:var(--primary); }

@media (max-width:960px) {
  .booking-layout { grid-template-columns:1fr; }
  .flight-summary-card { position:static; }
}

/* ===================================================
   THANK YOU PAGE
   =================================================== */
.thankyou-section { background:var(--light-bg); padding:80px 0; text-align:center; }
.thankyou-icon { font-size:64px; color:#10b981; margin-bottom:20px; }
.thankyou-section h1 { font-size:34px; font-weight:800; color:var(--text-dark); margin-bottom:12px; }
.thankyou-section p { font-size:15px; color:var(--text-mid); margin-bottom:24px; }
.thankyou-btn {
  background:var(--primary); color:#fff;
  padding:13px 32px; border-radius:8px;
  font-weight:700; font-size:14px;
  display:inline-flex; align-items:center; gap:8px;
  transition:background .2s;
}
.thankyou-btn:hover { background:var(--primary-dark); }

/* ===================================================
   MISC UTILITIES
   =================================================== */
.badge-primary {
  background:#fff7ed; color:var(--primary);
  padding:3px 10px; border-radius:20px;
  font-size:11px; font-weight:700;
}
.badge-secondary {
  background:#eff6ff; color:var(--secondary);
  padding:3px 10px; border-radius:20px;
  font-size:11px; font-weight:700;
}
.text-primary { color:var(--primary) !important; }
.text-secondary { color:var(--secondary) !important; }
.bg-light-orange { background:#fff7ed; }

/* ===================================================
   RESPONSIVE
   =================================================== */
@media (max-width:1100px) {
  .features-grid { grid-template-columns:repeat(2,1fr); }
  .deals-grid { grid-template-columns:repeat(2,1fr); }
  .testimonials-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  .hero { padding:40px 0 110px; min-height:340px; }
  .hero h1 { font-size:28px; }
  .search-row { grid-template-columns:1fr; }
  .search-row-2 { grid-template-columns:1fr; }
  .swap-btn { display:none; }
  .deals-grid { grid-template-columns:repeat(2,1fr); }
  .testimonials-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .trust-inner { gap:20px; }
  .cta-banner { background-attachment:scroll; padding:60px 0; }
  .site-navbar .panel-left { display:none; }
}
@media (max-width:480px) {
  .deals-grid { grid-template-columns:1fr; }
  .features-grid { grid-template-columns:1fr; }
  .hero h1 { font-size:24px; }
  .section-title { font-size:24px; }
  .search-card { padding:16px; }
  .hero { padding:32px 0 100px; }
}
