:root{
    --dfd-navy:#07172f;
    --dfd-navy-2:#0b2346;
    --dfd-blue:#145da0;
    --dfd-sky:#38bdf8;
    --dfd-yellow:#fbbf24;
    --dfd-yellow-2:#f59e0b;
    --dfd-text:#101b31;
    --dfd-muted:#64748b;
    --dfd-bg:#f4f7fb;
    --dfd-white:#ffffff;
    --dfd-border:#dfe7f2;
    --dfd-shadow:0 22px 55px rgba(7,23,47,.10);
}

*{box-sizing:border-box}

.dfd-home{
  font-family:inherit;
  background:#fbfaf7;
  color:#111827;
  overflow:hidden;
}

.home-container{
  width:min(1200px,calc(100% - 32px));
  margin:0 auto;
}

.home-hero{
  position:relative;
  padding:72px 0 74px;
  background:var(--dfd-navy);
  overflow:hidden;
}

.home-hero-bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

.home-hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(6,23,46,.92),rgba(6,23,46,.78),rgba(6,23,46,.58));
}

.hero-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,1fr) 500px;
  gap:48px;
  align-items:center;
}

.hero-copy{
  color:#fff;
}

.hero-badge,
.eyebrow,
.section-intro span,
.steps-head span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--dfd-blue);
}

.hero-badge{
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:#dbeafe;
  text-transform:none;
  letter-spacing:0;
  font-size:12px;
}

.hero-copy h1{
  max-width:600px;
  margin:22px 0 18px;
  font-size:44px;
  line-height:1.08;
  letter-spacing:-.6px;
  font-weight:800;
}

.hero-copy h1 span{
  display:block;
  color:var(--dfd-yellow);
}

.hero-copy p{
  max-width:610px;
  margin:0;
  color:#d8dee8;
  font-size:16px;
  line-height:1.75;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:30px;
}

.dfd-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  min-height:48px;
  padding:0 24px;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  font-size:16px;
  transition:.18s ease;
}

.dfd-btn-yellow,
.talk-btn{
  background:var(--dfd-yellow);
  color:var(--dfd-navy);
}

.dfd-btn-yellow:hover,
.talk-btn:hover{
  background:#fff;
  color:var(--dfd-navy);
}

.dfd-btn-light{
  background:transparent;
  color:#fff;
  border:1px solid rgba(255,255,255,.34);
}

.dfd-btn-light:hover{
  background:#fff;
  color:var(--dfd-navy);
  border-color:#fff;
}

.trust-row{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  margin-top:26px;
  margin-bottom:20px;
  color:#dbeafe;
  font-size:15px;
}

.trust-row i{
  color:var(--dfd-yellow);
}

.hero-feature-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}

.hero-feature-grid div{
  padding:14px;
  border-radius:12px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.13);
}

.hero-feature-grid strong{
  display:block;
  color:#fff;
  font-size:18px;
  margin-bottom:5px;
}

.hero-feature-grid span{
  display:block;
  color:#cbd5e1;
  font-size:15px;
  line-height:1.5;
}

@media (max-width:768px){

  .hero-feature-grid{
    grid-template-columns:repeat(3,1fr);
    gap:8px;
  }

  .hero-feature-grid div{
    padding:10px 8px;
    text-align:center;
    min-height:90px;
    display:flex;
    flex-direction:column;
    justify-content:center;
  }

  .hero-feature-grid strong{
    font-size:15px;
    margin-bottom:3px;
  }

  .hero-feature-grid span{
    font-size:11px;
    line-height:1.3;
  }
	.trust-row{
		font-size:11px;
	}
}
.flight-form-card{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:26px;
  box-shadow:0 22px 55px rgba(0,0,0,.16);
}

.flight-form-card h2{
  margin:0;
  color:var(--dfd-text);
  font-size:26px;
  line-height:1.15;
  font-weight:800;
}

.flight-form-card>p{
  margin:6px 0 0;
  color:var(--dfd-muted);
  font-size:15px;
}

.trip-tabs{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin:20px 0 18px;
  padding:6px;
  background:#f1f5f9;
  border-radius:14px;
}

.trip-tab{
  border:0;
  background:transparent;
  color:#64748b;
  font-size:14px;
  font-weight:800;
  padding:12px 8px;
  border-radius:11px;
  cursor:pointer;
  transition:.25s ease;
}

.trip-tab.active{
  background:var(--dfd-blue);
  color:#fff;
  box-shadow:0 8px 20px rgba(30,107,255,.24);
}

.flight-form{
  margin-top:0;
}

.form-grid,
.multi-row{
  display:grid;
  gap:14px;
}

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

.multi-row{
  grid-template-columns:repeat(3,1fr);
  margin-bottom:12px;
}

.form-field{
  height:56px;
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid #dbe3ef;
  border-radius:10px;
  padding:0 14px;
  background:#fff;
  transition:.18s ease;
}

.form-field:focus-within{
  border-color:var(--dfd-blue);
  box-shadow:0 0 0 3px rgba(30,107,255,.12);
}

.form-field i{
  color:#64748b;
  font-size:16px;
  min-width:18px;
}

.form-field input,
.form-field select{
  width:100%;
  height:100%;
  border:0;
  outline:0;
  background:transparent;
  font-size:15px;
  font-weight:700;
  color:#0f172a;
  padding:0;
}

.form-field input::placeholder{
  color:#9ca3af;
}

.multi-city-wrap{
  display:none;
  margin-top:14px;
}

.multi-city-wrap.active{
  display:block;
}

.main-trip-fields.is-hidden{
  display:none;
}

.add-city-btn{
  width:100%;
  height:46px;
  border:1px dashed var(--dfd-blue);
  background:#eef6ff;
  color:var(--dfd-blue);
  border-radius:10px;
  font-size:15px;
  font-weight:800;
  cursor:pointer;
  margin-bottom:14px;
}

.search-flight-btn,
.talk-btn{
  width:100%;
  height:60px;
  border:0;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-size:17px;
  font-weight:900;
  text-decoration:none;
  cursor:pointer;
}

.search-flight-btn{
  background:var(--dfd-blue);
  color:#fff;
  margin-top:18px;
}

.search-flight-btn:hover{
  background:var(--dfd-navy);
}

.form-or{
  text-align:center;
  color:#94a3b8;
  font-weight:900;
  margin:16px 0;
}

.form-note{
  text-align:center;
  color:#94a3b8;
  font-size:14px;
  font-weight:700;
  margin:14px 0 0!important;
}

.flight-success-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  background:rgba(6,23,46,.78);
}

.flight-success-modal.hidden{
  display:none;
}

.success-box{
  width:100%;
  max-width:560px;
  background:#fff;
  border-radius:22px;
  padding:34px;
  text-align:center;
  position:relative;
}

.success-close{
  position:absolute;
  right:18px;
  top:16px;
  width:38px;
  height:38px;
  border:0;
  border-radius:50%;
  background:#f1f5f9;
  color:#64748b;
  font-size:24px;
  cursor:pointer;
}

.success-icon{
  width:78px;
  height:78px;
  border-radius:22px;
  background:#eef6ff;
  color:var(--dfd-blue);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 22px;
  font-size:30px;
}

.success-box h3{
  margin:0;
  font-size:34px;
  line-height:1.18;
  color:var(--dfd-text);
  font-weight:800;
}

.success-box h3 span{
  display:block;
  color:var(--dfd-yellow);
}

.success-box p{
  max-width:430px;
  margin:18px auto 0;
  color:#64748b;
  line-height:1.7;
}

.success-status{
  margin:22px auto 0;
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:14px;
  padding:13px 18px;
  color:#64748b;
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
}

.success-status span{
  width:8px;
  height:8px;
  border-radius:50%;
  background:#22c55e;
}

.success-call{
  margin-top:24px;
  min-height:54px;
  border-radius:999px;
  padding:0 18px 0 24px;
  background:var(--dfd-navy);
  color:#fff;
  text-decoration:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-weight:800;
}

.success-call i{
  width:40px;
  height:40px;
  border-radius:50%;
  background:#fff;
  color:var(--dfd-navy);
  display:flex;
  align-items:center;
  justify-content:center;
}

.airline-section,
.destinations-section,
.essential-section,
.steps-section,
.faq-section{
  padding:72px 0;
}

.airline-section{
  background:#fbfaf7;
}

.destinations-section{
  background:#f3f7fb;
}

.section-intro{
  max-width:760px;
  margin-bottom:34px;
}

.section-intro.wide{
  max-width:820px;
}

.section-intro h2,
.essential-header h2,
.faq-section h2{
  margin:12px 0 0;
  font-size:34px;
  line-height:1.15;
  letter-spacing:-.2px;
  color:var(--dfd-text);
  font-weight:800;
}

.section-intro h2 strong{
  display:block;
  color:var(--dfd-blue);
}
.section-intro h2:after {
    content: "";
    display: block;
    width: 84px;
    height: 4px;
    border-radius: 10px;
    margin-top: 17px;
    background: var(--dfd-yellow);
}
.section-intro p{
  margin:16px 0 0;
  color:#64748b;
  font-size:16px;
  line-height:1.7;
}

.airline-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}

.airline-card{
  display:block;
  text-decoration:none;
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:12px;
  overflow:hidden;
  transition:.18s ease;
}

.airline-card:hover{
  border-color:#cbd5e1;
  transform:translateY(-3px);
}

.card-image-wrap{
  width:100%;
  height:200px;
  overflow:hidden;
  background:#f8fafc;
}

.card-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.card-content{
  padding:18px 18px 20px;
}

.badge{
  display:inline-block;
  font-size:11px;
  font-weight:800;
  color:var(--dfd-blue);
  background:#eef6ff;
  border:1px solid #d8e8ff;
  padding:5px 10px;
  border-radius:999px;
  margin-bottom:12px;
}

.card-content h3{
  margin:0 0 10px;
  font-size:22px;
  line-height:1.3;
  font-weight:800;
  color:var(--dfd-text);
}

.card-content p{
  margin:0;
  font-size:15px;
  line-height:1.7;
  color:#64748b;
}

.section-cta,
.ess-btn{
  margin-top:34px;
  text-align:center;
}

.destination-slider-wrap{
  position:relative;
  margin-top:38px;
  padding:0 8px;
}

.destination-slider{
  overflow:hidden;
}

.destination-track{
  display:flex;
  transition:transform .45s ease;
}

.destination-slide{
  flex:0 0 auto;
  width:33.333%;
  padding:0 10px;
}

.destination-card{
  position:relative;
  overflow:hidden;
  border-radius:14px;
  min-height:390px;
  background:var(--dfd-navy);
}

.destination-card img{
  width:100%;
  height:390px;
  object-fit:cover;
  display:block;
}

.destination-card:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(6,23,46,.82),rgba(6,23,46,.1));
}

.destination-content{
  position:absolute;
  inset:0;
  z-index:2;
  color:#fff;
  padding:24px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}

.destination-content>span{
  position:absolute;
  top:20px;
  left:20px;
  font-size:14px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  padding:7px 12px;
  border-radius:999px;
}

.destination-content p{
  margin:0 0 9px;
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--dfd-sky);
  font-weight:800;
}

.destination-content h3{
  margin:0 0 8px;
  font-size:29px;
  color:#fff;
}

.destination-content small{
  font-size:15px;
  line-height:1.6;
  color:#dbeafe;
}

.destination-content div{
  margin-top:18px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
}

.destination-content strong{
  color:var(--dfd-yellow);
}

.destination-nav{
  position:absolute;
  top:50%;
  z-index:5;
  width:44px;
  height:44px;
  border:0;
  border-radius:50%;
  background:var(--dfd-navy);
  color:#fff;
  font-size:28px;
  cursor:pointer;
  transform:translateY(-50%);
}

.destination-prev{
  left:-4px;
}

.destination-next{
  right:-4px;
}

.destination-dots{
  margin-top:24px;
  display:flex;
  justify-content:center;
  gap:8px;
}

.destination-dot{
  width:9px;
  height:9px;
  border:0;
  border-radius:50%;
  background:#cbd5e1;
  cursor:pointer;
}

.destination-dot.is-active{
  width:28px;
  border-radius:999px;
  background:var(--dfd-blue);
}

.essential-header{
  text-align:center;
  margin:0 auto 48px;
}

.essential-header .eyebrow{
  margin-bottom:12px;
}

.essential-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:30px;
  align-items:start;
}

.essential-image,
.faq-image{
  position:relative;
  border-radius:14px;
  overflow:hidden;
}

.essential-image img{
  width:100%;
  height:500px;
  object-fit:cover;
  display:block;
}

.image-pill{
  position:absolute;
  left:18px;
  bottom:18px;
  background:#fff;
  color:var(--dfd-text);
  border-radius:20px;
  padding:9px 14px;
  font-size:14px;
  font-weight:800;
}

.essential-cards{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.essential-cards div{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:12px;
  padding:22px;
}

.essential-cards h3{
  margin:0 0 9px;
  font-size:20px;
  color:var(--dfd-text);
  font-weight:800;
}

.essential-cards p{
  margin:0;
  color:#64748b;
  font-size:14px;
  line-height:1.7;
}

.steps-section{
  background:linear-gradient(135deg,var(--dfd-navy),var(--dfd-navy-2));
  color:#fff;
}

.steps-head{
  max-width:820px;
  margin:0 auto;
  text-align:center;
}

.steps-head span{
  color:var(--dfd-sky);
}

.steps-head h2{
  margin:14px 0 0;
  color:#fff;
  font-size:40px;
  line-height:1.15;
  font-weight:800;
}

.steps-head p{
  color:#dbeafe;
  line-height:1.7;
  margin:16px auto 0;
  max-width:720px;
}

.steps-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:42px;
}

.step-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:26px;
}

.step-card div{
  width:48px;
  height:48px;
  border-radius:8px;
  background:rgba(57,189,248,.16);
  color:var(--dfd-sky);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:20px;
}

.step-card h3{
  margin:10px 0 0;
  color:#fff;
  font-size:24px;
  font-weight:700;
}

.step-card p{
  margin:13px 0 0;
  color:#dbeafe;
  line-height:1.75;
  font-size:15px;
}

.faq-section{
  background:#fff;
}

.faq-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:54px;
  align-items:start;
}

.faq-image{
  margin-top:28px;
}

.faq-image img{
  width:100%;
  height:340px;
  object-fit:cover;
  display:block;
}

.faq-list{
  display:grid;
  gap:16px;
}

.faq-item{
  border:1px solid #e2e8f0;
  border-radius:10px;
  background:#fff;
  overflow:hidden;
}

.faq-question{
  width:100%;
  border:0;
  background:#fff;
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  text-align:left;
  cursor:pointer;
  color:var(--dfd-text);
  font-size:16px;
  font-weight:800;
}

.faq-icon{
  color:var(--dfd-blue);
  transition:.25s ease;
}

.faq-answer{
  max-height:0;
  overflow:hidden;
  opacity:0;
  padding:0 18px;
  color:#64748b;
  font-size:15px;
  line-height:1.7;
  transition:.25s ease;
}

.faq-item.active .faq-answer{
  max-height:260px;
  opacity:1;
  padding:0 18px 18px;
}

.faq-item.active .faq-icon{
  transform:rotate(45deg);
}

@media(max-width:1100px){
  .hero-grid,
  .essential-grid,
  .faq-grid{
    grid-template-columns:1fr;
  }

  .flight-form-card{
    max-width:640px;
  }

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

  .destination-slide{
    width:50%;
  }
}

@media(max-width:768px){
  .home-container{
    width:min(100% - 24px,1200px);
  }

  .home-hero{
    padding:48px 0;
  }

  .home-hero-overlay{
    background:rgba(6,23,46,.86);
  }

  .hero-copy h1{
    font-size:32px;
  }

  .hero-copy p{
    font-size:15px;
  }

  .form-grid,
  .multi-row,
  .airline-grid,
  .steps-grid,
  .essential-cards{
    grid-template-columns:1fr;
  }

  .flight-form-card{
    padding:20px;
  }

  .form-field{
    height:54px;
  }

  .section-intro h2,
  .essential-header h2,
  .faq-section h2{
    font-size:28px;
  }

  .destination-slide{
    width:100%;
  }

  .destination-card,
  .destination-card img{
    height:390px;
    min-height:390px;
  }

  .destination-nav{
    display:none;
  }

  .essential-image img{
    height:360px;
  }

  .steps-head h2{
    font-size:30px;
  }

  .airline-section,
  .destinations-section,
  .essential-section,
  .steps-section,
  .faq-section{
    padding:52px 0;
  }

  .card-image-wrap{
    height:210px;
  }

  .faq-question{
    font-size:16px;
  }
}

