 @import url('/assets/css/flight-filters.css');
 :root{
    --fx-card:#ffffff;
    --fx-soft:#f6f7fb;
    --fx-text:#0f172a;
    --fx-muted:#64748b;
    --fx-border:rgba(15,23,42,.08);
    --fx-shadow:0 18px 50px rgba(15,23,42,.12);
    --fx-shadow2:0 12px 30px rgba(15,23,42,.10);
    --fx-radius:24px;
  }

  .flight-hero{
    background:
      radial-gradient(1200px 400px at 20% 0%, rgba(255,204,0,.18), transparent 60%),
      radial-gradient(900px 380px at 80% 10%, rgba(0,0,0,.12), transparent 55%),
      linear-gradient(120deg, #0b1220, #111827 45%, #0b1220);
    
    position: relative;
  }
  .heroInner {
    background: #ffffff;
    background: linear-gradient(0deg, rgb(249 250 251) 0%, transparent 85%);
	padding: 28px 42px 20px 42px;
}
  .flight-hero:before{
    content:"";
    position:absolute; inset:-2px;
    background:
      url('/assets/img/flights/hero.jpg') center/cover no-repeat;
    opacity:.2;
    filter:saturate(1.2);
  }
  .flight-hero > *{ position:relative; z-index:2; }

  .search-shell{
    background: var(--fx-card);
    border-radius: 26px;
    box-shadow: 0 5px 30px rgba(0,0,0,.12);
    border: 1px solid var(--fx-border);
    padding: 16px;
    position: relative;
    z-index: 5;
	margin-top:20px
  }

  /* Layout */
  .filter-card{
    background: var(--fx-card);
    border-radius: var(--fx-radius);
    border:1px solid rgba(15,23,42,.08);
    box-shadow: var(--fx-shadow2);
    position: sticky;
    top: 16px;
	display:none;
  }
  .filter-card .hd{
    padding: 16px 16px 10px 16px;
    border-bottom: 1px solid rgba(15,23,42,.06);
    font-weight:1000;
  }
  .filter-card .bd{ padding: 14px 16px 16px 16px; }
  .fx-chip{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding: 8px 12px;
    border-radius: 999px;
    border:1px solid rgba(15,23,42,.10);
    background: #fff;
    font-weight:900;
    font-size:12px;
    color:#0f172a;
  }

  .list-shell{
    background: transparent;
  }
  .result-topbar{
    background: var(--fx-card);
    border-radius: var(--fx-radius);
    border:1px solid rgba(15,23,42,.08);
    box-shadow: var(--fx-shadow2);
    padding: 14px 16px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
  }
  .day-strip{
    display:flex;
    gap:8px;
    overflow:auto;
    padding-bottom: 6px;
  }
  .day-pill{
    min-width: 140px;
    border-radius: 16px;
    border:1px solid rgba(15,23,42,.10);
    background:#fff;
    padding: 10px 12px;
    font-weight:1000;
    cursor:pointer;
    transition:.2s;
  }
  .day-pill.active{
    background: rgba(255,204,0,.20);
    border-color: rgba(255,204,0,.60);
  }
  .day-pill .muted{ font-weight:800; font-size:12px; color: var(--fx-muted); }

  .airline-badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #0b1220;
    color:#fff;
    font-weight:1000;
    font-size:12px;
  }
  .price{
    font-weight:1100;
    font-size: 22px;
    color:#0f172a;
  }
  .small-muted{ color: var(--fx-muted); font-weight:800; font-size:12px; }

  .select-btn{
    border-radius: 14px;
    font-weight:1000;
    height:44px;
  }

  .split-title{
    margin: 18px 0 8px 0;
    color:#0f172a;
	background: #ffc106;
    padding: 10px 15px;
    border-radius: 15px;
    font-weight: 900;
  }

  .combo-bar{
    background: #0b1220;
    color:#fff;
    border-radius: 22px;
    padding: 14px 16px;
    box-shadow: var(--fx-shadow);
    position: sticky;
    bottom: 14px;
    margin-top: 18px;
    display:none;
    align-items:center;
    justify-content:space-between;
    gap:12px;
  }
  .combo-bar .btn{
    border-radius: 14px;
    font-weight:1100;
    height:44px;
  }

.col-btn .fx-cta {
  height: 48px;
  font-size: 14px;
  padding: 0 18px;
}

.col-type {
  display: none !important;
}
.ret-wrap {
  position: relative;
}
.ret-clear {
  position:absolute;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  font-weight:900;
  cursor:pointer;
  color:#999;
}
.ret-clear:hover{ color:#000; }
.date-card{
  display:flex;
  align-items:center;
  gap:10px;
}
.date-day{
  font-size:28px;
  font-weight:1000;
}
.date-meta{
  font-size:12px;
  line-height:14px;
  color:#64748b;
}
.form-range::-webkit-slider-thumb {
  background: #ffc106;
}

.form-range::-moz-range-thumb {
  background: #ffc106;
}

.form-range::-ms-thumb {
  background: #ffc106;
}
/* ===============================
   FLIGHT HERO – LIGHT WOW
================================ */
.flight-hero{
  position:relative;
  background:
    radial-gradient(700px 300px at 85% 20%, rgba(59,130,246,.14), transparent 60%),
    radial-gradient(600px 260px at 10% 30%, rgba(14,165,233,.12), transparent 60%),
    linear-gradient(180deg, #ffffff, #f8fafc);
}

.flight-hero-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 14px;
  border-radius:999px;
  background:#0f172a;
  color:#fff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:14px;
}

.flight-hero h1{
  font-size:clamp(28px, 4vw, 40px);
  font-weight:900;
  letter-spacing:-.04em;
  margin-bottom:8px;
  color:#0f172a;
}

.flight-hero-sub{
  font-size:16px;
  color:#475569;
  max-width:720px;
}

.flight-hero-actions{
  margin-top:22px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.flight-hero-chip{
  background:#ffffff;
  border:1px solid rgba(0,0,0,.12);
  border-radius:999px;
  padding:6px 14px;
  font-size:13px;
  font-weight:700;
  color:#0f172a;
  display:inline-flex;
  align-items:center;
  gap:6px;
}

/* decorative plane trail */
.flight-hero::after{
  content:"✈";
  position:absolute;
  right:28px;
  top:22px;
  font-size:42px;
  opacity:.08;
  transform:rotate(-12deg);
}

/* glow bubble */
.flight-hero::before{
  content:"";
  position:absolute;
  right:-80px;
  bottom:-80px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:linear-gradient(135deg, rgba(59,130,246,.25), rgba(14,165,233,.25));
  filter:blur(50px);
}


.heroClouds{
  background-image:url('/assets/img/bulut4.jpg');

  -webkit-animation:clouds 100s infinite linear;
}

@keyframes clouds{
	from{background-position:0 0;}
	to{background-position:-2500px 0;}
}

@-webkit-keyframes clouds{
	from{background-position:0 0;}
	to{background-position:-2500px 0;}
}

@-moz-keyframes clouds{
	from{background-position:0 0;}
	to{background-position:-2500px 0;}
}
.fx-row{ display:flex; justify-content:space-between; align-items:center; margin-bottom:8px }
.fx-airline-logos img{ height:22px; margin-right:6px }
.fx-airline-names{ font-weight:900 }

.fx-route{ align-items:flex-end }
.fx-time strong{ font-size:18px; display:block }
.fx-time span{ font-size:12px; color:#64748b }

.fx-line{ text-align:center; font-weight:800; font-size:12px }
.fx-line small{ display:block; color:#64748b }

.fx-meta{ font-size:12px; color:#64748b }

.fx-roundtrip{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.searchBtn {
    margin-top: 19px;
    height: 55px;
}

/* =========================================================
   FLIGHT RESULT CARD – CLEAN GRID SYSTEM
========================================================= */
/* ===============================
   FLIGHT RESULTS – LIST HEADER
================================ */
.flight-list-header{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  margin-bottom:10px;
  border-radius:14px;
  font-weight:800;
  color:#111;
      gap: 20px;
}
#flightListHeader>div {
    background: #ffc106;
    padding: 10px;
    border-radius: 15px;
}
#flightListHeader {
    grid-template-columns: 1fr 1fr;
    /* padding: 10px 16px; */
}
.flight-list-header div{
  text-align:center;
}
.flight-list-header div:first-child{
  text-align:left;
}
.irs--round .irs-handle {
    cursor: pointer;
}
.irs--round .irs-from, .irs--round .irs-to, .irs--round .irs-single {
    font-size: 12px;
    font-weight: 800;
}

#airportFilters label,#airlineFilters label{
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 12px;
    max-width: 100%;
}
.filter-card label {
    font-size: 12px;
}
.filter-card .fw-bold {
    font-size: 14px;
}








/* =========================================================
   FLIGHT RESULTS – CLEAN & STABLE CSS
========================================================= */

:root{
  --fx-yellow:#ffc107;
  --fx-bg:#ffffff;
  --fx-soft:#f8fafc;
  --fx-text:#0f172a;
  --fx-muted:#64748b;
  --fx-border:rgba(15,23,42,.12);
  --fx-radius:18px;
}

/* =========================================================
   LIST HEADER (Gidiş | Dönüş)
========================================================= */


#flightListHeader div{ text-align:center; }

/* =========================================================
   LIST WRAPPER
========================================================= */

#fxLists{
  display:block;
}
#fxLists.is-roundtrip{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

@media(max-width:992px){
  #fxLists.is-roundtrip{
    grid-template-columns:1fr;
  }
}

/* =========================================================
   OFFER CARD – MAIN GRID
========================================================= */

.offer-card{
    display: grid;
    grid-template-columns:70px /* airline */ 1fr /* trip */ 100px /* price */ 40px;
    gap: 10px;
    align-items: center;
    background: var(--fx-bg);
    border: 1px solid var(--fx-border);
    border-radius: var(--fx-radius);
    padding: 18px;
    margin-bottom: 14px;
}
.fx-col-trip,.fx-col-price{
	text-align:center;
}
.fx-trip-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
	    gap: 14px;
}
/* tek yön */
.offer-card.tekYon{
  grid-template-columns:
    220px
    1fr
    160px
    140px;
}

/* seçili */
.offer-card.is-selected{
  border-color:var(--fx-yellow);
  box-shadow:0 10px 30px rgba(255,193,7,.35);
  background:linear-gradient(0deg, rgba(255,193,7,.08), #fff 60%);
}

/* =========================================================
   AIRLINE COLUMN
========================================================= */

.fx-col-airline{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.fx-airline-logos{
    display: flex;
    gap: 6px;
    width: 24px;
}
.fx-airline-logos img{
  width:24px;
  height:24px;
  object-fit:contain;
}
.fx-airline-name{
    font-size: 10px;
    font-weight: 900;
    line-height: 11px;
}
.fx-airline-meta{
font-size: 10px;
    color: var(--fx-muted);
    line-height: 11px;
}

/* =========================================================
   TRIP COLUMN
========================================================= */

.fx-col-trip{
display: inline-block;
    justify-content: space-between;
    /* align-items: center; */
    text-align: center;
}

.fx-trip-col{
  text-align:center;
}
.fx-trip-col strong{
  display:block;
  font-size:15px;
  font-weight:900;
}
.fx-trip-col div{
  font-size:14px;
  font-weight:400;
  color:#000;
}
.fx-airline-meta {
    margin-top: -5px;
}
.fx-trip-mid{
  text-align:center;
}
.fx-duration{
  font-size:14px;
  font-weight:500;
}
.fx-stops{
  font-size:14px;
  font-weight:500;
  color:var(--fx-muted);
}
.fx-arrows{
  font-size:16px;
  opacity:.6;
}

/* =========================================================
   PRICE
========================================================= */

.fx-col-price{
  display:flex;
  justify-content:flex-end;
}
.fx-price{
  display:flex;
  align-items:flex-start;
  gap:3px;
}
.fx-price-main{
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
}
.fx-price-side{
  display:flex;
  flex-direction:column;
  transform:translateY(4px);
}
.fx-price-dec{
transform: translateY(-4px);
    color: #a4a4a4;
    font-size: 10px;
    position: relative;
}
.fx-price-cur{
    opacity: .8;
    transform: translateY(-9px);
    bottom: 0;
    color: #a4a4a4;
    font-size: 12px;
    font-weight: 700;
    position: relative;
}

/* =========================================================
   CTA
========================================================= */

.fx-col-cta{
  display:flex;
  justify-content:flex-end;
}
.fx-col-cta .btn{
    height: 37px;
    padding: 0 7px;
    border-radius: 999px;
    font-weight: 900;
    white-space: nowrap;
    font-size: 12px;
}
.fx-mobile-switch {
    display: none;
}
/* =========================================================
   MOBILE
========================================================= */

@media(max-width:992px){
  .offer-card{
    grid-template-columns:1fr 3fr;
    gap:12px;
  }
  .fx-col-price{
    justify-content:flex-start;
  }
  .fx-col-cta{
    justify-content:flex-end;
  }
  .fx-col-cta .btn{

  }
}

/* =========================================================
   STICKY SELECTED BAR
========================================================= */

#fxComboBar{
  position:sticky;
  bottom:12px;
  z-index:50;
  background:#0f172a;
  color:#fff;
  border-radius:20px;
  padding:14px 18px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-top:16px;
}
#fxComboPrice{
  font-size:18px;
  font-weight:900;
}
.fx-ms-btn{
  flex:1;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.15);
  background:#fff;
  font-weight:900;
}

.fx-ms-btn.is-active{
  background:#ffc107;
  border-color:#ffc107;
}
#fxLists.is-roundtrip{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

@media(max-width:992px){
  #fxLists.is-roundtrip{
    grid-template-columns:1fr;
  }
}
#fxLists{
  display:block;
}

#fxLists.is-roundtrip{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:24px;
}

#flightListHeader{
  grid-template-columns: 1fr 1fr;
}

.fx-mobile-switch{
  display:none;
}

@media (max-width:992px){
  #fxLists.is-roundtrip{
    grid-template-columns:1fr;
  }

  .fx-mobile-switch{
	display: flex;
	gap: 12px;
	grid-column: 1 / -1;
	margin-bottom: 0px;
	margin-top: 12px;
  }

  #flightListHeader{
    display:none !important;
  }
}
.tekYon .fx-trip-col strong {
    font-size: 18px;
}
.tekYon .fx-price-main {
    font-size: 24px;
}
#fxComboMeta {
    font-weight: 800;
}

/* =========================
   PRICE CALENDAR BAR
========================= */
.price-calendar-wrap {
  background: #fff;
  border-radius: 14px;
  padding: 14px 10px 10px;
  margin-bottom: 16px;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}

.price-calendar-title {
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:14px;
}

.price-calendar .pc-day {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  padding:6px;
  cursor:pointer;
}

.pc-bar {
  width:18px;
  border-radius:6px 6px 0 0;
  background:#ddd;
  transition:all .2s ease;
}

.pc-day.cheapest .pc-bar {
  background:#ffc107;
}

.pc-day.active .pc-bar {
  background:#0d6efd;
}

.pc-price {
    font-size: 10px;
    white-space: nowrap;
    font-weight: 700;
}

.pc-date {
font-size: 10px;
    color: #666;
    margin-top: 0px;
    line-height: 6px;
	white-space: nowrap;
}

.pc-day:hover .pc-bar {
  opacity:.8;
}

.price-calendar-wrap {
  margin-bottom: 20px;
}
.price-calendar-row.onewayWrap .price-calendar-wrap{
  width:100%;
}



@media (max-width: 991px) {
  .price-calendar-wrap {
    width: 100%;
    display: block;
  }
}

.pc-bar {
  height: 90px;
  display: flex;
  align-items: flex-end;
}

.pc-bar span {
  width: 100%;
  background: linear-gradient(180deg,#ffcc00,#ff9900);
  border-radius: 6px 6px 0 0;
  display: block;
}
.priceCalendar {
    display: flex;
}

/* ===============================
   PRICE CALENDAR LAYOUT
================================ */
.price-calendar-wrap {
  margin-bottom: 20px;
}
.price-calendar-wrap.dual {
  display: flex;
  gap: 16px;
}
@media (max-width:576px){
  .price-calendar-wrap.dual {
    flex-direction: column;
  }
}

/* ===============================
   DAY
================================ */
.pc-day {
  text-align: center;
  cursor: pointer;
}

/* ===============================
   BAR
================================ */
.pc-bar {
  height: 80px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.pc-bar span {
  width: 18px;
  background: -webkit-linear-gradient(bottom,#0564b0,#71c6e2);
  border-radius: 6px;
  display: block;
}

/* 🔥 EN UCUZ BAR */
.pc-day.is-cheapest .pc-bar span {
  background: -webkit-linear-gradient(bottom,#f3a200,#fec60a);
}

/* ===============================
   OWL NAV
================================ */
.price-calendar .owl-nav {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.price-calendar .owl-nav button {
  pointer-events: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #fff !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.2);
  font-size: 20px;
  font-weight: 900;
  line-height: 34px;
}

.price-calendar .owl-nav .owl-prev {
  left: -18px;
}

.price-calendar .owl-nav .owl-next {
  right: -18px;
}
.price-calendar .owl-nav button {
  pointer-events: auto;
  width: 24px;
  height: 24px;
  background: #fff !important;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0,0,0,.2);
  font-size: 20px;
  line-height: 24px !important;
  font-weight: 900 !important;
}
.price-calendar .owl-nav .owl-prev {
  position: absolute;
  left: -16px;
}
.price-calendar .owl-nav .owl-next {
  position: absolute;
  right: -16px;
}

/* ===============================
   PRICE CALENDAR ROW
================================ */
.price-calendar-row {
  display: flex;
  gap: 16px;
  width: 100%;
}

/* tek yön */
.price-calendar-row.is-oneway .price-calendar-wrap {
  max-width: 100%;
      display: none;
}

/* gidiş–dönüş */
.price-calendar-row.is-roundtrip .price-calendar-wrap {
  width: 50%;
}

/* mobil */
@media (max-width:576px){
  .price-calendar-row {
    flex-direction: column;
  }
  .price-calendar-row.is-roundtrip .price-calendar-wrap,
  .price-calendar-row.is-oneway .price-calendar-wrap {
    width: 100%;
  }
}
.price-calendar-row.onewayWrap .price-calendar-wrap {
  width: 100%;
  display:none
}

@media (max-width:576px){
  .price-calendar-row.roundTripWrap,
  .price-calendar-row.onewayWrap {
    flex-direction: column;
  }

  .price-calendar-row.roundTripWrap .price-calendar-wrap,
  .price-calendar-row.onewayWrap .price-calendar-wrap {
    width: 100%;
  }
}
.price-calendar-row.onewayWrap{
  display:flex;
}
.price-calendar-row.onewayWrap .price-calendar-wrap{
  width:100%;
}

.price-calendar-row.roundTripWrap{
  display:flex;
  gap:16px;
}
.price-calendar-row.roundTripWrap .price-calendar-wrap{
  width:50%;
  min-width:50%;
}

@media(max-width:576px){
  .price-calendar-row.roundTripWrap{
    flex-direction:column;
  }
  .price-calendar-row.roundTripWrap .price-calendar-wrap{
    width:100%;
  }
}
.pc-day.is-selected .pc-bar span{
  background:-webkit-linear-gradient(bottom, #f30000, #feca0a)!important;
}
.pc-day.is-cheapest:hover::after{
  content:"En ucuz";
  position:absolute;
  bottom:100%;
  background:#0f172a;
  color:#fff;
  padding:4px 8px;
  font-size:10px;
  border-radius:6px;
  white-space:nowrap;
}
#priceCalendarOut .owl-stage-outer,#priceCalendarRet .owl-stage-outer {
    padding-top: 25px;
}
#priceCalendarOut,#priceCalendarRet {
    margin-top: -20px;
	    display: flex;
}
#fxRet.has-value::placeholder {
  color: transparent;
}

@media(min-width:993px){
#loadingBox{
	margin-left:-33%;
	position:relative;
}
}
@media(max-width:992px){
	.offer-card.tekYon {
		grid-template-columns: 40px 1fr 60px 40px;
	}

  .price-calendar-wrap {
    display:none;
  }

  .price-calendar-wrap.is-active {
    display:block;
  }
  
  .col-swap {
		justify-content: center;
		display: flex;
	}
	.swap-btn {
		margin-top: -17px !important;
        position: absolute;
        z-index: 9;
        border-radius: 50% !important;
	}

  .filter-card{
    display:none !important;
  }

  .filter-card.is-open{
    display:block !important;
    position:fixed;
    inset:0;
    z-index:9999;
    background:#fff;
    overflow:auto;
	padding: 20px 30px;
    padding-bottom:80px;
  }

  body.filter-open{
    overflow:hidden;
  }
  #btnToggleFilters {
	max-width: 50px;
	font-size: 12px;
	line-height: 14px;
	padding: 7px 5px;
	text-align: center;
	font-weight: 700;
	border: solid 0px #cecece;
	background: #ffc106;
	align-self: flex-start;
	margin-top: 7px;
}
 .mobile-filter-cta{
    position: sticky;
    bottom: 0;
    display: flex;
    gap: 12px;
    padding: 12px 0;
    background: #fff;
    border-top: 1px solid rgba(0,0,0,.08);
    z-index: 10000;
  }

  .mobile-filter-cta .btn{
    flex:1;
    height: 48px;
    font-weight: 900;
    border-radius: 14px;
  }
  button#btnFilterClose {
    position: fixed;
    top: 20px;
    right: 30px;
    padding: 0;
    width: 40px;
    height: 40px;
    line-height: 40px;
    border-radius: 50%;
    text-align: center;
	background: #fff;
}
.flight-hero-actions {
    display: none;
}
.fx-chip {
    padding: 13px 0px;
    text-align: center;
    width: 55px;
    line-height: 12px;
}
.result-topbar {
    padding: 7px 10px;
    gap: 5px;
}
}
/*
#airportFilters,#airlineFilters {
    max-height: 200px;
    display: inline-block;
    overflow: auto;
}
*/
/* ===============================
   DESKTOP FILTER SCROLL FIX
================================ */

@media (min-width: 992px) {

  .filter-card {
    position: sticky;
    top: 16px;

    /* 👇 EN KRİTİK SATIRLAR */
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    overscroll-behavior: contain;

    /* scroll hissi */
    scrollbar-width: thin;
  }

  /* Webkit scrollbar (Chrome / Edge) */
  .filter-card::-webkit-scrollbar {
    width: 6px;
  }

  .filter-card::-webkit-scrollbar-track {
    background: transparent;
  }

  .filter-card::-webkit-scrollbar-thumb {
    background: rgba(0,0,0,.15);
    border-radius: 6px;
  }

  .filter-card::-webkit-scrollbar-thumb:hover {
    background: rgba(0,0,0,.25);
  }
}

/* ===============================
   PRE SEARCH INTRO CONTENT
================================ */

.presearch-intro{
  background: linear-gradient(180deg,#ffffff,#f8fafc);
  border-radius: 22px;
  padding: 28px;
  margin-bottom: 24px;
  border: 1px solid rgba(15,23,42,.16);
  text-align: left;
  box-shadow: 0 5px 30px rgba(0, 0, 0, .12);
}
.preSearchTop{
	background: linear-gradient(180deg, #ffffff, #f8fafc);
    border-radius: 22px;
    padding: 28px;
    margin-bottom: 45px;
    border: 1px solid rgba(15, 23, 42, .16);
	margin-top: 0;
	box-shadow: 0 5px 30px rgba(0, 0, 0, .12);
}
.presearch-title{
  font-size: 22px;
  font-weight: 900;
  margin-bottom: 10px;
}

.presearch-lead{
  color:#475569;
  font-size:15px;
}

.presearch-features{
  display:grid;
  grid-template-columns: repeat(2,1fr);
  gap:16px;
  margin-top:22px;
}

.ps-feature{
  display:flex;
  gap:14px;
  align-items:flex-start;
}

.ps-feature i{
  font-size:22px;
  color:#f59e0b;
  margin-top:2px;
}

.ps-feature strong{
  display:block;
  font-weight:800;
  font-size:14px;
}

.ps-feature span{
  font-size:13px;
  color:#64748b;
}

.presearch-hint{
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:22px;
  font-size:13px;
  color:#475569;
}

.presearch-hint i{
  font-size:16px;
}

/* mobile */
@media(max-width:768px){
  .presearch-features{
    grid-template-columns:1fr;
  }
}

.price-calendar-title .material-symbols-outlined{
	font-size: 14px;
}
.flight-list-header .material-symbols-outlined{
	font-size: 16px;
}
#routeTitle .material-symbols-outlined{
	font-size: 15px;
}
.fx-date-input{
  transition: background .25s ease, box-shadow .25s ease;
}

.fx-date-input.has-date{
  background:#f8fafc;
  box-shadow:0 0 0 2px rgba(255,193,7,.35);
}
.fx-chip-clear{
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  border:none;
  background:#e2e8f0;
  width:22px;
  height:22px;
  border-radius:50%;
  font-weight:900;
  font-size:12px;
  cursor:pointer;
  display:none;
}

.fx-date-input.has-date + .fx-chip-clear{
  display:flex;
  align-items:center;
  justify-content:center;
}

.fx-range-chip{
  margin-top:8px;
  padding:10px 14px;
  border-radius:14px;
  background:#fff7cc;
  font-weight:900;
  display:flex;
  gap:8px;
  align-items:center;
  font-size:14px;
}

.fx-range-chip i{
  color:#f59e0b;
}

.fx-sticky-chips{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}

.fx-sticky-chip{
  background:#0f172a;
  color:#fff;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
}





.loader {
  margin-left: 75px;
  padding: 30px 0;
  width: 150px;
  height: 150px;
  border: 1px solid rgba(125, 125, 125, 0.15);
  border-radius: 100%;
}
.hide {
  display: none;
}
.loader2 {
  position: relative;
  width: 150px;
  height: 150px;
}
.loader2 span {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: rotate(calc(18deg * var(--i)));
}
.loader2 span:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
  background:#fad66d;
  border-radius: 50%;
  transform: scale(0);
  animation: animate 2s linear infinite;
  animation-delay: calc(0.1s * var(--i));
}
.loader2 .plane {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  animation: rotating 4s linear infinite;
  animation-delay: -1s;
}
.loader2 .plane:before {
    content: "";
    content: "";
    font-family: fontAwesome;
    position: absolute;
    top: 120px;
    left: 34px;
    color: #fad66d;
    font-size: 30px;
    transform: rotate(200deg);
}
@keyframes animate {
  0% {
    transform: scale(0);
  }
  50% {
    transform: scale(1.2);
  }
  80%, 100% {
    transform: scale(0);
  }
}
@keyframes rotating {
  0% {
    transform: rotate(10deg);
  }
  100% {
    transform: rotate(370deg);
  }
}
#loadingBox{
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
}
.loaderWrap .small-muted{
	margin-top:30px;
}

.fx-arrows {
    padding: 0;
    margin: 2px 0 4px 0 !important;
    position: relative;
}

.arr.leftRight {
    background-color: #a6a6a3;
    float: left;
    height: 1px;
    width: 100%;
}
.arr.leftRight:before {
    color: #a6a6a3;
    content: url(../img/arrow-right.webp);
    display: inline-block;
    float: right;
    font-size: 8px;
    margin: -5px -8px;
}
.arr.leftRight:after {
	background: #a6a6a3;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -ms-border-radius: 50%;
    -o-border-radius: 50%;
    content: "";
    display: inline-block;
    float: left;
    height: 5px;
    margin-left: -5px;
    margin-top: -2px;
    width: 5px;
}
.pc-skeleton {
  display: none;
  
}

.pc-skeleton.is-active {
  display: flex;
  width:100%;
  justify-content: space-around;
  margin-top: 11px;
}

.pc-skel-day {
  width: 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
}

.pc-skel-bar {
  width: 100%;
  height: 80px;
  background: linear-gradient(
    90deg,
    #f0f0f0 25%,
    #e0e0e0 37%,
    #f0f0f0 63%
  );
  background-size: 400% 100%;
  animation: skel-shimmer 1.4s ease infinite;
  border-radius: 6px;
}

.pc-skel-date {
  width: 36px;
  height: 18px;
  background: #eee;
  border-radius: 4px;
  margin-bottom:25px;
}

@keyframes skel-shimmer {
  0% { background-position: 100% 0 }
  100% { background-position: 0 0 }
}

#priceCalendarWrapOut,
#priceCalendarWrapRet {
  flex: 1 1 100%;
  width: 100%;
  min-width: 0; /* flex overflow fix */
}


.pc-skeleton.is-hide{
  opacity: 0;
  transition: opacity .25s ease;
}
