
/* ===== DESIGN SYSTEM ===== */
:root {
  --teal:        #00B4B4;
  --teal-dark:   #008A8A;
  --teal-light:  #E0F7F7;
  --gold:        #F5A623;
  --gold-light:  #FFF3D6;
  --navy:        #0A1628;
  --navy-mid:    #122040;
  --slate:       #2C3E50;
  --smoke:       #F4F7FA;
  --white:       #FFFFFF;
  --border:      #E2EAF0;
  --muted:       #7A8FA6;
  --success:     #00C96A;
  --error:       #FF4757;
  --warning:     #FFB300;
  --font-head:   'Syne', sans-serif;
  --font-body:   'DM Sans', sans-serif;
  --radius:      14px;
  --radius-lg:   22px;
  --shadow-sm:   0 2px 8px rgba(10,22,40,.07);
  --shadow-md:   0 8px 32px rgba(10,22,40,.12);
  --shadow-lg:   0 20px 60px rgba(10,22,40,.16);
  --transition:  .25s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--slate);background:var(--white);line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:var(--font-body)}
input,select,textarea{font-family:var(--font-body)}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--smoke)}
::-webkit-scrollbar-thumb{background:var(--teal);border-radius:3px}

/* ===== UTILITY ===== */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hidden{display:none!important}
.flex{display:flex}
.items-center{align-items:center}
.gap-2{gap:8px}
.gap-3{gap:12px}
.gap-4{gap:16px}
.text-teal{color:var(--teal)}
.text-gold{color:var(--gold)}
.text-muted{color:var(--muted)}
.fw-600{font-weight:600}
.fw-700{font-weight:700}
.mt-1{margin-top:4px}
.mt-2{margin-top:8px}
.mb-1{margin-bottom:4px}
.mb-2{margin-bottom:8px}
.w-full{width:100%}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius);font-weight:600;font-size:.9375rem;border:none;transition:var(--transition);white-space:nowrap;letter-spacing:.02em}
.btn-primary{background:linear-gradient(135deg,var(--teal),var(--teal-dark));color:#fff;box-shadow:0 4px 16px rgba(0,180,180,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,180,180,.45)}
.btn-gold{background:linear-gradient(135deg,var(--gold),#e09520);color:#fff;box-shadow:0 4px 16px rgba(245,166,35,.35)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(245,166,35,.45)}
.btn-outline{background:transparent;color:var(--teal);border:2px solid var(--teal)}
.btn-outline:hover{background:var(--teal-light)}
.btn-white{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
.btn-white:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.btn-sm{padding:8px 18px;font-size:.875rem}
.btn-lg{padding:16px 36px;font-size:1.0625rem;border-radius:var(--radius-lg)}
.btn-block{width:100%;display:flex}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}

/* ===== FORM ELEMENTS ===== */
.form-group{display:flex;flex-direction:column;gap:6px;position:relative}
.form-label{font-size:.8125rem;font-weight:600;color:var(--navy);text-transform:uppercase;letter-spacing:.06em}
.form-control{padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius);font-size:.9375rem;color:var(--slate);background:#fff;transition:var(--transition);outline:none;width:100%}
.form-control:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,180,180,.12)}
.form-control.error{border-color:var(--error)}
.form-error{font-size:.8125rem;color:var(--error);margin-top:4px}

/* ===== NAVBAR ===== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:transparent;padding:16px 0;transition:var(--transition)}
.navbar.scrolled{background:var(--navy);box-shadow:var(--shadow-lg);padding:10px 0}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:800;font-size:1.5rem;color:#fff;letter-spacing:-.01em}
.logo-icon{width:38px;height:38px;background:linear-gradient(135deg,var(--teal),var(--teal-dark));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem}
.logo span{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none}
.nav-links a{color:rgba(255,255,255,.85);padding:8px 14px;border-radius:8px;font-size:.9rem;font-weight:500;transition:var(--transition)}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(255,255,255,.12)}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-user-menu{position:relative}
.nav-user-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(255,255,255,.12);color:#fff;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}
.nav-user-btn:hover{background:rgba(255,255,255,.2)}
.nav-avatar{width:28px;height:28px;background:var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff}
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:200px;overflow:hidden;opacity:0;transform:translateY(-8px);pointer-events:none;transition:var(--transition)}
.user-dropdown.open{opacity:1;transform:translateY(0);pointer-events:all}
.user-dropdown a,.user-dropdown button{display:flex;align-items:center;gap:10px;padding:12px 18px;color:var(--slate);font-size:.9rem;font-weight:500;width:100%;text-align:left;background:none;border:none;cursor:pointer;transition:var(--transition)}
.user-dropdown a:hover,.user-dropdown button:hover{background:var(--smoke);color:var(--teal)}
.user-dropdown hr{border:none;border-top:1px solid var(--border);margin:4px 0}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:var(--transition)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;background:linear-gradient(160deg,var(--navy) 0%,#0E2340 50%,#061828 100%);display:flex;align-items:center;overflow:hidden;padding:100px 0 60px}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-bg::before{content:'';position:absolute;top:-20%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(0,180,180,.18) 0%,transparent 70%);border-radius:50%}
.hero-bg::after{content:'';position:absolute;bottom:-20%;left:-5%;width:500px;height:500px;background:radial-gradient(circle,rgba(245,166,35,.1) 0%,transparent 70%);border-radius:50%}
.hero-grid{display:grid;grid-template-columns:1fr;gap:48px;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(0,180,180,.15);border:1px solid rgba(0,180,180,.3);color:var(--teal);padding:8px 16px;border-radius:100px;font-size:.875rem;font-weight:600;margin-bottom:20px}
.hero-badge::before{content:'✦';font-size:.75rem}
.hero h1{font-family:var(--font-head);font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800;color:#fff;line-height:1.1;letter-spacing:-.02em;margin-bottom:20px}
.hero h1 em{font-style:normal;color:var(--gold)}
.hero-sub{color:rgba(255,255,255,.7);font-size:1.0625rem;line-height:1.7;max-width:560px;margin-bottom:32px}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap}
.hero-stat{color:#fff}
.hero-stat-num{font-family:var(--font-head);font-size:1.75rem;font-weight:800;color:var(--teal);display:block}
.hero-stat-label{font-size:.8125rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.08em}

/* ===== SEARCH CARD ===== */
.search-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:32px;margin-top:0}
.search-tabs{display:flex;gap:4px;background:var(--smoke);border-radius:10px;padding:4px;margin-bottom:28px}
.search-tab{flex:1;padding:9px;text-align:center;border-radius:8px;font-size:.875rem;font-weight:600;color:var(--muted);border:none;background:none;cursor:pointer;transition:var(--transition)}
.search-tab.active{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
.search-row{display:grid;gap:16px;margin-bottom:16px}
.search-row-4{grid-template-columns:1fr 1fr 1fr 1fr}
.search-row-3{grid-template-columns:1fr 1fr 1fr}
.search-row-2{grid-template-columns:1fr 1fr}
.airport-input-wrap{position:relative}
.airport-input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--teal);font-size:1rem;pointer-events:none}
.airport-input-wrap .form-control{padding-left:42px}
.autocomplete-list{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border-radius:14px;box-shadow:0 8px 40px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.08);border:1.5px solid var(--border);max-height:320px;overflow-y:auto;z-index:1200;display:none;animation:acDrop .15s ease}
@keyframes acDrop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.autocomplete-list.show{display:block}
.ac-header{padding:8px 14px 6px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border-bottom:1px solid var(--border);background:var(--smoke)}
.autocomplete-item{padding:11px 16px;cursor:pointer;display:flex;align-items:center;gap:14px;transition:background .12s;border-bottom:1px solid rgba(0,0,0,.04)}
.autocomplete-item:last-child{border-bottom:none}
.autocomplete-item:hover,.autocomplete-item.highlighted{background:linear-gradient(90deg,rgba(0,180,180,.07),rgba(0,180,180,.03))}
.ac-iata-badge{font-family:var(--font-head);font-weight:800;font-size:.85rem;color:#fff;background:linear-gradient(135deg,var(--teal),var(--teal-dark));min-width:44px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;letter-spacing:.04em;flex-shrink:0}
.ac-info{flex:1;min-width:0}
.ac-city{font-weight:700;font-size:.9rem;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-sub{font-size:.78rem;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-flag{font-size:1.1rem;flex-shrink:0}
.ac-no-results{padding:20px 16px;text-align:center;color:var(--muted);font-size:.875rem}
.swap-btn{position:absolute;top:50%;right:-20px;transform:translateY(-50%);z-index:10;width:38px;height:38px;background:#fff;border:2px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--teal);cursor:pointer;transition:var(--transition);font-size:1rem}
.swap-btn:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.origin-dest-wrap{display:grid;grid-template-columns:1fr 1fr;gap:16px;position:relative}
.search-submit{margin-top:8px}
.passenger-select{position:relative}
.pax-display{padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius);font-size:.9375rem;color:var(--slate);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:var(--transition)}
.pax-display:hover,.pax-display.open{border-color:var(--teal)}
.pax-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:16px;z-index:999;display:none}
.pax-dropdown.show{display:block}
.pax-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}
.pax-row:last-child{border-bottom:none}
.pax-label{font-weight:600;font-size:.9rem;color:var(--navy)}
.pax-sub{font-size:.8rem;color:var(--muted)}
.pax-counter{display:flex;align-items:center;gap:10px}
.pax-btn{width:30px;height:30px;border-radius:50%;border:2px solid var(--border);background:#fff;color:var(--slate);font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}
.pax-btn:hover:not(:disabled){border-color:var(--teal);color:var(--teal)}
.pax-btn:disabled{opacity:.4;cursor:not-allowed}
.pax-num{font-weight:700;font-size:.95rem;min-width:20px;text-align:center}

/* ===== TRUST STRIP ===== */
.trust-strip{background:var(--smoke);padding:20px 0;border-bottom:1px solid var(--border)}
.trust-items{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:500;color:var(--slate)}
.trust-item span{font-size:1.1rem}

/* ===== SECTION TITLES ===== */
.section{padding:80px 0}
.section-alt{background:var(--smoke)}
.section-label{font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--teal);margin-bottom:10px}
.section-title{font-family:var(--font-head);font-size:clamp(1.75rem,3vw,2.5rem);font-weight:800;color:var(--navy);line-height:1.2;letter-spacing:-.02em;margin-bottom:16px}
.section-sub{color:var(--muted);font-size:1rem;max-width:540px;line-height:1.7}
.section-head{margin-bottom:48px}
.section-head.center{text-align:center}
.section-head.center .section-sub{margin:0 auto}

/* ===== DESTINATIONS ===== */
.dest-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.dest-card{border-radius:var(--radius-lg);overflow:hidden;position:relative;aspect-ratio:4/3;cursor:pointer;group}
.dest-card-bg{position:absolute;inset:0;transition:transform .4s ease}
.dest-card:hover .dest-card-bg{transform:scale(1.06)}
.dest-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,.8) 0%,rgba(10,22,40,.2) 60%,transparent 100%)}
.dest-info{position:absolute;bottom:0;left:0;right:0;padding:20px}
.dest-city{font-family:var(--font-head);font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:4px}
.dest-country{font-size:.8125rem;color:rgba(255,255,255,.75);margin-bottom:8px}
.dest-price{display:inline-flex;align-items:center;gap:4px;background:var(--gold);color:#fff;padding:4px 10px;border-radius:20px;font-size:.8125rem;font-weight:700}
.dest-colors{NBO-LHR:linear-gradient(135deg,#1a3a6b,#2d6abf);NBO-DXB:linear-gradient(135deg,#b45309,#d97706)}

/* Placeholder destination cards using CSS gradients */
.dest-card[data-dest="LHR"] .dest-card-bg{background:linear-gradient(135deg,#1e3a6e 0%,#4a7abf 50%,#1e3a6e 100%)}
.dest-card[data-dest="DXB"] .dest-card-bg{background:linear-gradient(135deg,#c2720d 0%,#e8a823 50%,#854b09 100%)}
.dest-card[data-dest="JFK"] .dest-card-bg{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%)}
.dest-card[data-dest="SIN"] .dest-card-bg{background:linear-gradient(135deg,#00594e 0%,#00b09b 50%,#00594e 100%)}
.dest-card[data-dest="DOH"] .dest-card-bg{background:linear-gradient(135deg,#5c1f5c 0%,#9b3fa0 50%,#5c1f5c 100%)}
.dest-card[data-dest="ADD"] .dest-card-bg{background:linear-gradient(135deg,#1a5c2a 0%,#3a9b4f 50%,#1a5c2a 100%)}

/* ===== FLIGHT RESULTS ===== */
.results-page{display:none;min-height:100vh;padding-top:80px;background:var(--smoke)}
.results-header{background:var(--navy);padding:28px 0;color:#fff}
.results-summary{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.results-route{font-family:var(--font-head);font-size:1.5rem;font-weight:800;display:flex;align-items:center;gap:12px}
.results-meta{color:rgba(255,255,255,.65);font-size:.875rem;margin-top:4px}
.results-modify{padding:10px 20px;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);font-size:.875rem;font-weight:500}
.results-body{padding:32px 0}
.results-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start}
.filters-panel{background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);position:sticky;top:100px}
.filter-title{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--navy);margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--border)}
.filter-group{margin-bottom:24px}
.filter-group-title{font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--navy);margin-bottom:12px}
.filter-option{display:flex;align-items:center;gap:10px;padding:6px 0;cursor:pointer}
.filter-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--teal);cursor:pointer}
.filter-option label{font-size:.875rem;color:var(--slate);cursor:pointer;flex:1}
.filter-option .count{font-size:.75rem;color:var(--muted);background:var(--smoke);padding:2px 6px;border-radius:4px}
.price-range{display:flex;flex-direction:column;gap:10px}
.price-range input[type=range]{width:100%;accent-color:var(--teal)}
.price-labels{display:flex;justify-content:space-between;font-size:.8125rem;color:var(--muted)}
.flight-list{display:flex;flex-direction:column;gap:16px}
.flight-card{background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);border:2px solid transparent;transition:var(--transition);cursor:pointer}
.flight-card:hover{box-shadow:var(--shadow-md);border-color:rgba(0,180,180,.3)}
.flight-card.selected{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,180,180,.15)}
.flight-card-inner{display:grid;grid-template-columns:auto 1fr auto auto;gap:20px;align-items:center}
.airline-logo{width:48px;height:48px;border-radius:12px;background:var(--smoke);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:.75rem;color:var(--teal);border:1px solid var(--border);text-align:center;line-height:1.2;overflow:hidden;padding:4px}
.flight-times{display:flex;align-items:center;gap:20px}
.flight-time{font-family:var(--font-head);font-size:1.5rem;font-weight:800;color:var(--navy)}
.flight-iata{font-size:.8125rem;color:var(--muted);font-weight:500}
.flight-duration-line{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;padding:0 12px}
.duration-text{font-size:.75rem;color:var(--muted);font-weight:500}
.duration-bar{width:100%;height:2px;background:var(--border);border-radius:1px;position:relative;display:flex;align-items:center;justify-content:center}
.duration-bar::before,.duration-bar::after{content:'';width:6px;height:6px;border-radius:50%;background:var(--border);position:absolute}
.duration-bar::before{left:0}
.duration-bar::after{right:0}
.stop-dot{width:8px;height:8px;border-radius:50%;background:var(--teal);position:absolute;top:50%;transform:translateY(-50%)}
.flight-details{text-align:right}
.cabin-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600}
.cabin-economy{background:rgba(0,180,180,.1);color:var(--teal)}
.cabin-business{background:rgba(245,166,35,.1);color:var(--gold)}
.cabin-first{background:rgba(92,26,166,.1);color:#5c1aa6}
.flight-aircraft{font-size:.8125rem;color:var(--muted);margin-top:4px}
.flight-seats{font-size:.8125rem;color:var(--error);font-weight:600;margin-top:4px}
.flight-price-section{text-align:right}
.flight-price{font-family:var(--font-head);font-size:1.75rem;font-weight:800;color:var(--navy)}
.flight-price-per{font-size:.8125rem;color:var(--muted)}
.flight-select-btn{margin-top:12px}
.no-results{text-align:center;padding:60px 20px;color:var(--muted)}
.no-results-icon{font-size:3rem;margin-bottom:16px}
.results-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 0;color:var(--muted)}
.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.sort-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.sort-label{font-size:.875rem;color:var(--muted)}
.sort-btns{display:flex;gap:6px}
.sort-btn{padding:7px 14px;border-radius:8px;font-size:.8125rem;font-weight:600;border:2px solid var(--border);background:#fff;color:var(--slate);cursor:pointer;transition:var(--transition)}
.sort-btn.active{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}

/* ===== BOOKING PAGE ===== */
.booking-page{display:none;min-height:100vh;padding-top:80px;background:var(--smoke)}
.booking-header{background:var(--navy);padding:28px 0;color:#fff}
.progress-bar{display:flex;align-items:center;gap:0;margin-top:24px}
.progress-step{display:flex;align-items:center;gap:8px;flex:1;position:relative}
.progress-step:not(:last-child)::after{content:'';position:absolute;right:0;top:50%;width:calc(100% - 140px);height:2px;background:rgba(255,255,255,.2);transform:translateY(-50%);left:140px}
.progress-step.done::after,.progress-step.active::after{background:var(--teal)}
.step-circle{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;color:rgba(255,255,255,.7);flex-shrink:0;transition:var(--transition)}
.progress-step.done .step-circle{background:var(--teal);border-color:var(--teal);color:#fff}
.progress-step.active .step-circle{background:#fff;border-color:#fff;color:var(--navy)}
.step-label{font-size:.8125rem;font-weight:600;color:rgba(255,255,255,.7)}
.progress-step.active .step-label{color:#fff}
.progress-step.done .step-label{color:var(--teal)}
.booking-body{padding:40px 0}
.booking-layout{display:grid;grid-template-columns:1fr 380px;gap:28px;align-items:start}
.booking-main{display:flex;flex-direction:column;gap:24px}
.booking-section{background:#fff;border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm)}
.booking-section-title{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:24px;padding-bottom:14px;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:10px}
.booking-section-title span{font-size:1.1rem}
.pax-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pax-form-full{grid-column:1/-1}
.seat-map{margin-top:16px}
.seat-legend{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.seat-legend-item{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--muted)}
.seat-legend-dot{width:16px;height:16px;border-radius:4px}
.seat-legend-dot.available{background:var(--teal-light);border:2px solid var(--teal)}
.seat-legend-dot.selected{background:var(--teal);border:2px solid var(--teal-dark)}
.seat-legend-dot.occupied{background:var(--border)}
.seat-grid{display:flex;flex-direction:column;gap:8px}
.seat-row{display:flex;align-items:center;gap:8px}
.seat-row-num{width:20px;font-size:.75rem;color:var(--muted);text-align:center;flex-shrink:0}
.seat-btn{width:34px;height:34px;border-radius:6px;border:2px solid var(--teal);background:var(--teal-light);color:var(--teal);font-size:.7rem;font-weight:700;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.seat-btn:hover{background:var(--teal);color:#fff}
.seat-btn.selected{background:var(--teal);color:#fff;border-color:var(--teal-dark)}
.seat-btn.occupied{background:var(--border);border-color:var(--border);color:var(--muted);cursor:not-allowed}
.seat-aisle{width:20px;flex-shrink:0}
.payment-methods{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:20px}
.payment-method{padding:16px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:center;transition:var(--transition)}
.payment-method:hover{border-color:var(--teal);background:var(--teal-light)}
.payment-method.selected{border-color:var(--teal);background:var(--teal-light)}
.payment-method input{display:none}
.pm-icon{font-size:1.5rem;margin-bottom:6px}
.pm-name{font-size:.875rem;font-weight:600;color:var(--navy)}
.pm-desc{font-size:.75rem;color:var(--muted)}
.mpesa-form,.card-form,.paypal-form{padding-top:16px;border-top:1px solid var(--border);margin-top:4px}
.order-summary{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;position:sticky;top:100px}
.order-summary-header{background:var(--navy);padding:20px 24px;color:#fff}
.order-summary-title{font-family:var(--font-head);font-weight:700;font-size:1rem}
.order-summary-body{padding:24px}
.summary-flight-card{padding:16px;background:var(--smoke);border-radius:var(--radius);margin-bottom:16px}
.summary-route{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.summary-iata{font-family:var(--font-head);font-weight:800;font-size:1.1rem;color:var(--navy)}
.summary-arrow{color:var(--teal);font-size:1.1rem}
.summary-info{display:flex;flex-direction:column;gap:6px}
.summary-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;padding:4px 0}
.summary-row .label{color:var(--muted)}
.summary-row .value{font-weight:600;color:var(--navy)}
.summary-divider{border:none;border-top:2px solid var(--border);margin:16px 0}
.summary-total{display:flex;justify-content:space-between;align-items:center}
.summary-total-label{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--navy)}
.summary-total-amount{font-family:var(--font-head);font-weight:800;font-size:1.5rem;color:var(--teal)}

/* ===== CONFIRMATION PAGE ===== */
.confirm-page{display:none;min-height:100vh;padding-top:80px;background:var(--smoke)}
.confirm-hero{background:linear-gradient(135deg,var(--navy),#0E2340);padding:60px 0;text-align:center;color:#fff}
.confirm-checkmark{width:80px;height:80px;background:var(--success);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 20px;animation:popIn .5s cubic-bezier(.34,1.56,.64,1)}
@keyframes popIn{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}
.confirm-title{font-family:var(--font-head);font-size:2rem;font-weight:800;margin-bottom:8px}
.confirm-sub{color:rgba(255,255,255,.7);font-size:1rem}
.confirm-ref{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);padding:10px 20px;margin-top:16px;font-family:var(--font-head);font-weight:700;font-size:1.1rem;letter-spacing:.08em}
.confirm-body{padding:48px 0}
.confirm-layout{display:grid;grid-template-columns:2fr 1fr;gap:24px}
.e-ticket{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}
.ticket-header{background:linear-gradient(135deg,var(--navy),var(--navy-mid));padding:24px 32px;display:flex;align-items:center;justify-content:space-between}
.ticket-logo{color:#fff;font-family:var(--font-head);font-weight:800;font-size:1.1rem;display:flex;align-items:center;gap:8px}
.ticket-tag{background:var(--success);color:#fff;padding:6px 14px;border-radius:20px;font-size:.8125rem;font-weight:700;display:flex;align-items:center;gap:6px}
.ticket-body{padding:32px}
.ticket-route{display:flex;align-items:center;gap:24px;margin-bottom:32px;padding-bottom:24px;border-bottom:2px dashed var(--border)}
.ticket-iata{font-family:var(--font-head);font-size:2.5rem;font-weight:800;color:var(--navy)}
.ticket-city{font-size:.875rem;color:var(--muted);margin-top:2px}
.ticket-plane{font-size:1.5rem;color:var(--teal);transform:rotate(90deg);margin:0 8px}
.ticket-duration{text-align:center}
.ticket-dur-text{font-size:.8125rem;color:var(--muted);margin-bottom:4px}
.ticket-dur-line{width:80px;height:2px;background:var(--teal);position:relative}
.ticket-dur-line::after{content:'✈';position:absolute;top:-10px;right:-6px;font-size:.875rem;color:var(--teal)}
.ticket-details-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}
.ticket-detail{padding:14px;background:var(--smoke);border-radius:var(--radius)}
.td-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-bottom:4px}
.td-value{font-weight:700;color:var(--navy);font-size:.9375rem}
.ticket-barcode{text-align:center;padding:20px;border-top:2px dashed var(--border);margin-top:8px}
.barcode{display:inline-flex;gap:2px;align-items:flex-end;height:48px}
.bar{background:var(--navy);border-radius:1px;width:3px}
.ticket-actions{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.confirm-actions{background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;position:sticky;top:100px}
.confirm-action-item{padding:16px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;gap:14px;transition:var(--transition)}
.confirm-action-item:hover{border-color:var(--teal);background:var(--teal-light)}
.ca-icon{font-size:1.5rem}
.ca-text .ca-title{font-weight:600;font-size:.9rem;color:var(--navy)}
.ca-text .ca-sub{font-size:.8rem;color:var(--muted)}

/* ===== AUTH MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(10,22,40,.7);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:var(--transition);backdrop-filter:blur(4px)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);transform:scale(.95) translateY(20px);transition:var(--transition)}
.modal-overlay.open .modal{transform:scale(1) translateY(0)}
.modal-header{padding:28px 28px 0;display:flex;align-items:center;justify-content:space-between}
.modal-title{font-family:var(--font-head);font-size:1.4rem;font-weight:800;color:var(--navy)}
.modal-close{width:32px;height:32px;border-radius:50%;background:var(--smoke);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--muted);transition:var(--transition)}
.modal-close:hover{background:var(--border);color:var(--slate)}
.modal-body{padding:24px 28px 28px}
.modal-tabs{display:flex;gap:4px;background:var(--smoke);border-radius:10px;padding:4px;margin-bottom:28px}
.modal-tab{flex:1;padding:9px;text-align:center;border-radius:8px;font-size:.875rem;font-weight:600;color:var(--muted);border:none;background:none;cursor:pointer;transition:var(--transition)}
.modal-tab.active{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted);font-size:.875rem}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.social-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;border:2px solid var(--border);border-radius:var(--radius);background:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);color:var(--slate)}
.social-btn:hover{border-color:var(--teal);background:var(--teal-light)}
.form-check{display:flex;align-items:flex-start;gap:10px;margin-top:4px}
.form-check input{margin-top:2px;accent-color:var(--teal)}
.form-check label{font-size:.875rem;color:var(--muted);cursor:pointer}
.form-check a{color:var(--teal)}
.alert{padding:12px 16px;border-radius:var(--radius);font-size:.875rem;font-weight:500;margin-bottom:16px}
.alert-error{background:#FFF0F0;color:var(--error);border:1px solid #FFD0D0}
.alert-success{background:#F0FFF4;color:var(--success);border:1px solid #B3F0CC}
.alert-info{background:var(--teal-light);color:var(--teal-dark);border:1px solid rgba(0,180,180,.25)}

/* ===== DASHBOARD ===== */
.dashboard-page{display:none;min-height:100vh;padding-top:80px;background:var(--smoke)}
.dashboard-header{background:var(--navy);padding:32px 0;color:#fff}
.dashboard-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;padding:32px 0;align-items:start}
.dashboard-sidebar{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;position:sticky;top:100px}
.dashboard-user{padding:24px;border-bottom:1px solid var(--border);text-align:center}
.dash-avatar{width:64px;height:64px;background:linear-gradient(135deg,var(--teal),var(--teal-dark));border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:1.4rem;font-weight:800;color:#fff;margin:0 auto 12px}
.dash-name{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--navy)}
.dash-email{font-size:.8125rem;color:var(--muted)}
.dash-points{display:inline-flex;align-items:center;gap:6px;background:var(--gold-light);color:var(--gold);padding:4px 10px;border-radius:20px;font-size:.8125rem;font-weight:700;margin-top:8px}
.dash-nav{padding:12px 0}
.dash-nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px;font-size:.9rem;font-weight:500;color:var(--slate);cursor:pointer;transition:var(--transition);border-left:3px solid transparent}
.dash-nav-item:hover{background:var(--smoke);color:var(--teal)}
.dash-nav-item.active{background:var(--teal-light);color:var(--teal);border-left-color:var(--teal);font-weight:600}
.dash-nav-icon{font-size:1.1rem}
.dash-content{display:flex;flex-direction:column;gap:24px}
.dash-panel{background:#fff;border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm)}
.dash-panel-title{font-family:var(--font-head);font-weight:700;font-size:1.1rem;color:var(--navy);margin-bottom:24px;padding-bottom:14px;border-bottom:2px solid var(--border)}
.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.dash-stat-card{background:var(--smoke);border-radius:var(--radius);padding:20px;text-align:center}
.dash-stat-num{font-family:var(--font-head);font-size:1.75rem;font-weight:800;color:var(--navy)}
.dash-stat-label{font-size:.8125rem;color:var(--muted);margin-top:4px}
.booking-list-item{display:flex;align-items:center;gap:16px;padding:16px;border:2px solid var(--border);border-radius:var(--radius);transition:var(--transition);cursor:pointer}
.booking-list-item:hover{border-color:var(--teal);background:var(--teal-light)}
.booking-list-item + .booking-list-item{margin-top:10px}
.bli-route{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--navy);flex:1}
.bli-date{font-size:.8125rem;color:var(--muted)}
.bli-status{padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700}
.status-confirmed{background:#E8FBF0;color:var(--success)}
.status-pending{background:var(--gold-light);color:var(--gold)}
.status-cancelled{background:#FFF0F0;color:var(--error)}
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.profile-full{grid-column:1/-1}

/* ===== FOOTER ===== */
.footer{background:var(--navy);color:rgba(255,255,255,.7);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand .logo{margin-bottom:16px}
.footer-desc{font-size:.875rem;line-height:1.7;max-width:280px;margin-bottom:20px}
.footer-contact p{display:flex;align-items:center;gap:8px;font-size:.875rem;margin-bottom:8px}
.footer-heading{font-family:var(--font-head);font-weight:700;font-size:.9375rem;color:#fff;margin-bottom:16px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:.875rem;color:rgba(255,255,255,.6);transition:var(--transition)}
.footer-links a:hover{color:var(--teal)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:gap}
.footer-bottom-text{font-size:.8125rem}
.footer-badges{display:flex;gap:8px;flex-wrap:wrap}
.footer-badge{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.7);padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:500}
.social-links{display:flex;gap:10px;margin-top:16px}
.social-link{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);font-size:.9rem;transition:var(--transition)}
.social-link:hover{background:var(--teal);color:#fff}

/* ===== WHY CHOOSE ===== */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:24px}
.feature-card{padding:28px;border-radius:var(--radius-lg);background:#fff;border:2px solid transparent;transition:var(--transition);box-shadow:var(--shadow-sm)}
.feature-card:hover{border-color:var(--teal);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.feature-icon{width:52px;height:52px;background:var(--teal-light);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:18px}
.feature-title{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--navy);margin-bottom:8px}
.feature-desc{font-size:.875rem;color:var(--muted);line-height:1.6}

/* ===== AIRLINES STRIP ===== */
.airlines-strip{padding:40px 0;border-bottom:1px solid var(--border)}
.airlines-title{text-align:center;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:28px}
.airlines-logos{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.airline-pill{padding:8px 20px;background:var(--smoke);border:1px solid var(--border);border-radius:100px;font-family:var(--font-head);font-weight:700;font-size:.9rem;color:var(--slate);transition:var(--transition)}
.airline-pill:hover{background:var(--teal-light);border-color:var(--teal);color:var(--teal)}

/* ===== TOAST ===== */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.toast{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:14px 18px;display:flex;align-items:center;gap:12px;min-width:280px;max-width:360px;animation:slideIn .3s ease;pointer-events:all;border-left:4px solid var(--teal)}
.toast.error{border-left-color:var(--error)}
.toast.success{border-left-color:var(--success)}
.toast-icon{font-size:1.2rem}
.toast-text{flex:1;font-size:.875rem;font-weight:500;color:var(--slate)}
.toast-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1rem;line-height:1;padding:2px}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ===== LOADING OVERLAY ===== */
.page-loader{position:fixed;inset:0;background:rgba(255,255,255,.9);z-index:1500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:.3s}
.page-loader.show{opacity:1;pointer-events:all}
.page-loader .logo{color:var(--navy)}
.loader-plane{font-size:2.5rem;animation:fly 1s ease-in-out infinite alternate}
@keyframes fly{from{transform:translateX(-20px) rotate(-5deg)}to{transform:translateX(20px) rotate(5deg)}}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .results-layout{grid-template-columns:1fr}
  .filters-panel{position:static;display:none}
  .filters-panel.show{display:block}
  .booking-layout{grid-template-columns:1fr}
  .order-summary{position:static}
  .confirm-layout{grid-template-columns:1fr}
  .dashboard-layout{grid-template-columns:1fr}
  .dashboard-sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .search-row-4{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links,.nav-actions .btn-outline{display:none}
  .hamburger{display:flex}
  .hero h1{font-size:2rem}
  .search-row-4,.search-row-3,.search-row-2{grid-template-columns:1fr}
  .origin-dest-wrap{grid-template-columns:1fr}
  .swap-btn{display:none}
  .flight-card-inner{grid-template-columns:1fr;gap:12px}
  .flight-price-section{text-align:left}
  .pax-form-grid{grid-template-columns:1fr}
  .payment-methods{grid-template-columns:1fr 1fr}
  .progress-bar{overflow-x:auto}
  .progress-step::after{display:none}
  .ticket-details-grid{grid-template-columns:1fr 1fr}
  .dash-stats{grid-template-columns:1fr 1fr}
  .profile-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .container{padding:0 16px}
  .section{padding:56px 0}
  .payment-methods{grid-template-columns:1fr}
  .ticket-details-grid{grid-template-columns:1fr}
  .search-card{padding:20px}
  .booking-section{padding:20px}
  .hero{padding:90px 0 40px}
}

/* ===== INTERACTIVE ENHANCEMENTS ===== */
/* Pulse animation on search button */
.btn-search-pulse{animation:searchPulse 2s ease-in-out infinite}
@keyframes searchPulse{0%,100%{box-shadow:0 0 0 0 rgba(0,180,180,.4)}50%{box-shadow:0 0 0 10px rgba(0,180,180,0)}}

/* Flight card hover lift */
.flight-card{transition:transform .2s ease, box-shadow .2s ease}
.flight-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.12)!important}
.flight-card.selected{border:2px solid var(--teal)!important;background:linear-gradient(135deg,rgba(0,180,180,.03),#fff)!important}

/* Search form polish */
.form-control:focus{border-color:var(--teal);box-shadow:0 0 0 4px rgba(0,180,180,.12);transform:none}
.airport-input-wrap .form-control{padding-left:44px;font-weight:500}
.airport-input-wrap .form-control::placeholder{color:var(--muted);font-weight:400}

/* Mobile search card stacking */
@media(max-width:640px){
  .origin-dest-wrap{grid-template-columns:1fr!important;gap:12px}
  .search-row-3{grid-template-columns:1fr!important}
  .search-row-4{grid-template-columns:1fr 1fr!important}
  .swap-btn{display:none!important}
  .search-card{padding:20px 16px;border-radius:16px}
  .search-tabs{gap:2px}
  .search-tab{font-size:.78rem;padding:8px 6px}
  .hero h1{font-size:1.85rem}
  .hero-sub{font-size:.9375rem}
  .hero-stats{gap:20px}
  .hero-stat-num{font-size:1.4rem}
  .autocomplete-list{border-radius:12px;max-height:240px}
}

/* Smooth page transitions */
#homePage,#resultsPage,#bookingPage,#confirmationPage,#dashboardPage{
  animation:pageFade .25s ease
}
@keyframes pageFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Better mobile navbar */
@media(max-width:768px){
  .navbar-inner{padding:0 16px}
  .logo{font-size:1.3rem}
  .logo-icon{width:32px;height:32px;font-size:1.05rem}
}

/* Date input styling */
input[type=date].form-control{cursor:pointer;color-scheme:light}

/* Pax dropdown polish */
.pax-display{border-radius:var(--radius);font-weight:500}
.pax-display:focus,.pax-display:hover{border-color:var(--teal)}

/* Filter sidebar on mobile */
@media(max-width:900px){
  .results-layout{grid-template-columns:1fr!important}
  .filters-sidebar{display:none}
  .results-layout.filters-open .filters-sidebar{display:block}
}

/* Better booking steps on mobile */
@media(max-width:600px){
  .progress-step span{display:none}
  .progress-step{min-width:40px}
  .booking-layout{grid-template-columns:1fr!important}
}

/* Smooth autocomplete highlight */
.autocomplete-item{position:relative;overflow:hidden}
.autocomplete-item::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(0,180,180,.05),transparent);opacity:0;transition:.2s}
.autocomplete-item:hover::after,.autocomplete-item.highlighted::after{opacity:1}

/* Mark tag for search highlighting */
mark{padding:0 2px;border-radius:2px}

/* Touch-friendly targets */
@media(hover:none){
  .autocomplete-item{padding:14px 16px}
  .btn{min-height:44px}
  .form-control{min-height:46px}
}

/* Skeleton loading for flight results */
.flight-skeleton{background:#fff;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:12px}
.skeleton-line{background:linear-gradient(90deg,var(--smoke) 25%,#e8ecf0 50%,var(--smoke) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:6px;height:14px;margin-bottom:10px}
.skeleton-line.w30{width:30%}
.skeleton-line.w50{width:50%}
.skeleton-line.w70{width:70%}
.skeleton-line.w100{width:100%}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ===== MOBILE MENU ===== */
.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:300px;background:var(--navy);z-index:1100;transform:translateX(100%);transition:.3s ease;overflow-y:auto;padding:80px 0 40px}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1099;display:none}
.mobile-menu-overlay.open{display:block}
.mobile-nav-link{display:flex;align-items:center;gap:12px;padding:14px 24px;color:rgba(255,255,255,.8);font-size:.9375rem;font-weight:500;transition:var(--transition)}
.mobile-nav-link:hover{color:#fff;background:rgba(255,255,255,.08)}
.mobile-menu-close{position:absolute;top:16px;right:16px;width:40px;height:40px;background:rgba(255,255,255,.1);border:none;border-radius:50%;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* ===== DESTINATIONS SECTION ===== */
.popular-section{padding:80px 0}
.dest-emoji{position:absolute;top:16px;right:16px;font-size:1.5rem;z-index:2}

/* ===== FOOTER EXTRAS ===== */
.footer-logo{font-family:var(--font-head);font-weight:800;font-size:1.3rem;color:#fff;margin-bottom:12px}
.footer-contact{display:flex;flex-direction:column;gap:6px;font-size:.875rem}
.footer-contact a{color:rgba(255,255,255,.7);transition:var(--transition)}
.footer-contact a:hover{color:var(--teal)}
.footer-col .footer-title{font-family:var(--font-head);font-weight:700;font-size:.9375rem;color:#fff;margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col ul a{font-size:.875rem;color:rgba(255,255,255,.6);transition:var(--transition)}
.footer-col ul a:hover{color:var(--teal)}
.footer-payments{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}
.fp-badge{padding:6px 12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:8px;font-size:.78rem;color:rgba(255,255,255,.7)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:.8125rem;color:rgba(255,255,255,.5)}
.footer-bottom a{color:rgba(255,255,255,.5);transition:var(--transition)}
.footer-bottom a:hover{color:var(--teal)}

/* ===== PAGE HEADERS (for individual pages) ===== */
.page-hero{background:linear-gradient(135deg,var(--navy),#0E2340);padding:120px 0 60px;color:#fff;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-20%;right:-5%;width:500px;height:500px;background:radial-gradient(circle,rgba(0,180,180,.15),transparent 70%);border-radius:50%}
.page-hero h1{font-family:var(--font-head);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;margin-bottom:12px;position:relative;z-index:1}
.page-hero p{color:rgba(255,255,255,.7);font-size:1rem;max-width:560px;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.875rem;color:rgba(255,255,255,.5);margin-bottom:16px;position:relative;z-index:1}
.breadcrumb a{color:rgba(255,255,255,.5);transition:var(--transition)}
.breadcrumb a:hover{color:var(--teal)}
.breadcrumb span{color:rgba(255,255,255,.3)}

/* ===== AUTH PAGES ===== */
.auth-page{min-height:100vh;background:linear-gradient(160deg,var(--navy) 0%,#0E2340 50%,#061828 100%);display:flex;align-items:center;justify-content:center;padding:80px 20px 40px;position:relative;overflow:hidden}
.auth-page::before{content:'';position:absolute;top:-20%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(0,180,180,.15),transparent 70%);border-radius:50%;pointer-events:none}
.auth-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:40px;width:100%;max-width:480px;position:relative;z-index:1}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo .logo{justify-content:center;font-size:1.3rem}
.auth-title{font-family:var(--font-head);font-size:1.6rem;font-weight:800;color:var(--navy);margin-bottom:6px;text-align:center}
.auth-sub{color:var(--muted);font-size:.9rem;text-align:center;margin-bottom:28px}
.auth-switch{text-align:center;margin-top:20px;font-size:.875rem;color:var(--muted)}
.auth-switch a{color:var(--teal);font-weight:600}
.form-control.error{border-color:var(--error)}

/* ===== FLIGHTS RESULTS PAGE ===== */
.flights-page{padding-top:80px;min-height:100vh;background:var(--smoke)}
.flights-header{background:var(--navy);padding:28px 0}
.flights-body{padding:32px 0}
.mobile-filter-toggle{display:none;background:var(--teal);color:#fff;border:none;border-radius:var(--radius);padding:10px 18px;font-size:.875rem;font-weight:600;cursor:pointer;margin-bottom:16px}
@media(max-width:900px){.mobile-filter-toggle{display:block}.results-layout{grid-template-columns:1fr}.filters-panel{display:none}.filters-panel.show{display:block}}

/* ===== BOOKING PAGE STANDALONE ===== */
.booking-page-wrap{padding-top:80px;min-height:100vh;background:var(--smoke)}

/* ===== DASHBOARD STANDALONE ===== */  
.dash-page-wrap{padding-top:80px;min-height:100vh;background:var(--smoke)}

/* ===== MOBILE MENU ===== */
.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:300px;background:var(--navy);z-index:1100;transform:translateX(100%);transition:.3s ease;overflow-y:auto;padding:80px 0 40px}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1099;display:none}
.mobile-menu-overlay.open{display:block}
.mobile-nav-link{display:flex;align-items:center;gap:12px;padding:14px 24px;color:rgba(255,255,255,.8);font-size:.9375rem;font-weight:500;transition:var(--transition)}
.mobile-nav-link:hover{color:#fff;background:rgba(255,255,255,.08)}
.mobile-menu-close{position:absolute;top:16px;right:16px;width:40px;height:40px;background:rgba(255,255,255,.1);border:none;border-radius:50%;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* ===== SKELETON ===== */
.flight-skeleton{background:#fff;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:12px}
.skeleton-line{background:linear-gradient(90deg,var(--smoke) 25%,#e8ecf0 50%,var(--smoke) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:6px;height:14px;margin-bottom:10px}
.skeleton-line.w30{width:30%}.skeleton-line.w50{width:50%}.skeleton-line.w70{width:70%}.skeleton-line.w100{width:100%}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

mark{padding:0 2px;border-radius:2px;background:rgba(0,180,180,.2);color:var(--teal);font-weight:700}
@media(hover:none){.autocomplete-item{padding:14px 16px}.btn{min-height:44px}.form-control{min-height:46px}}
