/* ============================================================
   FIRSTCLASS TRAVEL — Global CSS v2
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap');
:root {
  --orange:#F26522; --orange-light:#FF8A4C; --orange-dark:#D4541A;
  --navy:#1B2A6B; --navy-light:#253680; --navy-dark:#111C4E;
  --white:#FFFFFF; --gray-50:#F9FAFB; --gray-100:#F3F4F6; --gray-200:#E5E7EB;
  --gray-300:#D1D5DB; --gray-500:#6B7280; --gray-700:#374151; --gray-800:#1F2937;
  --success:#10B981; --warning:#F59E0B; --danger:#EF4444; --info:#3B82F6;
  --shadow-sm:0 1px 3px rgba(0,0,0,.07); --shadow-md:0 4px 20px rgba(0,0,0,.10);
  --shadow-lg:0 20px 60px rgba(0,0,0,.15); --shadow-orange:0 8px 30px rgba(242,101,34,.30);
  --radius:16px; --radius-sm:10px; --transition:all .25s cubic-bezier(.4,0,.2,1);
  --navbar-h:70px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--gray-800);background:#fff;overflow-x:hidden;line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4,h5{font-family:'Poppins',sans-serif;line-height:1.15}
ul{list-style:none}
button,input,select,textarea{font-family:inherit}

/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--navbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 5%;background:transparent;transition:background .4s,box-shadow .4s}
.navbar.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(20px);box-shadow:0 2px 20px rgba(0,0,0,.08)}
.navbar.solid{background:var(--navy-dark)}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-logo img{height:44px;width:auto}
.nav-logo-text{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.3rem;color:white}
.nav-logo-text .orange{color:var(--orange)}
.navbar.scrolled .nav-logo-text{color:var(--navy)}
.nav-menu{display:flex;align-items:center;gap:32px}
.nav-menu a{font-size:.9rem;font-weight:500;color:rgba(255,255,255,.9);transition:var(--transition);position:relative;padding-bottom:2px}
.nav-menu a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--orange);transition:width .3s}
.nav-menu a:hover::after,.nav-menu a.active::after{width:100%}
.nav-menu a:hover{color:var(--orange-light)}
.navbar.scrolled .nav-menu a{color:var(--gray-700)}
.navbar.scrolled .nav-menu a:hover{color:var(--orange)}
.nav-actions{display:flex;gap:10px;align-items:center}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-hamburger span{display:block;width:24px;height:2px;background:white;border-radius:2px;transition:var(--transition)}
.navbar.scrolled .nav-hamburger span,.navbar.solid .nav-hamburger span{background:white}
.nav-drawer{position:fixed;top:var(--navbar-h);left:0;right:0;bottom:0;background:var(--navy-dark);z-index:999;padding:24px 5%;flex-direction:column;gap:0;transform:translateX(-100%);transition:transform .35s ease;display:flex}
.nav-drawer.open{transform:translateX(0)}
.nav-drawer a{font-size:1.05rem;font-weight:600;color:rgba(255,255,255,.85);padding:16px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.nav-drawer a:hover{color:var(--orange)}
.nav-drawer .drawer-actions{padding-top:24px;display:flex;flex-direction:column;gap:10px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:50px;font-weight:600;font-size:.9rem;cursor:pointer;border:none;transition:var(--transition);white-space:nowrap;font-family:'DM Sans',sans-serif}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 4px 14px rgba(242,101,34,.3)}
.btn-primary:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:var(--shadow-orange)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-light);transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:var(--gray-50);transform:translateY(-2px)}
.btn-outline{background:transparent;border:2px solid rgba(255,255,255,.6);color:#fff}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-outline-dark{background:transparent;border:2px solid var(--gray-300);color:var(--gray-700)}
.btn-outline-dark:hover{border-color:var(--gray-500);background:var(--gray-50)}
.btn-sm{padding:9px 20px;font-size:.82rem}
.btn-lg{padding:16px 40px;font-size:1rem}

/* HERO SLIDER */
.hero-slider{position:relative;height:100vh;min-height:580px;overflow:hidden}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed;opacity:0;transition:opacity 1.2s ease;display:flex;align-items:center}
.slide.active{opacity:1;z-index:1}
.slide::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,rgba(17,28,78,.88) 0%,rgba(17,28,78,.45) 55%,transparent 100%)}
.slide-content{position:relative;z-index:2;padding:0 8%;max-width:720px}
.slide-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(242,101,34,.18);border:1px solid rgba(242,101,34,.4);color:var(--orange-light);padding:6px 16px;border-radius:50px;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:22px;animation:fadeInUp .8s .2s both}
.slide-title{font-size:clamp(2.2rem,6vw,4.2rem);font-weight:800;color:#fff;line-height:1.08;margin-bottom:18px;animation:fadeInUp .8s .4s both}
.slide-title .accent{color:var(--orange)}
.slide-sub{font-size:clamp(.9rem,2vw,1.1rem);color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:34px;max-width:500px;animation:fadeInUp .8s .6s both}
.slide-actions{display:flex;gap:14px;flex-wrap:wrap;animation:fadeInUp .8s .8s both}
.slider-dots{position:absolute;bottom:90px;left:8%;display:flex;gap:10px;z-index:5}
.slider-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:var(--transition);border:none}
.slider-dot.active{background:var(--orange);width:28px;border-radius:4px}
.slider-arrows{position:absolute;bottom:80px;right:5%;z-index:5;display:flex;gap:10px}
.slider-arrow{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:var(--transition);backdrop-filter:blur(10px)}
.slider-arrow:hover{background:var(--orange);border-color:var(--orange)}
.slider-progress{position:absolute;bottom:0;left:0;height:3px;background:var(--orange);transition:width .1s linear;z-index:5}
.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:5;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,.5);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;animation:bounce 2s infinite}
.scroll-hint i{font-size:.9rem}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* SEARCH BOX */
.search-section{position:relative;z-index:10;padding:0 5% 70px;margin-top:-80px}
.search-box{background:#fff;border-radius:20px;box-shadow:0 24px 70px rgba(0,0,0,.13);padding:34px 38px;max-width:1140px;margin:0 auto}
.search-tabs{display:flex;gap:4px;background:var(--gray-100);padding:4px;border-radius:12px;width:fit-content;margin-bottom:26px}
.search-tab{padding:10px 22px;border-radius:10px;border:none;background:transparent;cursor:pointer;font-weight:600;font-size:.88rem;color:var(--gray-500);transition:var(--transition)}
.search-tab.active{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
.search-tab i{margin-right:6px}
.trip-type-row{display:flex;align-items:center;gap:20px;margin-bottom:18px}
.trip-radio{display:flex;align-items:center;gap:7px;cursor:pointer;font-size:.88rem;font-weight:600;color:var(--gray-500)}
.trip-radio input{accent-color:var(--orange);width:16px;height:16px;cursor:pointer}
.trip-radio.selected,.trip-radio input:checked~span{color:var(--navy)}
.search-grid{display:grid;gap:14px;align-items:end}
.search-grid.flights{grid-template-columns:1fr 1fr 1fr 1fr auto}
.search-grid.flights.roundtrip{grid-template-columns:1fr 1fr 1fr 1fr 1fr auto}
.search-grid.hotels{grid-template-columns:1.5fr 1fr 1fr 1fr auto}
.s-field{display:flex;flex-direction:column;gap:6px}
.s-field label{font-size:.7rem;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:5px}
.s-field label i{color:var(--orange)}
.s-field .inp-wrap{position:relative}
.s-field .inp-wrap .ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--gray-400);font-size:.85rem;pointer-events:none}
.s-field input,.s-field select{width:100%;padding:12px 12px 12px 34px;border:2px solid var(--gray-200);border-radius:var(--radius-sm);font-size:.9rem;background:var(--gray-50);color:var(--gray-800);outline:none;transition:var(--transition)}
.s-field input:focus,.s-field select:focus{border-color:var(--orange);background:#fff;box-shadow:0 0 0 3px rgba(242,101,34,.1)}
.btn-search{background:var(--orange);color:#fff;border:none;padding:14px 28px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:8px;transition:var(--transition);white-space:nowrap;align-self:end;height:50px}
.btn-search:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:var(--shadow-orange)}
.swap-btn{background:var(--gray-100);border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;color:var(--orange);font-size:.9rem;display:flex;align-items:center;justify-content:center;align-self:end;margin-bottom:7px;transition:var(--transition);flex-shrink:0}
.swap-btn:hover{background:var(--orange);color:#fff;transform:rotate(180deg)}

/* SECTIONS */
section{padding:90px 5%}
.section-inner{max-width:1280px;margin:0 auto}
.section-header{margin-bottom:52px}
.section-header.centered{text-align:center}
.section-header.centered .section-sub{margin:0 auto}
.section-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--orange);margin-bottom:12px}
.section-eyebrow::before{content:'';width:18px;height:2px;background:var(--orange)}
.section-title{font-size:clamp(1.7rem,3.5vw,2.6rem);font-weight:800;color:var(--navy);margin-bottom:14px}
.section-sub{font-size:.98rem;color:var(--gray-500);max-width:560px;line-height:1.7}

/* DESTINATIONS */
.dest-mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto;gap:18px}
.dest-card{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer}
.dest-card img{width:100%;height:260px;object-fit:cover;transition:transform .6s ease}
.dest-card.big img{height:100%}
.dest-card.big{grid-row:span 2}
.dest-card:hover img{transform:scale(1.07)}
.dest-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(17,28,78,.88) 0%,transparent 55%);transition:var(--transition)}
.dest-card:hover::after{background:linear-gradient(to top,rgba(17,28,78,.95) 0%,rgba(17,28,78,.15) 60%)}
.dest-info{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:22px 18px}
.dest-country{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--orange-light);margin-bottom:4px}
.dest-city{font-size:1.2rem;font-weight:800;color:#fff;font-family:'Poppins',sans-serif}
.dest-price{font-size:.78rem;color:rgba(255,255,255,.65);margin-top:3px}
.dest-badge{position:absolute;top:14px;left:14px;z-index:3;background:var(--orange);color:#fff;padding:4px 12px;border-radius:20px;font-size:.68rem;font-weight:700;text-transform:uppercase}

/* FLIGHT CARDS */
.flights-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}
.flight-card{border:2px solid var(--gray-200);border-radius:var(--radius);padding:24px;transition:var(--transition);cursor:pointer;background:#fff}
.flight-card:hover{border-color:var(--orange);box-shadow:0 12px 40px rgba(242,101,34,.12);transform:translateY(-4px)}
.fc-airline{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.fc-airline-logo{width:38px;height:38px;border-radius:10px;background:var(--gray-100);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--navy);font-size:.82rem}
.fc-airline-name{font-weight:700;color:var(--navy);font-size:.88rem}
.fc-airline-num{font-size:.7rem;color:var(--gray-500)}
.fc-route{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.fc-iata{font-family:'Poppins',sans-serif;font-size:1.5rem;font-weight:800;color:var(--gray-800);line-height:1}
.fc-city-name{font-size:.7rem;color:var(--gray-500);margin-top:3px}
.fc-middle{flex:1;text-align:center}
.fc-duration{font-size:.72rem;font-weight:700;color:var(--gray-500);margin-bottom:4px}
.fc-route-line{display:flex;align-items:center;gap:2px}
.fc-line-bar{flex:1;height:1px;background:var(--gray-300)}
.fc-plane-icon{color:var(--orange);font-size:.82rem}
.fc-stop{font-size:.65rem;color:var(--orange);font-weight:600;margin-top:3px}
.fc-footer{display:flex;align-items:center;justify-content:space-between}
.fc-date{font-size:.78rem;color:var(--gray-500)}
.fc-seats{font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:20px;background:rgba(242,101,34,.08);color:var(--orange)}
.fc-price{font-family:'Poppins',sans-serif;font-size:1.35rem;font-weight:800;color:var(--orange)}
.fc-price-sub{font-size:.68rem;color:var(--gray-500)}

/* PACKAGES */
.packages-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pkg-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);transition:var(--transition);background:#fff}
.pkg-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.pkg-img{position:relative;height:215px;overflow:hidden}
.pkg-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.pkg-card:hover .pkg-img img{transform:scale(1.06)}
.pkg-badge{position:absolute;top:14px;left:14px;background:var(--orange);color:#fff;padding:4px 13px;border-radius:20px;font-size:.7rem;font-weight:700}
.pkg-duration{position:absolute;top:14px;right:14px;background:rgba(0,0,0,.5);color:#fff;padding:4px 12px;border-radius:20px;font-size:.7rem;font-weight:600;backdrop-filter:blur(10px)}
.pkg-body{padding:20px}
.pkg-dest{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--orange);margin-bottom:6px}
.pkg-title{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:12px}
.pkg-features{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.pkg-feat{display:flex;align-items:center;gap:5px;font-size:.74rem;color:var(--gray-500)}
.pkg-feat i{color:var(--orange);font-size:.7rem}
.pkg-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--gray-100)}
.pkg-price .from{font-size:.68rem;color:var(--gray-500);display:block}
.pkg-price .amount{font-family:'Poppins',sans-serif;font-size:1.25rem;font-weight:800;color:var(--navy)}
.pkg-price .per{font-size:.7rem;color:var(--gray-500)}

/* STATS */
.stats-section{background:linear-gradient(135deg,var(--navy-dark),var(--navy));padding:80px 5%}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;max-width:1000px;margin:0 auto;text-align:center}
.stat-number{font-family:'Poppins',sans-serif;font-size:clamp(2rem,5vw,3.2rem);font-weight:800;color:var(--orange);line-height:1}
.stat-suffix{color:var(--orange)}
.stat-label{font-size:.85rem;color:rgba(255,255,255,.55);margin-top:8px;font-weight:500}

/* FEATURES */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.feature-card{padding:34px 26px;border-radius:var(--radius);background:#fff;border:2px solid transparent;transition:var(--transition);text-align:center;box-shadow:var(--shadow-sm)}
.feature-card:hover{border-color:var(--orange);transform:translateY(-6px);box-shadow:var(--shadow-md)}
.feature-icon{width:72px;height:72px;border-radius:20px;margin:0 auto 20px;background:linear-gradient(135deg,var(--orange),var(--orange-light));display:flex;align-items:center;justify-content:center;font-size:1.7rem;color:#fff}
.feature-card h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:10px}
.feature-card p{font-size:.86rem;color:var(--gray-500);line-height:1.65}

/* PARALLAX */
.parallax-section{position:relative;min-height:460px;display:flex;align-items:center;background-attachment:fixed;background-size:cover;background-position:center;overflow:hidden}
.parallax-section::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(17,28,78,.9),rgba(242,101,34,.55))}
.parallax-content{position:relative;z-index:1;padding:80px 8%;max-width:720px}
.parallax-content h2{font-size:clamp(2rem,5vw,2.8rem);font-weight:800;color:#fff;margin-bottom:16px}
.parallax-content p{font-size:1rem;opacity:.82;line-height:1.7;margin-bottom:32px;color:rgba(255,255,255,.85)}

/* TESTIMONIALS */
.testi-wrapper{overflow:hidden;position:relative}
.testi-track{display:flex;transition:transform .5s ease;gap:22px}
.testi-card{min-width:calc(33.333% - 15px);background:var(--gray-50);border-radius:var(--radius);padding:32px;border:1px solid var(--gray-200);flex-shrink:0}
.testi-stars{color:var(--orange);margin-bottom:14px;letter-spacing:2px}
.testi-text{font-size:.92rem;color:var(--gray-600);line-height:1.75;margin-bottom:22px;font-style:italic}
.testi-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-light));display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-weight:800;color:#fff;font-size:.88rem;flex-shrink:0}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-name{font-weight:700;color:var(--navy);font-size:.88rem}
.testi-loc{font-size:.74rem;color:var(--gray-500)}
.testi-nav{display:flex;justify-content:center;gap:12px;margin-top:30px}
.testi-btn{width:40px;height:40px;border-radius:50%;border:2px solid var(--gray-200);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-500);transition:var(--transition)}
.testi-btn:hover{border-color:var(--orange);color:var(--orange)}

/* FOOTER */
.footer{background:var(--navy-dark);color:rgba(255,255,255,.62)}
.footer-main{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;padding:76px 5% 56px;max-width:1400px;margin:0 auto}
.footer-brand .logo-text{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.45rem;color:#fff;margin-bottom:14px}
.footer-brand p{font-size:.86rem;line-height:1.75;max-width:300px;margin-bottom:22px}
.footer-col h4{font-family:'Poppins',sans-serif;font-weight:700;color:#fff;margin-bottom:18px;font-size:.88rem;text-transform:uppercase;letter-spacing:.05em}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:.84rem;transition:var(--transition)}
.footer-col ul a:hover{color:var(--orange);padding-left:4px}
.footer-contact li{display:flex;align-items:flex-start;gap:10px;font-size:.84rem;margin-bottom:12px}
.footer-contact li i{color:var(--orange);margin-top:3px;flex-shrink:0;width:14px}
.social-links{display:flex;gap:10px}
.social-link{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-size:.88rem;transition:var(--transition)}
.social-link:hover{background:var(--orange);color:#fff;transform:translateY(-3px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:22px 5%;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;max-width:1400px;margin:0 auto}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700}
.badge-success{background:rgba(16,185,129,.1);color:var(--success)}
.badge-warning{background:rgba(245,158,11,.1);color:var(--warning)}
.badge-danger{background:rgba(239,68,68,.1);color:var(--danger)}
.badge-info{background:rgba(59,130,246,.1);color:var(--info)}
.badge-navy{background:rgba(27,42,107,.1);color:var(--navy)}
.badge-secondary{background:var(--gray-100);color:var(--gray-500)}

/* PAGE HERO */
.page-hero{min-height:300px;display:flex;align-items:flex-end;background-size:cover;background-position:center;background-attachment:fixed;padding:60px 5% 44px;position:relative}
.page-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(17,28,78,.65),rgba(17,28,78,.92))}
.page-hero-inner{position:relative;z-index:1;max-width:1280px;width:100%;margin:0 auto}
.page-hero h1{font-size:clamp(1.8rem,4vw,2.8rem);color:#fff;margin-bottom:10px}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.8rem;color:rgba(255,255,255,.55)}
.breadcrumb a:hover{color:var(--orange)}
.breadcrumb .sep{font-size:.55rem;opacity:.5}

/* FORM */
.form-control{width:100%;padding:12px 14px;border:2px solid var(--gray-200);border-radius:var(--radius-sm);font-size:.92rem;color:var(--gray-800);background:var(--gray-50);outline:none;transition:var(--transition)}
.form-control:focus{border-color:var(--orange);background:#fff;box-shadow:0 0 0 3px rgba(242,101,34,.1)}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:.74rem;font-weight:700;color:var(--gray-700);text-transform:uppercase;letter-spacing:.05em;margin-bottom:7px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* ANIMATIONS */
@keyframes fadeInUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.reveal{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-36px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(36px);transition:opacity .7s ease,transform .7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}.delay-3{transition-delay:.3s}
.delay-4{transition-delay:.4s}.delay-5{transition-delay:.5s}

/* PAGE LOADER */
.page-loader{position:fixed;inset:0;z-index:9999;background:var(--navy-dark);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;transition:opacity .5s,visibility .5s}
.page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-logo{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.8rem;color:#fff}
.loader-logo span{color:var(--orange)}
.loader-bar{width:200px;height:3px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden}
.loader-bar-inner{height:100%;background:var(--orange);border-radius:2px;animation:loadBar 1s ease forwards}
@keyframes loadBar{from{width:0}to{width:100%}}

/* RESPONSIVE */
@media(max-width:1200px){
  .dest-mosaic{grid-template-columns:repeat(3,1fr)}
  .packages-grid{grid-template-columns:repeat(2,1fr)}
  .footer-main{grid-template-columns:1fr 1fr;gap:36px}
  .testi-card{min-width:calc(50% - 11px)}
}
@media(max-width:1024px){
  .search-grid.flights{grid-template-columns:1fr 1fr 1fr}
  .search-grid.flights .btn-search{grid-column:1/-1;width:100%;justify-content:center}
  .search-grid.flights.roundtrip{grid-template-columns:1fr 1fr 1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .features-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  :root{--navbar-h:62px}
  .nav-menu,.nav-actions .btn-outline-dark,.nav-actions .btn-white{display:none}
  .nav-hamburger{display:flex}
  section{padding:60px 5%}
  .search-box{padding:22px 18px}
  .search-grid.flights,.search-grid.flights.roundtrip,.search-grid.hotels{grid-template-columns:1fr}
  .btn-search{width:100%;justify-content:center}
  .dest-mosaic{grid-template-columns:1fr 1fr}
  .dest-card.big{grid-row:span 1}
  .packages-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr;gap:28px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:24px}
  .form-row{grid-template-columns:1fr}
  .slide{background-attachment:scroll}
  .parallax-section{background-attachment:scroll}
  .page-hero{background-attachment:scroll}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  .testi-card{min-width:100%}
}
@media(max-width:480px){
  .hero-slider{min-height:520px}
  .dest-mosaic{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .slide-actions{flex-direction:column}
  .slide-actions .btn{width:100%;justify-content:center}
  .search-tabs{flex-wrap:wrap}
}
