/* ==========================================================================
   Tatilsepeti Tasarım Ruhu — Acentenet Override Tema
   Marka: Riotatil Turizm
   Yüklenme sırası: main.css'TEN SONRA gelir, üzerine biner.
   ========================================================================== */

/* ----------- Tasarım Token'ları ----------- */
:root {
  /* Marka */
  --ts-orange:        #FF6B00;
  --ts-orange-hover:  #E55E00;
  --ts-orange-dark:   #C24E00;
  --ts-orange-light:  #FFF1E5;
  --ts-orange-soft:   #FFE0CC;
  --ts-orange-shadow: rgba(255, 107, 0, 0.30);

  --ts-navy:          #0A2A5E;
  --ts-navy-dark:     #062048;
  --ts-navy-light:    #1B3F7E;
  --ts-navy-soft:     #E8EDF5;
  --ts-navy-shadow:   rgba(10, 42, 94, 0.25);

  /* Anlamsal */
  --ts-success:       #22C55E;
  --ts-success-light: #DCFCE7;
  --ts-warning:       #FFC107;
  --ts-warning-light: #FFF8E1;
  --ts-danger:        #DC2626;
  --ts-danger-light:  #FEE2E2;
  --ts-info:          #3B82F6;

  /* Nötr */
  --ts-bg:            #F4F6F9;
  --ts-bg-soft:       #FAFBFC;
  --ts-bg-card:       #FFFFFF;
  --ts-border:        #E5E7EB;
  --ts-border-strong: #D1D5DB;
  --ts-text:          #1F2937;
  --ts-text-soft:     #6B7280;
  --ts-text-muted:    #9CA3AF;
  --ts-text-light:    #FFFFFF;

  /* Effects */
  --ts-radius-sm:     6px;
  --ts-radius:        10px;
  --ts-radius-lg:     14px;
  --ts-radius-xl:     18px;
  --ts-radius-2xl:    24px;
  --ts-radius-pill:   999px;

  --ts-shadow-xs:     0 1px 2px rgba(15, 23, 42, 0.04);
  --ts-shadow-sm:     0 1px 3px rgba(15, 23, 42, 0.06), 0 1px 2px rgba(15, 23, 42, 0.04);
  --ts-shadow:        0 4px 14px rgba(15, 23, 42, 0.08), 0 2px 4px rgba(15, 23, 42, 0.04);
  --ts-shadow-lg:     0 10px 30px rgba(15, 23, 42, 0.12), 0 4px 8px rgba(15, 23, 42, 0.06);
  --ts-shadow-xl:     0 20px 50px rgba(15, 23, 42, 0.16), 0 8px 16px rgba(15, 23, 42, 0.08);

  --ts-transition:    0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --ts-transition-slow: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ==========================================================================
   1. GLOBAL — Tipografi, Body, Container
   Inter — Booking, Stripe, Tatilsepeti tarzı KURUMSAL sans-serif.
   Variable font (400-800), excellent x-height, Türkçe karakter desteği tam.
   ========================================================================== */
.theme-tatilsepeti,
body.theme-pro.theme-tatilsepeti,
.theme-tatilsepeti * {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
}
.theme-tatilsepeti,
body.theme-pro.theme-tatilsepeti {
  background: var(--ts-bg) !important;
  color: var(--ts-text) !important;
  font-size: 14.5px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'cv02', 'cv03', 'cv04', 'cv11'; /* Inter alternate glyphs */
  letter-spacing: -0.005em;
}
/* Font Awesome ikonları zaten kendi font-family'lerini override eder, ama emin olmak için: */
.theme-tatilsepeti i.fa,
.theme-tatilsepeti i.fas,
.theme-tatilsepeti i.far,
.theme-tatilsepeti i.fab,
.theme-tatilsepeti i.fal,
.theme-tatilsepeti .fa,
.theme-tatilsepeti .fas,
.theme-tatilsepeti .far,
.theme-tatilsepeti .fab,
.theme-tatilsepeti .fal {
  font-family: 'Font Awesome 5 Free', 'Font Awesome 5 Brands', 'FontAwesome' !important;
}
.theme-tatilsepeti i.fab,
.theme-tatilsepeti .fab {
  font-family: 'Font Awesome 5 Brands' !important;
}

.theme-tatilsepeti a {
  color: var(--ts-navy);
  text-decoration: none;
  transition: color var(--ts-transition);
}
.theme-tatilsepeti a:hover {
  color: var(--ts-orange);
}

.theme-tatilsepeti h1, .theme-tatilsepeti h2, .theme-tatilsepeti h3, .theme-tatilsepeti h4, .theme-tatilsepeti h5, .theme-tatilsepeti h6 {
  font-weight: 700;
  color: var(--ts-navy);
  letter-spacing: -0.015em; /* Inter için biraz daha sıkı tracking */
}
.theme-tatilsepeti h1 { font-size: 2rem; }
.theme-tatilsepeti h2 { font-size: 1.625rem; }
.theme-tatilsepeti h3 { font-size: 1.25rem; }
.theme-tatilsepeti h4 { font-size: 1.125rem; }

.theme-tatilsepeti .container {
  max-width: 1240px !important;
  width: 100% !important;
  padding-left: 16px;
  padding-right: 16px;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 1400px) {
  .theme-tatilsepeti .container { max-width: 1280px !important; }
}

.theme-tatilsepeti .bg-gray { background: var(--ts-bg) !important; }
.theme-tatilsepeti .bg-white { background: var(--ts-bg-card) !important; }
.theme-tatilsepeti .bg-navy { background: var(--ts-navy) !important; color: #fff; }
.theme-tatilsepeti .bg-navy-dark { background: var(--ts-navy-dark) !important; color: #fff; }
.theme-tatilsepeti .bg-orange { background: var(--ts-orange) !important; color: #fff; }
.theme-tatilsepeti .bg-orange-light { background: var(--ts-orange-light) !important; }

.theme-tatilsepeti .text-navy { color: var(--ts-navy) !important; }
.theme-tatilsepeti .text-orange { color: var(--ts-orange) !important; }
.theme-tatilsepeti .text-soft { color: var(--ts-text-soft) !important; }

/* Renk eski sınıfları yeni paletle eşle */
.theme-tatilsepeti .text-yellow,
.theme-tatilsepeti .text-red {
  color: var(--ts-orange) !important;
}
.theme-tatilsepeti .text-blue,
.theme-tatilsepeti .text-dark { color: var(--ts-navy) !important; }
.theme-tatilsepeti .text-gray,
.theme-tatilsepeti .text-dark-gray { color: var(--ts-text-soft) !important; }

/* ==========================================================================
   2. ÜST BİLDİRİM ÇUBUĞU (Promo Bar)
   - position: fixed → viewport top'a yapışır, header'ın ÜSTÜNDE kalır.
   - z-index: 1040 → header (1050)'den düşük ama dropdown'lardan yüksek değil;
     mega menu (1200) ve currency dropdown (1100) zaten promo bar'ı örter.
   ========================================================================== */
.ts-promo-bar {
  background: linear-gradient(90deg, var(--ts-orange) 0%, var(--ts-orange-hover) 100%);
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  height: 34px;
  display: flex;
  align-items: center;
  overflow: hidden;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1040;
  box-shadow: 0 1px 0 rgba(0,0,0,0.08);
}
/* Sayfa scroll edildiğinde promo bar yukarı kaysın (header is-scrolled ile birlikte) */
body.theme-pro.theme-tatilsepeti.is-scrolled .ts-promo-bar { transform: translateY(-100%); transition: transform .3s ease; }
.ts-promo-bar { transition: transform .3s ease; }
.ts-promo-bar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: 16px;
}
.ts-promo-bar .ts-promo-marquee {
  flex: 1;
  overflow: hidden;
  white-space: nowrap;
  position: relative;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 24px, #000 calc(100% - 24px), transparent);
          mask-image: linear-gradient(to right, transparent, #000 24px, #000 calc(100% - 24px), transparent);
}
.ts-promo-bar .ts-promo-marquee-track {
  display: inline-flex;
  gap: 48px;
  align-items: center;
  animation: ts-marquee 60s linear infinite;
  padding-left: 100%;
}
.ts-promo-bar .ts-promo-marquee:hover .ts-promo-marquee-track { animation-play-state: paused; }
.ts-promo-bar .ts-promo-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.ts-promo-bar .ts-promo-item i { font-size: 12px; opacity: 0.9; }
.ts-promo-bar .ts-promo-item a {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 2px;
  font-weight: 600;
}
.ts-promo-bar .ts-promo-item a:hover { opacity: 0.85; color: #fff; }
.ts-promo-bar .ts-promo-close {
  background: rgba(255,255,255,0.18);
  border: 0;
  color: #fff;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  transition: background var(--ts-transition);
}
.ts-promo-bar .ts-promo-close:hover { background: rgba(255,255,255,0.32); }

@keyframes ts-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-100%); }
}

@media (max-width: 768px) {
  .ts-promo-bar { height: 32px; font-size: 12px; }
  .ts-promo-bar .ts-promo-marquee-track { animation-duration: 35s; gap: 32px; }
}

/* ==========================================================================
   3. HEADER — Tatilsepeti Tarzı Profesyonel Header
   - Üst beyaz logo bar (74px): Logo + Telefon (sol) | Currency / Lang / Üye / Acente (sağ)
   - Lacivert navigasyon bar (54px): Otel / Tur / Feribot / Transfer / vs.
   - z-index 1050 (promo bar 990'ın çok üstünde — dropdown'lar her şeyin üstünde)
   ========================================================================== */
.theme-tatilsepeti header.site-header {
  background: #fff !important;
  background-image: none !important;  /* main.css'teki sliderup.jpg arka planını sil */
  box-shadow: 0 2px 12px rgba(10,42,94,0.06) !important;
  top: 34px !important; /* promo bar yüksekliği (34px) */
  z-index: 1050 !important; /* PROMO BAR'IN (990) ÜSTÜNDE */
  border-bottom: 0 !important;
}
.theme-tatilsepeti header.site-header.is-scrolled {
  top: -74px !important; /* logo bar (74px) yukarı kayar, sadece nav (46px) görünür kalır */
  box-shadow: 0 6px 28px rgba(10,42,94,0.10) !important;
}
.theme-tatilsepeti.no-promo header.site-header { top: 0 !important; }

/* Eski kırmızı/turuncu çizgi tamamen kaldır */
.theme-tatilsepeti header.site-header::after {
  display: none !important;
  content: none !important;
}

/* ===== Üst Logo Bar (.top) — temiz beyaz, kurumsal =====
   ÖNEMLİ: container'ın iç padding'i KALDIRILDI → logo container'ın TAM SOL kenarına,
   butonlar TAM SAĞ kenarına yapışır. nav menü de aynı şekilde tam-genişlik dağılır. */
.theme-tatilsepeti header.site-header > .container,
.theme-tatilsepeti header.site-header .menu > .container {
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 1320px;
  width: 100%;
  margin: 0 auto;
}
.theme-tatilsepeti header.site-header .top {
  background: #ffffff !important;
  background-image: none !important;
  border-bottom: 1px solid #eaecef !important;
  height: 74px;
  min-height: 74px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  position: relative;
  padding: 0 !important; /* logo TAM sol kenarda, butonlar TAM sağ kenarda */
}
/* Üst turuncu vurgu — DAHA SUBTLE, sadece çok ince ipucu (kurumsal his) */
.theme-tatilsepeti header.site-header .top::before {
  content: '';
  position: absolute;
  left: 0; right: 0; top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255,107,0,0.35) 30%, rgba(255,107,0,0.35) 70%, transparent 100%);
  opacity: 1;
}

.theme-tatilsepeti header.site-header .top .left {
  display: flex;
  align-items: center;
  gap: 22px;
}
.theme-tatilsepeti header.site-header .top .left .logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
}
.theme-tatilsepeti header.site-header .top .left .logo img {
  max-height: 50px;
  width: auto;
  display: block;
  transition: transform .15s ease;
}
.theme-tatilsepeti header.site-header .top .left .logo:hover img { transform: scale(1.02); }

/* Telefon "pill" — KURUMSAL: subtle gri çerçeve + turuncu icon (renk çok keskin değil) */
.theme-tatilsepeti header.site-header .top .left .phone {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  background: #fafbfc !important;
  border: 1px solid #e3e6ea !important;
  color: var(--ts-navy) !important;
  border-radius: 999px !important;
  padding: 8px 16px !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  text-decoration: none;
  line-height: 1;
  height: 38px;
  transition: all .18s ease;
  white-space: nowrap;
}
.theme-tatilsepeti header.site-header .top .left .phone svg {
  width: 16px;
  height: 16px;
}
.theme-tatilsepeti header.site-header .top .left .phone .header-phone-icon { fill: var(--ts-orange) !important; }
.theme-tatilsepeti header.site-header .top .left .phone:hover {
  background: #fff !important;
  border-color: rgba(255,107,0,0.45) !important;
  color: var(--ts-orange) !important;
  box-shadow: 0 2px 10px rgba(10,42,94,0.08);
  transform: none;
}
.theme-tatilsepeti header.site-header .top .left .phone:hover .header-phone-icon { fill: var(--ts-orange) !important; }

/* ===== Sağ taraf — Currency / Language / Üye / Acente ===== */
.theme-tatilsepeti header.site-header .top .right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.theme-tatilsepeti header.site-header .top .right .currency,
.theme-tatilsepeti header.site-header .top .right .language {
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
.theme-tatilsepeti header.site-header .top .right .dropdown .btn {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  color: var(--ts-text) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  background: transparent !important;
  border: 0 !important;
  padding: 8px 12px !important;
  border-radius: var(--ts-radius-sm) !important;
  height: 38px;
  line-height: 1;
  text-decoration: none;
  transition: background-color .15s ease;
  box-shadow: none !important;
}
.theme-tatilsepeti header.site-header .top .right .dropdown .btn:hover,
.theme-tatilsepeti header.site-header .top .right .dropdown .btn[aria-expanded="true"] {
  background: #f3f5f8 !important;
  color: var(--ts-navy) !important;
}
.theme-tatilsepeti header.site-header .top .right .dropdown .btn img {
  width: 18px;
  height: 18px;
  border-radius: 2px;
  object-fit: cover;
}
.theme-tatilsepeti header.site-header .top .right .dropdown .btn.dropdown-toggle::after {
  color: var(--ts-text-muted) !important;
  border-top-color: currentColor;
  margin-left: 4px;
}

/* Currency / Language dropdown menü */
.theme-tatilsepeti header.site-header .top .right .dropdown-menu {
  border: 0 !important;
  border-radius: var(--ts-radius) !important;
  box-shadow: 0 8px 30px rgba(10,42,94,0.12) !important;
  padding: 6px !important;
  min-width: 160px !important;
  margin-top: 6px !important;
  z-index: 1100 !important;
}
.theme-tatilsepeti header.site-header .top .right .dropdown-menu .dropdown-item {
  padding: 8px 12px !important;
  border-radius: var(--ts-radius-sm) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--ts-text) !important;
  display: flex;
  align-items: center;
  gap: 8px;
}
.theme-tatilsepeti header.site-header .top .right .dropdown-menu .dropdown-item img {
  width: 18px; height: 18px; border-radius: 2px;
}
.theme-tatilsepeti header.site-header .top .right .dropdown-menu .dropdown-item:hover {
  background: var(--ts-orange-light) !important;
  color: var(--ts-orange) !important;
}
.theme-tatilsepeti header.site-header .top .right .dropdown-menu .dropdown-item.active {
  background: var(--ts-navy) !important;
  color: #fff !important;
}

/* Üye Girişi (subtle outline) ve Acente Girişi (mat lacivert dolu) — KURUMSAL */
.theme-tatilsepeti header.site-header .top .right .buttons {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-left: 6px;
}
.theme-tatilsepeti header.site-header .top .right .buttons a.btn-outline-yellow {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  border: 1px solid #d8dde3 !important;
  color: var(--ts-navy) !important;
  background: #ffffff !important;
  border-radius: 8px !important;
  padding: 9px 16px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.01em;
  height: 38px;
  line-height: 1;
  text-decoration: none;
  transition: all .18s ease;
  margin: 0 !important;
  box-shadow: 0 1px 2px rgba(10,42,94,0.04);
}
.theme-tatilsepeti header.site-header .top .right .buttons a.btn-outline-yellow:hover {
  background: #fff8f2 !important;
  color: var(--ts-orange) !important;
  border-color: rgba(255,107,0,0.35) !important;
  box-shadow: 0 2px 8px rgba(255,107,0,0.10);
  transform: none;
}
.theme-tatilsepeti header.site-header .top .right .buttons a.btn-dark {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  background: #1a3158 !important;
  background-image: none !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: 0 2px 6px rgba(10,42,94,0.12) !important;
  border-radius: 8px !important;
  padding: 9px 18px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.01em;
  height: 38px;
  line-height: 1;
  text-decoration: none;
  transition: all .18s ease;
  margin: 0 !important;
}
.theme-tatilsepeti header.site-header .top .right .buttons a.btn-dark:hover {
  background: #142847 !important;
  box-shadow: 0 4px 14px rgba(10,42,94,0.18) !important;
  transform: none;
}

/* ===== Navigasyon Bar — BEYAZ KURUMSAL (Jolly/Tatilsepeti tarzı) =====
   - Background BEYAZ (lacivert değil — referans Jolly tur header'a göre)
   - Lacivert metin item'lar, hover/active TURUNCU
   - Alt 1px ince gri border (logo bar ile birleşik görsel akış)
   - Aktif item: turuncu metin + altta turuncu kalın underline (3px)
   ===================================================================== */
.theme-tatilsepeti header.site-header .menu {
  background: #eff1f5 !important; /* kullanıcı talebi: soft kurumsal gri-mavi */
  background-image: none !important;
  border-top: 1px solid #e3e6ec !important;
  border-bottom: 1px solid #d9dde4 !important;
  height: 46px !important;
  min-height: 46px !important;
  display: flex !important;
  align-items: stretch !important;
  position: relative;
  z-index: 1;
  box-shadow: 0 2px 8px rgba(10,42,94,0.04);
}
.theme-tatilsepeti header.site-header .menu > .container {
  display: flex !important;
  align-items: stretch !important;
  height: 100% !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  justify-content: space-between !important; /* ilk item TAM sol, son item TAM sağ — aralar eşit */
  list-style: none;
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;
  height: 100% !important;
  flex-wrap: nowrap;
  width: 100% !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li {
  display: flex;
  align-items: stretch;
  position: relative;
  margin: 0 !important;
  padding: 0 !important;
  flex: 0 0 auto;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li > a {
  display: inline-flex !important;
  align-items: center;
  gap: 5px;
  color: #1f2c45 !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  height: 100% !important;
  padding: 0 12px !important;
  position: relative;
  text-decoration: none;
  transition: color .15s ease, background-color .15s ease;
  white-space: nowrap;
  border-radius: 0 !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li > a > i {
  font-size: 12px !important;
  margin-right: 2px !important;
  opacity: 0.6;
  color: #6c7a96 !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li > a:hover {
  background: #ffffff !important; /* gri wrapper'da BEYAZ hover = belirgin kontrast */
  color: var(--ts-orange) !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li > a:hover > i {
  color: var(--ts-orange) !important;
  opacity: 1;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li > a::after {
  content: '';
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: -1px;
  height: 3px;
  background: var(--ts-orange);
  border-radius: 0;
  opacity: 0;
  transform: scaleX(0.4);
  transform-origin: center;
  transition: opacity .18s ease, transform .18s ease;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li:hover > a::after,
.theme-tatilsepeti header.site-header .menu .webmenu > li.active > a::after,
.theme-tatilsepeti header.site-header .menu .webmenu > li > a.active::after {
  opacity: 1;
  transform: scaleX(1);
}
.theme-tatilsepeti header.site-header .menu .webmenu > li.active > a,
.theme-tatilsepeti header.site-header .menu .webmenu > li > a.active {
  color: var(--ts-orange) !important;
  background: transparent !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li.active > a > i,
.theme-tatilsepeti header.site-header .menu .webmenu > li > a.active > i {
  color: var(--ts-orange) !important;
  opacity: 1;
}

/* Tema item'ları (Antalya/Side/Belek/Çeşme/Termal) — KOMPAKT, sığsın */
.theme-tatilsepeti header.site-header .menu .webmenu > li.nav-themed > a {
  padding: 0 9px !important;
  font-size: 12.5px !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li.nav-themed > a > i {
  font-size: 11px !important;
  margin-right: 2px !important;
}

/* Mega dropdown — beyaz nav üzerinde divider rengi güncellendi */
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box {
  padding-top: 6px !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box .dropdown-content {
  border: 1px solid #ecf0f4 !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box .dropdown-content::before {
  background: #fff;
  border-top: 1px solid #ecf0f4;
  border-left: 1px solid #ecf0f4;
}

/* Responsive nav sıkışma */
@media (max-width: 1399px) {
  .theme-tatilsepeti header.site-header .menu .webmenu > li > a { padding: 0 10px !important; font-size: 12.5px !important; }
  .theme-tatilsepeti header.site-header .menu .webmenu > li.nav-themed > a { padding: 0 7px !important; font-size: 12px !important; }
  .theme-tatilsepeti header.site-header .menu .webmenu > li > a::after { left: 10px; right: 10px; }
}
@media (max-width: 1199px) {
  .theme-tatilsepeti header.site-header .menu .webmenu > li > a { padding: 0 8px !important; font-size: 12px !important; }
  .theme-tatilsepeti header.site-header .menu .webmenu > li.nav-themed > a { padding: 0 6px !important; font-size: 11.5px !important; }
  .theme-tatilsepeti header.site-header .menu .webmenu > li > a > i { display: none; }
  .theme-tatilsepeti header.site-header .menu .webmenu > li > a::after { left: 8px; right: 8px; }
}

/* ===== Mega Dropdown — webmenu altında açılan kutular ===== */
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box {
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  z-index: 1200 !important;
  padding-top: 8px !important; /* turuncu çizgiden boşluk */
}
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box .dropdown-content {
  background: #fff !important;
  border: 0 !important;
  border-radius: 12px !important;
  box-shadow: 0 12px 40px rgba(10,42,94,0.18), 0 4px 16px rgba(10,42,94,0.10) !important;
  padding: 14px !important;
  min-width: 320px !important;
  position: relative;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box .dropdown-content::before {
  content: '';
  position: absolute;
  top: -7px;
  left: 32px;
  width: 14px;
  height: 14px;
  background: #fff;
  transform: rotate(45deg);
  box-shadow: -2px -2px 6px rgba(10,42,94,0.06);
  border-radius: 2px;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box .dropdown-content .title {
  display: block;
  color: var(--ts-navy) !important;
  font-weight: 800 !important;
  font-size: 12px !important;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  padding: 4px 10px 10px;
  margin: 0 0 6px;
  border-bottom: 1px solid #f0f2f5 !important;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box .dropdown-content ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2px;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box .dropdown-content ul li { margin: 0; }
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box .dropdown-content ul li a {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--ts-text) !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  padding: 8px 12px !important;
  border-radius: 8px !important;
  text-decoration: none;
  border-left: 3px solid transparent !important;
  transition: all .15s ease;
}
.theme-tatilsepeti header.site-header .menu .webmenu > li .dropdown-box .dropdown-content ul li a:hover {
  background: var(--ts-orange-light) !important;
  color: var(--ts-orange) !important;
  border-left-color: var(--ts-orange) !important;
  padding-left: 14px !important;
}

/* Mobil menü butonu (hamburger) */
.theme-tatilsepeti header.site-header .mobile-menu-btn .mobile-menu-btn-line {
  background: var(--ts-navy) !important;
}

/* Body padding ofseti — promo (34) + logo bar (74) + nav (46) = 154 */
body.theme-pro.theme-tatilsepeti {
  padding-top: 154px !important;
}
body.theme-pro.theme-tatilsepeti.no-promo {
  padding-top: 120px !important;
}
@media (max-width: 991px) {
  body.theme-pro.theme-tatilsepeti,
  body.theme-pro.theme-tatilsepeti.no-promo {
    padding-top: 0 !important;
  }
  .theme-tatilsepeti header.site-header {
    position: relative !important;
    top: 0 !important;
  }
  .theme-tatilsepeti header.site-header.is-scrolled { top: 0 !important; }
  .theme-tatilsepeti header.site-header .menu { display: none !important; }
  .theme-tatilsepeti header.site-header .top {
    height: 64px;
    min-height: 64px;
  }
  .theme-tatilsepeti header.site-header .top .left .phone span { display: none; }
  .theme-tatilsepeti header.site-header .top .right { display: none !important; }
}

/* ==========================================================================
   4. HERO + ARAMA KUTUSU (iç sayfalarda — otel/list, tur/list, vb.)
   Daha KOMPAKT: arka plan resmi YOK (sadece düz lacivert), tab ve form ARASI 0
   ========================================================================== */
.theme-tatilsepeti .main-search {
  background: linear-gradient(135deg, var(--ts-navy-dark) 0%, var(--ts-navy) 100%) !important;
  background-image: linear-gradient(135deg, var(--ts-navy-dark) 0%, var(--ts-navy) 100%) !important;
  background-size: cover !important;
  background-position: center !important;
  min-height: 0 !important;
  height: auto !important;
  padding: 18px 0 24px !important;
  display: block !important;
  position: relative;
  margin-bottom: 0 !important;
  overflow: hidden;
}
.theme-tatilsepeti .main-search::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at top right, rgba(255,107,0,0.08), transparent 60%),
    radial-gradient(ellipse at bottom left, rgba(27,63,126,0.20), transparent 55%);
  pointer-events: none;
}
.theme-tatilsepeti .main-search .container { position: relative; z-index: 2; }
.theme-tatilsepeti .main-search .gradient { display: none !important; }

/* Hero başlık (opsiyonel, otel/list, tur/list sayfalarında) */
.theme-tatilsepeti .ts-hero-title {
  text-align: center;
  color: #fff;
  margin-bottom: 10px;
}
.theme-tatilsepeti .ts-hero-title h1 {
  color: #fff !important;
  font-size: 22px;
  font-weight: 800;
  line-height: 1.15;
  margin: 0 0 2px;
  text-shadow: 0 2px 10px rgba(0,0,0,0.20);
}
.theme-tatilsepeti .ts-hero-title h1 span { color: var(--ts-orange); }
.theme-tatilsepeti .ts-hero-title p {
  color: rgba(255,255,255,0.92);
  font-size: 13px;
  margin: 0;
}

/* ----- Sekme şeridi — tab pill'ler form kartına YAPIŞIR (gap=0)
   Tatilsepeti tarzı yatay sekmeler: yarı-saydam beyaz, aktif=beyaz dolu.
   ------ */
.theme-tatilsepeti .main-search .nav.nav-pills {
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
  justify-content: flex-start !important;
  gap: 4px !important;
  flex-wrap: nowrap;
  overflow-x: auto;
  border: 0 !important;
  display: flex !important;
  line-height: 1 !important;
  align-items: flex-end !important;
}
.theme-tatilsepeti .main-search .nav.nav-pills .nav-item {
  margin: 0 !important;
  padding: 0 !important;
  flex: 0 0 auto !important;
}
/* PILL'ler: pasif #eef1f5 (açık gri), aktif #fff (= tab-content beyaz, SEAMLESS) */
.theme-tatilsepeti .main-search .nav.nav-pills .nav-link {
  background: #eef1f5 !important; /* PASIF — açık gri (kullanıcı talebi) */
  color: var(--ts-navy) !important;
  border: 0 !important;
  border-radius: 8px 8px 0 0 !important;
  height: 42px !important;
  padding: 0 20px !important;
  font-size: 13px !important;
  font-weight: 500 !important; /* INCE — kullanıcı talebi */
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center;
  gap: 8px !important;
  position: relative;
  transition: background-color .15s ease, color .15s ease;
  white-space: nowrap;
  outline: 0 !important;
  letter-spacing: 0;
  margin: 0 !important;
}
.theme-tatilsepeti .main-search .nav.nav-pills .nav-link i {
  color: var(--ts-navy) !important; /* PASIF ikon: lacivert */
  font-size: 13px !important;
  opacity: 1;
  margin: 0 !important;
}
.theme-tatilsepeti .main-search .nav.nav-pills .nav-link:hover {
  background: #f7f8fb !important;
  color: var(--ts-orange) !important;
}
.theme-tatilsepeti .main-search .nav.nav-pills .nav-link:hover i {
  color: var(--ts-orange) !important;
}
/* AKTIF pill: BEYAZ + lacivert metin + turuncu ikon — alt köşeler keskin (form ile birleşir) */
.theme-tatilsepeti .main-search .nav.nav-pills .nav-link.active {
  background: #fff !important;
  color: var(--ts-navy) !important;
  font-weight: 600 !important;
  box-shadow: 0 -1px 4px rgba(10,42,94,0.04) !important;
  z-index: 6;
}
.theme-tatilsepeti .main-search .nav.nav-pills .nav-link.active i {
  color: var(--ts-orange) !important; /* AKTIF ikon: TURUNCU */
  opacity: 1;
}
/* main.css'in default triangle'ını ve underline'ını GIZLE */
.theme-tatilsepeti .main-search .nav.nav-pills .nav-link.active::after,
.theme-tatilsepeti .main-search .nav.nav-pills .nav-link::after {
  display: none !important;
  content: none !important;
}

/* ===== KESİN ÇÖZÜM: nav-pills wrapper'ına BEYAZ BG ver, böylece pill etraflarında
   ve altında BEYAZ alan var → tab-content beyaz ile SEAMLESS birleşim, lacivert SIZMA YOK.
   ============================================================================ */
.theme-tatilsepeti .main-search > .container > .d-flex {
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: flex-end !important;
  line-height: 0 !important;
  font-size: 0 !important;
  height: auto !important;
  min-height: 42px !important;
  position: relative;
  z-index: 4;
  background: #ffffff !important;        /* WRAPPER BEYAZ — gap KAPATILDI */
  border-radius: var(--ts-radius-lg) var(--ts-radius-lg) 0 0 !important;
  padding: 0 0 0 0 !important;
}
.theme-tatilsepeti .main-search > .container > .d-flex > .nav.nav-pills {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 13px !important;
  align-items: flex-end !important;
  line-height: 1 !important;
  position: relative;
  z-index: 5;
  width: 100%;
}
.theme-tatilsepeti .main-search > .container > .d-flex > .nav.nav-pills .nav-link {
  margin-bottom: 0 !important;
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

/* TAB-CONTENT — wrapper'a yapışık (her ikisi BEYAZ → görsel olarak TEK kart) */
.theme-tatilsepeti .main-search .tab-content,
.theme-tatilsepeti .main-search > .container > .tab-content,
.theme-tatilsepeti .main-search > .container > .d-flex + .tab-content {
  background: #fff !important;
  border-radius: 0 0 var(--ts-radius-lg) var(--ts-radius-lg) !important; /* sadece ALT köşeler radius */
  box-shadow: var(--ts-shadow-xl) !important;
  margin: 0 !important;
  padding: 14px 18px 16px !important;
  border: 0 !important;
  position: relative;
  z-index: 3;
  display: block !important;
}
/* Pill'lerin alt köşeleri keskin → form kartı ile seamless */
.theme-tatilsepeti .main-search .nav.nav-pills .nav-item .nav-link,
.theme-tatilsepeti .main-search .nav.nav-pills .nav-link {
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}
/* Tab-pane iç padding sıfırla — form direkt tepeden başlasın */
.theme-tatilsepeti .main-search .tab-content > .tab-pane {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
.theme-tatilsepeti .main-search .tab-content > .tab-pane > .search-form,
.theme-tatilsepeti .main-search .tab-content > .tab-pane > form {
  margin-top: 0 !important;
  padding-top: 0 !important;
}
.theme-tatilsepeti .main-search .tab-content > .tab-pane > .search-form > .search-list,
.theme-tatilsepeti .main-search .tab-content > .tab-pane .search-list {
  margin-top: 0 !important;
}
/* Wrapper'a tüm-genişlik form kartı için, container content küçülmesin */
.theme-tatilsepeti .main-search > .container {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.theme-tatilsepeti .main-search .tab-content.fixed {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  border-radius: 0 !important;
  padding: 12px 20px !important;
  z-index: 998 !important;
  box-shadow: var(--ts-shadow-lg) !important;
}

/* Form alanları */
.theme-tatilsepeti .main-search .search-form { gap: 12px; }
.theme-tatilsepeti .main-search .search-form .search-list {
  gap: 10px !important;
  height: auto !important;
}
.theme-tatilsepeti .main-search .search-form .search-list .form-group {
  background: var(--ts-bg-soft) !important;
  border: 1.5px solid var(--ts-border) !important;
  border-radius: var(--ts-radius) !important;
  padding: 10px 14px !important;
  min-height: 62px !important;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .main-search .search-form .search-list .form-group:hover {
  border-color: var(--ts-orange-soft) !important;
}
.theme-tatilsepeti .main-search .search-form .search-list .form-group:focus-within {
  border-color: var(--ts-orange) !important;
  background: #fff !important;
  box-shadow: 0 0 0 3px rgba(255,107,0,0.12) !important;
}
.theme-tatilsepeti .main-search .search-form .search-list .form-group .form-label,
.theme-tatilsepeti .main-search .search-form .search-list .form-group label.form-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  color: var(--ts-text-soft) !important;
  margin-bottom: 4px !important;
}
.theme-tatilsepeti .main-search .search-form .search-list .form-group .form-control,
.theme-tatilsepeti .main-search .search-form .search-list .form-group .form-select {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--ts-navy) !important;
  height: auto !important;
  box-shadow: none !important;
}
.theme-tatilsepeti .main-search .search-form .search-list .form-group .room-btn {
  font-weight: 600 !important;
  color: var(--ts-navy) !important;
}

/* Ara butonu — büyük turuncu */
.theme-tatilsepeti .main-search .search-form .search-btn {
  background: var(--ts-orange) !important;
  background-image: linear-gradient(135deg, var(--ts-orange) 0%, var(--ts-orange-hover) 100%) !important;
  color: #fff !important;
  border: 0 !important;
  height: 62px !important;
  min-height: 62px !important;
  padding: 0 32px !important;
  border-radius: var(--ts-radius) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em;
  box-shadow: 0 6px 20px var(--ts-orange-shadow) !important;
  transition: all var(--ts-transition);
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.theme-tatilsepeti .main-search .search-form .search-btn:hover {
  background-image: linear-gradient(135deg, var(--ts-orange-hover) 0%, var(--ts-orange-dark) 100%) !important;
  box-shadow: 0 10px 28px rgba(255,107,0,0.45) !important;
  transform: translateY(-2px);
}
.theme-tatilsepeti .main-search .search-form .search-btn i { font-size: 16px; }

/* Search içi onay kutusu */
.theme-tatilsepeti .main-search .form-check-input { border-color: var(--ts-border-strong); }
.theme-tatilsepeti .main-search .form-check-input:checked {
  background-color: var(--ts-orange) !important;
  border-color: var(--ts-orange) !important;
}
.theme-tatilsepeti .main-search .form-check-label { color: var(--ts-navy); font-weight: 600; }

/* Quantity (oda kişi) */
.theme-tatilsepeti .quantity-wrapper .qty {
  border-radius: var(--ts-radius-sm) !important;
  border-color: var(--ts-border) !important;
}
.theme-tatilsepeti .quantity-wrapper .qty .value-button {
  color: var(--ts-orange) !important;
  background: var(--ts-orange-light);
}
.theme-tatilsepeti .quantity-wrapper .qty .value-button:hover {
  background: var(--ts-orange) !important;
  color: #fff !important;
}

/* ==========================================================================
   5. BUTONLAR — Yeni sistem + eski sınıf eşlemeleri
   ========================================================================== */
.theme-tatilsepeti .btn {
  border-radius: var(--ts-radius) !important;
  font-weight: 600 !important;
  padding: 0.625rem 1.25rem;
  transition: all var(--ts-transition);
  letter-spacing: 0.01em;
}
.theme-tatilsepeti .btn-lg { padding: 0.875rem 1.75rem; font-size: 16px; }
.theme-tatilsepeti .btn-sm { padding: 0.4rem 0.8rem; font-size: 13px; }

.theme-tatilsepeti .btn-ts-primary,
.theme-tatilsepeti .btn-yellow,
.theme-tatilsepeti .btn-red,
.theme-tatilsepeti .btn-primary {
  background: var(--ts-orange) !important;
  background-image: linear-gradient(135deg, var(--ts-orange) 0%, var(--ts-orange-hover) 100%) !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: 0 4px 14px var(--ts-orange-shadow) !important;
}
.theme-tatilsepeti .btn-ts-primary:hover,
.theme-tatilsepeti .btn-yellow:hover,
.theme-tatilsepeti .btn-red:hover,
.theme-tatilsepeti .btn-primary:hover {
  background-image: linear-gradient(135deg, var(--ts-orange-hover) 0%, var(--ts-orange-dark) 100%) !important;
  box-shadow: 0 8px 24px rgba(255,107,0,0.40) !important;
  transform: translateY(-1px);
  color: #fff !important;
}

.theme-tatilsepeti .btn-ts-secondary,
.theme-tatilsepeti .btn-default {
  background: var(--ts-navy) !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: 0 4px 14px var(--ts-navy-shadow) !important;
}
.theme-tatilsepeti .btn-ts-secondary:hover,
.theme-tatilsepeti .btn-default:hover {
  background: var(--ts-navy-dark) !important;
  color: #fff !important;
  transform: translateY(-1px);
}

.theme-tatilsepeti .btn-ts-outline,
.theme-tatilsepeti .btn-outline-yellow {
  background: transparent !important;
  color: var(--ts-orange) !important;
  border: 2px solid var(--ts-orange) !important;
}
.theme-tatilsepeti .btn-ts-outline:hover,
.theme-tatilsepeti .btn-outline-yellow:hover {
  background: var(--ts-orange) !important;
  color: #fff !important;
  box-shadow: 0 6px 20px var(--ts-orange-shadow);
}

.theme-tatilsepeti .btn-ts-success {
  background: var(--ts-success) !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: 0 4px 14px rgba(34,197,94,0.30) !important;
}
.theme-tatilsepeti .btn-ts-success:hover { background: #16a34a !important; transform: translateY(-1px); }

.theme-tatilsepeti .btn-ts-pill { border-radius: var(--ts-radius-pill) !important; }

.theme-tatilsepeti .btn-ts-ghost {
  background: transparent !important;
  color: var(--ts-navy) !important;
  border: 0 !important;
}
.theme-tatilsepeti .btn-ts-ghost:hover { color: var(--ts-orange) !important; background: var(--ts-orange-light) !important; }

/* btn-dark eski sınıfı header dışında lacivert kalsın */
.theme-tatilsepeti .btn-dark {
  background: var(--ts-navy) !important;
  color: #fff !important;
  border: 0 !important;
}
.theme-tatilsepeti .btn-dark:hover { background: var(--ts-navy-dark) !important; color: #fff !important; }

/* ==========================================================================
   6. KART SİSTEMİ — Otel / Tur / Feribot / Transfer
   ========================================================================== */
.theme-tatilsepeti .ts-card,
.theme-tatilsepeti .ts-card-hotel,
.theme-tatilsepeti .ts-card-tour {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  box-shadow: var(--ts-shadow-sm);
  overflow: hidden;
  transition: all var(--ts-transition);
  display: flex;
  flex-direction: column;
  height: 100%;
  position: relative;
  border: 1px solid var(--ts-border);
}
.theme-tatilsepeti .ts-card:hover,
.theme-tatilsepeti .ts-card-hotel:hover,
.theme-tatilsepeti .ts-card-tour:hover {
  transform: translateY(-4px);
  box-shadow: var(--ts-shadow-lg);
  border-color: var(--ts-orange-soft);
}
.theme-tatilsepeti .ts-card-image {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--ts-bg);
}
.theme-tatilsepeti .ts-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--ts-transition-slow);
}
.theme-tatilsepeti .ts-card:hover .ts-card-image img,
.theme-tatilsepeti .ts-card-hotel:hover .ts-card-image img { transform: scale(1.06); }

/* Kompakt kart body — Tatilsepeti tarzı dar dikey aralıklar */
.theme-tatilsepeti .ts-card-body {
  padding: 12px 14px 14px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 0;
}
.theme-tatilsepeti .ts-card-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--ts-navy);
  margin: 0 0 4px;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.5em; /* tüm kartlar 2 satır kadar yer kaplasın → eşit hizalama */
}
.theme-tatilsepeti .ts-card-location {
  font-size: 12.5px;
  color: var(--ts-text-soft);
  margin: 0 0 4px;
  display: flex;
  align-items: center;
  gap: 4px;
  line-height: 1.3;
}
.theme-tatilsepeti .ts-card-location i { color: var(--ts-orange); font-size: 11px; }
.theme-tatilsepeti .ts-card-stars { color: var(--ts-warning); font-size: 12px; margin: 0 0 6px; line-height: 1; }
.theme-tatilsepeti .ts-card-stars i { margin-right: 1px; }
.theme-tatilsepeti .ts-card-tagline {
  font-size: 11px;
  font-weight: 600;
  color: var(--ts-navy);
  background: var(--ts-orange-light);
  padding: 4px 8px;
  border-radius: var(--ts-radius-sm);
  margin: 0 0 8px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  align-self: flex-start;
  line-height: 1.2;
}
.theme-tatilsepeti .ts-card-tagline i { color: var(--ts-orange); font-size: 10px; }

.theme-tatilsepeti .ts-card-footer {
  margin-top: auto;
  padding-top: 8px;
  border-top: 1px dashed var(--ts-border);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 8px;
}
.theme-tatilsepeti .ts-price { display: flex; flex-direction: column; line-height: 1.15; }
.theme-tatilsepeti .ts-price-old {
  font-size: 12px;
  color: var(--ts-text-muted);
  text-decoration: line-through;
  line-height: 1.2;
}
.theme-tatilsepeti .ts-price-new {
  font-size: 19px;
  font-weight: 800;
  color: var(--ts-orange);
  line-height: 1.1;
}
.theme-tatilsepeti .ts-price-currency { font-size: 12px; font-weight: 600; }
.theme-tatilsepeti .ts-price-night { font-size: 10.5px; color: var(--ts-text-soft); margin-top: 1px; line-height: 1.2; }

.theme-tatilsepeti .ts-card-cta {
  background: var(--ts-orange);
  color: #fff;
  padding: 7px 12px;
  border-radius: var(--ts-radius);
  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
  border: 0;
  cursor: pointer;
  transition: all var(--ts-transition);
  box-shadow: 0 2px 8px rgba(255,107,0,0.25);
  line-height: 1.2;
}
.theme-tatilsepeti .ts-card-cta:hover {
  background: var(--ts-orange-hover);
  color: #fff;
  box-shadow: 0 6px 16px var(--ts-orange-shadow);
  transform: translateY(-1px);
}

/* "Sizin İçin Seçtiklerimiz" Owl Carousel için daha da sıkı kompakt görünüm
   Owl-stage flex + align-items: stretch → tüm slaytlar EŞİT YÜKSEKLİKTE */
.theme-tatilsepeti #tsSelectedCarousel .ts-card-image {
  aspect-ratio: 4 / 3 !important;
  width: 100% !important;
  height: auto !important;
  flex-shrink: 0;
}
.theme-tatilsepeti #tsSelectedCarousel .ts-card-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}
.theme-tatilsepeti #tsSelectedCarousel .ts-card-body { padding: 10px 12px 12px; }
.theme-tatilsepeti #tsSelectedCarousel .ts-card-title { font-size: 14px; min-height: 2.4em; margin-bottom: 3px; }
.theme-tatilsepeti #tsSelectedCarousel .ts-card-location { font-size: 12px; margin-bottom: 3px; }
.theme-tatilsepeti #tsSelectedCarousel .ts-card-stars { margin-bottom: 4px; font-size: 11px; }
.theme-tatilsepeti #tsSelectedCarousel .ts-card-tagline { display: none; }
.theme-tatilsepeti #tsSelectedCarousel .ts-price-new { font-size: 17px; }
.theme-tatilsepeti #tsSelectedCarousel .ts-card-cta { padding: 6px 10px; font-size: 11.5px; }
.theme-tatilsepeti #tsSelectedCarousel .owl-stage {
  display: flex !important;
  align-items: stretch !important;
}
.theme-tatilsepeti #tsSelectedCarousel .owl-item {
  display: flex !important;
  flex-direction: column;
}
.theme-tatilsepeti #tsSelectedCarousel .owl-item > .ts-card-hotel,
.theme-tatilsepeti #tsSelectedCarousel .owl-item .ts-card-hotel {
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column;
}

/* Badge'ler */
.theme-tatilsepeti .ts-badge {
  position: absolute;
  z-index: 3;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 10px;
  border-radius: var(--ts-radius-sm);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.theme-tatilsepeti .ts-badge-discount {
  top: 12px;
  left: 12px;
  background: var(--ts-orange);
}
.theme-tatilsepeti .ts-badge-new {
  top: 12px;
  left: 12px;
  background: var(--ts-success);
}
.theme-tatilsepeti .ts-badge-soldout {
  top: 12px;
  left: 12px;
  background: var(--ts-danger);
}
.theme-tatilsepeti .ts-badge-popular {
  top: 12px;
  right: 12px;
  background: var(--ts-navy);
}

/* Wishlist */
.theme-tatilsepeti .ts-wishlist {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 4;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ts-text-soft);
  border: 0;
  cursor: pointer;
  transition: all var(--ts-transition);
  box-shadow: var(--ts-shadow-sm);
}
.theme-tatilsepeti .ts-wishlist:hover { color: var(--ts-orange); transform: scale(1.1); }
.theme-tatilsepeti .ts-wishlist.active { color: var(--ts-orange); }

/* ==========================================================================
   7. KAMPANYA ŞERİDİ (Promo pills)
   ========================================================================== */
.theme-tatilsepeti .ts-campaign-strip {
  background: #fff;
  padding: 18px 0;
  border-bottom: 1px solid var(--ts-border);
  position: relative;
}
.theme-tatilsepeti .ts-campaign-strip-track {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: thin;
  scrollbar-color: var(--ts-orange) transparent;
  padding: 4px 0;
}
.theme-tatilsepeti .ts-campaign-strip-track::-webkit-scrollbar { height: 6px; }
.theme-tatilsepeti .ts-campaign-strip-track::-webkit-scrollbar-thumb { background: var(--ts-orange); border-radius: 3px; }
.theme-tatilsepeti .ts-promo-pill {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  background: var(--ts-orange-light);
  border: 1px solid var(--ts-orange-soft);
  border-radius: var(--ts-radius-pill);
  color: var(--ts-navy);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  transition: all var(--ts-transition);
  white-space: nowrap;
}
.theme-tatilsepeti .ts-promo-pill i { color: var(--ts-orange); font-size: 16px; }
.theme-tatilsepeti .ts-promo-pill:hover {
  background: var(--ts-orange);
  color: #fff;
  border-color: var(--ts-orange);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px var(--ts-orange-shadow);
}
.theme-tatilsepeti .ts-promo-pill:hover i { color: #fff; }

/* ==========================================================================
   8. SECTION BAŞLIKLARI
   ========================================================================== */
.theme-tatilsepeti .ts-section { padding: 56px 0; }
.theme-tatilsepeti .ts-section-tight { padding: 36px 0; }
.theme-tatilsepeti .ts-section-bg { background: var(--ts-bg); }
.theme-tatilsepeti .ts-section-navy { background: var(--ts-navy); color: #fff; }

.theme-tatilsepeti .ts-section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 28px;
}
.theme-tatilsepeti .ts-section-head .ts-section-title {
  font-size: 26px;
  font-weight: 800;
  color: var(--ts-navy);
  margin: 0 0 4px;
  line-height: 1.2;
}
.theme-tatilsepeti .ts-section-navy .ts-section-head .ts-section-title { color: #fff; }
.theme-tatilsepeti .ts-section-head .ts-section-subtitle {
  font-size: 15px;
  color: var(--ts-text-soft);
  margin: 0;
}
.theme-tatilsepeti .ts-section-navy .ts-section-head .ts-section-subtitle { color: rgba(255,255,255,0.78); }
.theme-tatilsepeti .ts-section-head .ts-section-link {
  font-size: 14px;
  font-weight: 700;
  color: var(--ts-orange);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.theme-tatilsepeti .ts-section-head .ts-section-link:hover { color: var(--ts-orange-hover); gap: 10px; }

/* ==========================================================================
   9. KATEGORİ SEKMELİ GALERİ (Antalya/Ege/Kıbrıs/Termal/Şehir/...)
   ========================================================================== */
.theme-tatilsepeti .ts-category-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: thin;
  margin-bottom: 24px;
  padding-bottom: 4px;
}
.theme-tatilsepeti .ts-category-tab {
  flex-shrink: 0;
  padding: 10px 18px;
  border-radius: var(--ts-radius-pill);
  background: #fff;
  border: 1.5px solid var(--ts-border);
  color: var(--ts-navy);
  text-decoration: none;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-category-tab:hover {
  border-color: var(--ts-orange);
  color: var(--ts-orange);
}
.theme-tatilsepeti .ts-category-tab.active {
  background: var(--ts-orange);
  border-color: var(--ts-orange);
  color: #fff;
  box-shadow: 0 4px 14px var(--ts-orange-shadow);
}

.theme-tatilsepeti .ts-category-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 991px) { .theme-tatilsepeti .ts-category-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .theme-tatilsepeti .ts-category-grid { grid-template-columns: 1fr; } }

.theme-tatilsepeti .ts-destination-card {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--ts-radius-lg);
  overflow: hidden;
  display: block;
  text-decoration: none;
  box-shadow: var(--ts-shadow-sm);
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-destination-card:hover { transform: translateY(-4px); box-shadow: var(--ts-shadow-lg); }
.theme-tatilsepeti .ts-destination-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--ts-transition-slow);
}
.theme-tatilsepeti .ts-destination-card:hover img { transform: scale(1.08); }
.theme-tatilsepeti .ts-destination-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(10,42,94,0.85) 100%);
  pointer-events: none;
}
.theme-tatilsepeti .ts-destination-card .ts-destination-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 18px;
  z-index: 2;
  color: #fff;
}
.theme-tatilsepeti .ts-destination-card .ts-destination-overlay h3 {
  color: #fff !important;
  font-size: 18px;
  font-weight: 800;
  margin: 0 0 4px;
}
.theme-tatilsepeti .ts-destination-card .ts-destination-overlay p {
  margin: 0;
  font-size: 13px;
  color: rgba(255,255,255,0.85);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.theme-tatilsepeti .ts-destination-card .ts-destination-overlay .ts-destination-price {
  background: var(--ts-orange);
  padding: 4px 10px;
  border-radius: var(--ts-radius-sm);
  font-weight: 700;
  font-size: 12px;
  color: #fff;
}

/* ==========================================================================
   10. 3 KOLONLU TUR PAKETLERİ
   ========================================================================== */
.theme-tatilsepeti .ts-tour-columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 991px) { .theme-tatilsepeti .ts-tour-columns { grid-template-columns: 1fr; } }

.theme-tatilsepeti .ts-tour-column {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  overflow: hidden;
  box-shadow: var(--ts-shadow-sm);
  display: flex;
  flex-direction: column;
  transition: transform var(--ts-transition);
}
.theme-tatilsepeti .ts-tour-column:hover { transform: translateY(-4px); box-shadow: var(--ts-shadow); }
.theme-tatilsepeti .ts-tour-column-head {
  position: relative;
  height: 180px;
  overflow: hidden;
}
.theme-tatilsepeti .ts-tour-column-head img {
  width: 100%; height: 100%; object-fit: cover;
}
.theme-tatilsepeti .ts-tour-column-head::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(10,42,94,0.85) 100%);
}
.theme-tatilsepeti .ts-tour-column-head h3 {
  position: absolute;
  bottom: 16px;
  left: 18px;
  right: 18px;
  color: #fff !important;
  font-size: 20px;
  font-weight: 800;
  margin: 0;
  z-index: 2;
}
.theme-tatilsepeti .ts-tour-column-body {
  padding: 18px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.theme-tatilsepeti .ts-tour-column-body ul {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
}
.theme-tatilsepeti .ts-tour-column-body ul li {
  border-bottom: 1px dashed var(--ts-border);
  padding: 10px 0;
}
.theme-tatilsepeti .ts-tour-column-body ul li:last-child { border-bottom: 0; }
.theme-tatilsepeti .ts-tour-column-body ul li a {
  color: var(--ts-navy);
  font-size: 14px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-decoration: none;
  transition: color var(--ts-transition);
}
.theme-tatilsepeti .ts-tour-column-body ul li a::after {
  content: '\f054'; font-family: 'Font Awesome 5 Free'; font-weight: 900; font-size: 11px; color: var(--ts-text-muted);
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-tour-column-body ul li a:hover { color: var(--ts-orange); }
.theme-tatilsepeti .ts-tour-column-body ul li a:hover::after { color: var(--ts-orange); transform: translateX(2px); }
.theme-tatilsepeti .ts-tour-column-body .ts-tour-link {
  margin-top: auto;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--ts-orange);
  padding: 8px;
  border-top: 1px solid var(--ts-border);
}

/* ==========================================================================
   11. SEO İÇERİK BLOKLARI (accordion)
   ========================================================================== */
.theme-tatilsepeti .ts-seo-section { background: #fff; padding: 48px 0; }
.theme-tatilsepeti .ts-seo-block { margin-bottom: 16px; }
.theme-tatilsepeti .ts-seo-block summary {
  list-style: none;
  cursor: pointer;
  padding: 18px 22px;
  background: var(--ts-bg);
  border-radius: var(--ts-radius);
  font-size: 17px;
  font-weight: 700;
  color: var(--ts-navy);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 1px solid var(--ts-border);
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-seo-block summary::-webkit-details-marker { display: none; }
.theme-tatilsepeti .ts-seo-block summary::after {
  content: '\f067'; font-family: 'Font Awesome 5 Free'; font-weight: 900;
  color: var(--ts-orange);
  transition: transform var(--ts-transition);
}
.theme-tatilsepeti .ts-seo-block[open] summary {
  background: var(--ts-orange-light);
  border-color: var(--ts-orange-soft);
  color: var(--ts-navy);
  border-radius: var(--ts-radius) var(--ts-radius) 0 0;
}
.theme-tatilsepeti .ts-seo-block[open] summary::after { content: '\f068'; }
.theme-tatilsepeti .ts-seo-block .ts-seo-content {
  padding: 20px 22px;
  background: #fff;
  border: 1px solid var(--ts-orange-soft);
  border-top: 0;
  border-radius: 0 0 var(--ts-radius) var(--ts-radius);
  font-size: 14px;
  line-height: 1.75;
  color: var(--ts-text);
}
.theme-tatilsepeti .ts-seo-block .ts-seo-content h2,
.theme-tatilsepeti .ts-seo-block .ts-seo-content h3 {
  color: var(--ts-orange);
  font-size: 18px;
  margin: 16px 0 8px;
}
.theme-tatilsepeti .ts-seo-block .ts-seo-content a { color: var(--ts-orange); font-weight: 600; }
.theme-tatilsepeti .ts-seo-block .ts-seo-content a:hover { text-decoration: underline; }

/* ==========================================================================
   12. GÜVEN BANDI (Trust Band — Nielsen, TURSAB, IATA, 444...)
   ========================================================================== */
.theme-tatilsepeti .ts-trust-band {
  background: var(--ts-bg);
  padding: 48px 0;
}
.theme-tatilsepeti .ts-trust-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
@media (max-width: 991px) { .theme-tatilsepeti .ts-trust-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .theme-tatilsepeti .ts-trust-grid { grid-template-columns: 1fr; } }

.theme-tatilsepeti .ts-trust-card {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  padding: 24px 20px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  box-shadow: var(--ts-shadow-sm);
  border: 1px solid var(--ts-border);
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-trust-card:hover {
  border-color: var(--ts-orange-soft);
  box-shadow: var(--ts-shadow);
  transform: translateY(-2px);
}
.theme-tatilsepeti .ts-trust-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--ts-orange-light);
  color: var(--ts-orange);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  flex-shrink: 0;
}
.theme-tatilsepeti .ts-trust-content h4 {
  font-size: 15px;
  font-weight: 800;
  color: var(--ts-navy);
  margin: 0 0 6px;
}
.theme-tatilsepeti .ts-trust-content p {
  font-size: 13px;
  color: var(--ts-text-soft);
  margin: 0;
  line-height: 1.5;
}
.theme-tatilsepeti .ts-trust-content a {
  font-size: 13px;
  font-weight: 700;
  color: var(--ts-orange);
  display: inline-block;
  margin-top: 4px;
}

/* ==========================================================================
   13. E-BÜLTEN BANDI (Newsletter)
   ========================================================================== */
.theme-tatilsepeti .ts-newsletter,
.theme-tatilsepeti .subscribe {
  background: var(--ts-navy) !important;
  background-image: linear-gradient(135deg, var(--ts-navy) 0%, var(--ts-navy-light) 100%) !important;
  padding: 22px 0 !important;
  position: relative;
  overflow: hidden;
}
.theme-tatilsepeti .ts-newsletter::before,
.theme-tatilsepeti .subscribe::before {
  content: '';
  position: absolute;
  top: -50%; right: -10%;
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(255,107,0,0.16), transparent 70%);
  pointer-events: none;
}
.theme-tatilsepeti .subscribe .container { position: relative; z-index: 2; }

.theme-tatilsepeti .subscribe .subscribe-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 18px 28px;
}

.theme-tatilsepeti .subscribe .subscribe-left {
  flex: 1 1 460px;
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px 18px;
}
.theme-tatilsepeti .subscribe .subscribe-left .title {
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  margin: 0 !important;
  flex: 0 0 auto;
}
.theme-tatilsepeti .subscribe .subscribe-form { flex: 1 1 320px; margin: 0; }
.theme-tatilsepeti .subscribe .subscribe-form .form-group { margin: 0; }
.theme-tatilsepeti .subscribe .subscribe-form .form-control {
  background: #fff !important;
  border: 0 !important;
  border-radius: var(--ts-radius) !important;
  padding: 11px 16px !important;
  font-size: 14px !important;
  color: var(--ts-navy) !important;
  flex: 1 1 220px;
  min-width: 200px;
  height: 44px;
  line-height: 1.2;
}
.theme-tatilsepeti .subscribe .subscribe-form .form-control::placeholder { color: var(--ts-text-soft); }
.theme-tatilsepeti .subscribe .subscribe-form .btn-yellow {
  background: var(--ts-orange) !important;
  background-image: linear-gradient(135deg, var(--ts-orange) 0%, var(--ts-orange-hover) 100%) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: var(--ts-radius) !important;
  padding: 0 22px !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  height: 44px;
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}
.theme-tatilsepeti .subscribe .subscribe-form .btn-yellow:hover { transform: translateY(-1px); box-shadow: 0 6px 18px var(--ts-orange-shadow); }

.theme-tatilsepeti .subscribe .subscribe-right {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: #fff;
  padding: 6px 14px;
  border-radius: var(--ts-radius);
  background: rgba(255,255,255,0.06);
  transition: var(--ts-transition);
}
.theme-tatilsepeti .subscribe .subscribe-right:hover { background: rgba(255,255,255,0.12); transform: translateY(-1px); }
.theme-tatilsepeti .subscribe .subscribe-right > i {
  font-size: 26px;
  color: var(--ts-orange);
  line-height: 1;
}
.theme-tatilsepeti .subscribe .subscribe-right .phone-text { display: flex; flex-direction: column; line-height: 1.2; }
.theme-tatilsepeti .subscribe .subscribe-right .phone-text small { color: rgba(255,255,255,0.78); font-size: 11px; letter-spacing: 0.5px; font-weight: 600; text-transform: uppercase; }
.theme-tatilsepeti .subscribe .subscribe-right .phone-text strong { color: #fff; font-size: 18px; font-weight: 800; letter-spacing: 0.3px; }

@media (max-width: 767px) {
  .theme-tatilsepeti .subscribe { padding: 18px 0 !important; }
  .theme-tatilsepeti .subscribe .subscribe-left { flex-direction: column; align-items: flex-start; gap: 10px; }
  .theme-tatilsepeti .subscribe .subscribe-left .title { font-size: 14px !important; }
  .theme-tatilsepeti .subscribe .subscribe-row { gap: 14px; }
  .theme-tatilsepeti .subscribe .subscribe-right { width: 100%; justify-content: center; }
}

/* ==========================================================================
   14. FOOTER (5 kolonlu, geniş)
   ========================================================================== */
.theme-tatilsepeti footer {
  background: #fff !important;
  border-top: 0 !important;
}

.theme-tatilsepeti .ts-footer-cta {
  background: var(--ts-navy);
  padding: 24px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.theme-tatilsepeti .ts-footer-cta .container {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}
@media (max-width: 991px) { .theme-tatilsepeti .ts-footer-cta .container { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .theme-tatilsepeti .ts-footer-cta .container { grid-template-columns: 1fr; } }

.theme-tatilsepeti .ts-footer-cta-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: rgba(255,255,255,0.06);
  border-radius: var(--ts-radius);
  color: #fff;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,0.08);
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-footer-cta-item:hover {
  background: var(--ts-orange);
  border-color: var(--ts-orange);
  color: #fff;
  transform: translateY(-2px);
}
.theme-tatilsepeti .ts-footer-cta-item i {
  font-size: 22px;
  color: var(--ts-orange);
  width: 32px;
  text-align: center;
  transition: color var(--ts-transition);
}
.theme-tatilsepeti .ts-footer-cta-item:hover i { color: #fff; }
.theme-tatilsepeti .ts-footer-cta-item .ts-footer-cta-text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}
.theme-tatilsepeti .ts-footer-cta-item .ts-footer-cta-text small {
  font-size: 11px;
  color: rgba(255,255,255,0.7);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.theme-tatilsepeti .ts-footer-cta-item:hover .ts-footer-cta-text small { color: rgba(255,255,255,0.9); }
.theme-tatilsepeti .ts-footer-cta-item .ts-footer-cta-text strong { font-size: 15px; font-weight: 700; }

/* Ana 5 kolonlu footer */
.theme-tatilsepeti .ts-footer-main {
  background: #fff;
  padding: 56px 0 36px;
  border-bottom: 1px solid var(--ts-border);
}
.theme-tatilsepeti .ts-footer-cols {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px;
}
@media (max-width: 1199px) { .theme-tatilsepeti .ts-footer-cols { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px)  { .theme-tatilsepeti .ts-footer-cols { grid-template-columns: repeat(2, 1fr); gap: 24px; } }
@media (max-width: 480px)  { .theme-tatilsepeti .ts-footer-cols { grid-template-columns: 1fr; } }

.theme-tatilsepeti .ts-footer-col h5 {
  font-size: 13px;
  font-weight: 800;
  color: var(--ts-navy);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--ts-orange);
  display: inline-block;
}
.theme-tatilsepeti .ts-footer-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.theme-tatilsepeti .ts-footer-col ul li { margin: 0; }
.theme-tatilsepeti .ts-footer-col ul li a {
  display: block;
  padding: 6px 0;
  color: var(--ts-text-soft);
  font-size: 13px;
  text-decoration: none;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-footer-col ul li a:hover { color: var(--ts-orange); padding-left: 6px; }

/* Footer alt çizgi: sosyal medya + kurumsal linkler */
.theme-tatilsepeti footer .footer-bottom-list {
  background: var(--ts-navy-dark) !important;
  padding: 18px 0 !important;
}
.theme-tatilsepeti footer .footer-bottom-list .container {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap;
  gap: 14px;
}
.theme-tatilsepeti footer .footer-bottom-list .social-list { gap: 8px; }
.theme-tatilsepeti footer .footer-bottom-list .social-list li { margin: 0 !important; }
.theme-tatilsepeti footer .footer-bottom-list .social-list li a {
  width: 36px; height: 36px;
  display: flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  color: #fff !important;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti footer .footer-bottom-list .social-list li a:hover {
  background: var(--ts-orange) !important;
  color: #fff !important;
  transform: translateY(-2px);
}
.theme-tatilsepeti footer .footer-bottom-list .footer-bottom-menu {
  flex-wrap: wrap;
  gap: 4px 0;
}
.theme-tatilsepeti footer .footer-bottom-list .footer-bottom-menu a {
  color: rgba(255,255,255,0.78) !important;
  font-size: 12px !important;
  margin: 0 14px 0 0 !important;
  font-weight: 500;
}
.theme-tatilsepeti footer .footer-bottom-list .footer-bottom-menu a:hover { color: var(--ts-orange) !important; }
.theme-tatilsepeti footer .footer-bottom-list .text-gray { color: rgba(255,255,255,0.78) !important; }

/* Footer alt: ödeme/güven logoları + telif */
.theme-tatilsepeti footer .bg-white {
  background: #fff !important;
  padding: 26px 0 !important;
  color: var(--ts-text-soft) !important;
}
.theme-tatilsepeti footer .footer-icon-wrapper {
  gap: 24px;
  flex-wrap: wrap;
}
.theme-tatilsepeti footer .footer-icon-wrapper .footer-logo img {
  filter: grayscale(0.5);
  opacity: 0.85;
  transition: all var(--ts-transition);
  margin: 0 !important;
}
.theme-tatilsepeti footer .footer-icon-wrapper .footer-logo img:hover { filter: none; opacity: 1; }
.theme-tatilsepeti footer .bg-white .text-muted,
.theme-tatilsepeti footer .bg-white { color: var(--ts-text-soft) !important; font-size: 12px !important; }
.theme-tatilsepeti footer .bg-white a { color: var(--ts-orange) !important; }
.theme-tatilsepeti footer .bg-white a:hover { text-decoration: underline; }

/* ==========================================================================
   15. MOBİL BOTTOM-BAR
   ========================================================================== */
.theme-tatilsepeti .mobile-bottom {
  background: #fff !important;
  border-top: 1px solid var(--ts-border) !important;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
}
.theme-tatilsepeti .mobile-bottom .phone-no {
  background: var(--ts-orange) !important;
  color: #fff !important;
  border-radius: 0 !important;
}
.theme-tatilsepeti .mobile-bottom .whatsapp {
  background: #25D366 !important;
  color: #fff !important;
}

/* ==========================================================================
   16. FORM, MODAL, DROPDOWN, TOAST
   ========================================================================== */
.theme-tatilsepeti .form-control,
.theme-tatilsepeti .form-select {
  border-radius: var(--ts-radius-sm) !important;
  border-color: var(--ts-border) !important;
  font-size: 14px !important;
  padding: 0.625rem 0.875rem;
}
.theme-tatilsepeti .form-control:focus,
.theme-tatilsepeti .form-select:focus {
  border-color: var(--ts-orange) !important;
  box-shadow: 0 0 0 3px rgba(255,107,0,0.12) !important;
}
.theme-tatilsepeti .form-label { font-weight: 600; color: var(--ts-navy); font-size: 13px; }
.theme-tatilsepeti .form-check-input:checked { background-color: var(--ts-orange) !important; border-color: var(--ts-orange) !important; }

.theme-tatilsepeti .modal-content {
  border-radius: var(--ts-radius-lg) !important;
  border: 0 !important;
  box-shadow: var(--ts-shadow-xl) !important;
  overflow: hidden;
}
.theme-tatilsepeti .modal-header {
  background: var(--ts-navy) !important;
  color: #fff !important;
  border-bottom: 0 !important;
  padding: 16px 22px !important;
}
.theme-tatilsepeti .modal-header .modal-title { color: #fff !important; font-weight: 700; }
.theme-tatilsepeti .modal-header .btn-close { filter: invert(1) brightness(2); }
.theme-tatilsepeti .modal-body { padding: 22px !important; }
.theme-tatilsepeti .modal-footer {
  border-top-color: var(--ts-border) !important;
  padding: 14px 22px !important;
}

.theme-tatilsepeti .dropdown-menu {
  border-radius: var(--ts-radius) !important;
  border: 1px solid var(--ts-border) !important;
  box-shadow: var(--ts-shadow-lg) !important;
  padding: 6px !important;
}
.theme-tatilsepeti .dropdown-item {
  border-radius: var(--ts-radius-sm) !important;
  padding: 8px 12px !important;
  font-size: 14px;
  color: var(--ts-navy);
}
.theme-tatilsepeti .dropdown-item:hover {
  background: var(--ts-orange-light) !important;
  color: var(--ts-orange) !important;
}
.theme-tatilsepeti .dropdown-item.active { background: var(--ts-orange) !important; color: #fff !important; }

.theme-tatilsepeti .alert { border-radius: var(--ts-radius); border-width: 0; padding: 14px 18px; font-size: 14px; }
.theme-tatilsepeti .alert-success { background: var(--ts-success-light); color: #166534; }
.theme-tatilsepeti .alert-warning { background: var(--ts-warning-light); color: #854D0E; }
.theme-tatilsepeti .alert-danger  { background: var(--ts-danger-light); color: #991B1B; }
.theme-tatilsepeti .alert-info    { background: #DBEAFE; color: #1E40AF; }

/* ==========================================================================
   17. SAYFA — LISTE (Otel/Tur/Feribot/Transfer)
   ========================================================================== */
.theme-tatilsepeti .ts-list-wrapper {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  padding: 32px 0;
}
@media (max-width: 991px) { .theme-tatilsepeti .ts-list-wrapper { grid-template-columns: 1fr; } }

.theme-tatilsepeti .ts-list-filter {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  padding: 20px;
  border: 1px solid var(--ts-border);
  position: sticky;
  top: 180px;
  align-self: start;
  max-height: calc(100vh - 200px);
  overflow-y: auto;
}
.theme-tatilsepeti .ts-filter-group {
  border-bottom: 1px solid var(--ts-border);
  padding: 14px 0;
}
.theme-tatilsepeti .ts-filter-group:first-child { padding-top: 0; }
.theme-tatilsepeti .ts-filter-group:last-child { border-bottom: 0; }
.theme-tatilsepeti .ts-filter-group h6 {
  font-size: 13px;
  font-weight: 800;
  color: var(--ts-navy);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 12px;
}
.theme-tatilsepeti .ts-filter-group .form-check { margin-bottom: 6px; }
.theme-tatilsepeti .ts-filter-group .form-check-label { font-size: 13px; color: var(--ts-text); }

.theme-tatilsepeti .ts-list-results {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.theme-tatilsepeti .ts-list-toolbar {
  background: #fff;
  border-radius: var(--ts-radius);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  border: 1px solid var(--ts-border);
  margin-bottom: 4px;
}
.theme-tatilsepeti .ts-list-toolbar .ts-result-count {
  font-size: 14px;
  color: var(--ts-text-soft);
}
.theme-tatilsepeti .ts-list-toolbar .ts-result-count strong { color: var(--ts-navy); }
.theme-tatilsepeti .ts-list-toolbar .ts-sort {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.theme-tatilsepeti .ts-list-toolbar .ts-sort .form-select {
  width: auto !important;
  min-width: 180px;
  padding: 6px 28px 6px 12px !important;
  font-size: 13px !important;
}

/* Yatay otel kartı (liste için) */
.theme-tatilsepeti .ts-card-list {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  border: 1px solid var(--ts-border);
  display: grid;
  grid-template-columns: 280px 1fr 200px;
  overflow: hidden;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-card-list:hover { box-shadow: var(--ts-shadow); border-color: var(--ts-orange-soft); transform: translateY(-2px); }
.theme-tatilsepeti .ts-card-list .ts-card-list-image {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.theme-tatilsepeti .ts-card-list .ts-card-list-image img {
  width: 100%; height: 100%; object-fit: cover;
}
.theme-tatilsepeti .ts-card-list .ts-card-list-body {
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
}
.theme-tatilsepeti .ts-card-list .ts-card-list-body .ts-card-title {
  font-size: 18px;
  margin-bottom: 4px;
  -webkit-line-clamp: 1;
}
.theme-tatilsepeti .ts-card-list .ts-card-list-body .ts-card-features {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.theme-tatilsepeti .ts-card-list .ts-card-list-body .ts-card-features span {
  font-size: 11px;
  background: var(--ts-bg);
  color: var(--ts-text-soft);
  padding: 4px 10px;
  border-radius: var(--ts-radius-pill);
  font-weight: 600;
}
.theme-tatilsepeti .ts-card-list .ts-card-list-pricing {
  background: var(--ts-bg-soft);
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 10px;
  border-left: 1px solid var(--ts-border);
}

@media (max-width: 767px) {
  .theme-tatilsepeti .ts-card-list { grid-template-columns: 1fr; }
  .theme-tatilsepeti .ts-card-list .ts-card-list-pricing { border-left: 0; border-top: 1px solid var(--ts-border); align-items: flex-start; }
  .theme-tatilsepeti .ts-list-filter { position: static; max-height: none; }
}

/* ==========================================================================
   18. DETAY SAYFALARI (Otel/Tur/Feribot)
   ========================================================================== */
.theme-tatilsepeti .ts-detail-hero {
  background: #fff;
  padding: 22px 0 16px;
  border-bottom: 1px solid var(--ts-border);
}
.theme-tatilsepeti .ts-detail-breadcrumb {
  font-size: 12px;
  color: var(--ts-text-muted);
  margin-bottom: 8px;
}
.theme-tatilsepeti .ts-detail-breadcrumb a { color: var(--ts-text-soft); }
.theme-tatilsepeti .ts-detail-breadcrumb a:hover { color: var(--ts-orange); }
.theme-tatilsepeti .ts-detail-breadcrumb .ts-sep { margin: 0 6px; opacity: 0.5; }

.theme-tatilsepeti .ts-detail-title {
  font-size: 28px;
  font-weight: 800;
  color: var(--ts-navy);
  margin: 0 0 6px;
}
.theme-tatilsepeti .ts-detail-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--ts-text-soft);
}
.theme-tatilsepeti .ts-detail-meta .ts-stars { color: var(--ts-warning); }
.theme-tatilsepeti .ts-detail-meta .ts-loc i { color: var(--ts-orange); margin-right: 4px; }

.theme-tatilsepeti .ts-detail-gallery {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 200px 200px;
  gap: 8px;
  border-radius: var(--ts-radius-lg);
  overflow: hidden;
  margin-top: 16px;
}
.theme-tatilsepeti .ts-detail-gallery > a:first-child { grid-row: 1 / 3; }
.theme-tatilsepeti .ts-detail-gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--ts-transition-slow);
}
.theme-tatilsepeti .ts-detail-gallery a { display: block; overflow: hidden; }
.theme-tatilsepeti .ts-detail-gallery a:hover img { transform: scale(1.04); }
@media (max-width: 767px) {
  .theme-tatilsepeti .ts-detail-gallery { grid-template-columns: 1fr; grid-template-rows: 250px; }
  .theme-tatilsepeti .ts-detail-gallery > a:not(:first-child) { display: none; }
}

.theme-tatilsepeti .ts-detail-body {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 24px;
  padding: 24px 0 48px;
}
@media (max-width: 991px) { .theme-tatilsepeti .ts-detail-body { grid-template-columns: 1fr; } }

.theme-tatilsepeti .ts-detail-content > section {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  padding: 22px 24px;
  margin-bottom: 16px;
  border: 1px solid var(--ts-border);
}
.theme-tatilsepeti .ts-detail-content section h2 {
  font-size: 18px;
  font-weight: 800;
  color: var(--ts-navy);
  margin: 0 0 12px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--ts-orange);
  display: inline-block;
}

/* Sticky fiyat kutusu */
.theme-tatilsepeti .ts-detail-pricing {
  position: sticky;
  top: 180px;
  align-self: start;
  background: #fff;
  border-radius: var(--ts-radius-lg);
  padding: 22px;
  border: 1px solid var(--ts-border);
  box-shadow: var(--ts-shadow);
}
.theme-tatilsepeti .ts-detail-pricing .ts-pricing-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--ts-border);
  margin-bottom: 16px;
}
.theme-tatilsepeti .ts-detail-pricing .ts-pricing-head .ts-price-new { font-size: 28px; }

.theme-tatilsepeti .ts-room-card {
  background: var(--ts-bg-soft);
  border: 1px solid var(--ts-border);
  border-radius: var(--ts-radius);
  padding: 14px;
  margin-bottom: 10px;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-room-card:hover { border-color: var(--ts-orange); }
.theme-tatilsepeti .ts-room-card .ts-room-title { font-size: 14px; font-weight: 700; color: var(--ts-navy); margin: 0 0 4px; }
.theme-tatilsepeti .ts-room-card .ts-room-meta { font-size: 12px; color: var(--ts-text-soft); margin-bottom: 8px; }
.theme-tatilsepeti .ts-room-card .ts-room-footer {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}

/* ==========================================================================
   19. REZERVASYON ADIM ÇUBUĞU
   ========================================================================== */
.theme-tatilsepeti .ts-stepper {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  padding: 18px 22px;
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--ts-border);
  overflow-x: auto;
}
.theme-tatilsepeti .ts-stepper-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 4px;
  flex-shrink: 0;
}
.theme-tatilsepeti .ts-stepper-num {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--ts-bg);
  color: var(--ts-text-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 14px;
}
.theme-tatilsepeti .ts-stepper-label { font-size: 13px; font-weight: 600; color: var(--ts-text-soft); white-space: nowrap; }
.theme-tatilsepeti .ts-stepper-arrow { color: var(--ts-text-muted); font-size: 12px; margin: 0 4px; }
.theme-tatilsepeti .ts-stepper-item.active .ts-stepper-num,
.theme-tatilsepeti .ts-stepper-item.completed .ts-stepper-num {
  background: var(--ts-orange);
  color: #fff;
  box-shadow: 0 4px 10px var(--ts-orange-shadow);
}
.theme-tatilsepeti .ts-stepper-item.active .ts-stepper-label,
.theme-tatilsepeti .ts-stepper-item.completed .ts-stepper-label { color: var(--ts-navy); }
.theme-tatilsepeti .ts-stepper-item.completed .ts-stepper-num::before {
  content: '\f00c';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
}
.theme-tatilsepeti .ts-stepper-item.completed .ts-stepper-num { font-size: 0; }

/* ==========================================================================
   20. ÜYE PANELİ
   ========================================================================== */
.theme-tatilsepeti .ts-member-wrapper {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 24px;
  padding: 32px 0;
}
@media (max-width: 991px) { .theme-tatilsepeti .ts-member-wrapper { grid-template-columns: 1fr; } }

.theme-tatilsepeti .ts-member-side {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  padding: 22px 18px;
  border: 1px solid var(--ts-border);
  align-self: start;
}
.theme-tatilsepeti .ts-member-avatar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-bottom: 16px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--ts-border);
}
.theme-tatilsepeti .ts-member-avatar img,
.theme-tatilsepeti .ts-member-avatar .ts-avatar-circle {
  width: 50px; height: 50px;
  border-radius: 50%;
  background: var(--ts-orange-light);
  color: var(--ts-orange);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 20px;
  border: 2px solid var(--ts-orange);
}
.theme-tatilsepeti .ts-member-avatar .ts-avatar-info strong { font-size: 14px; color: var(--ts-navy); display: block; }
.theme-tatilsepeti .ts-member-avatar .ts-avatar-info small { font-size: 12px; color: var(--ts-text-soft); }
.theme-tatilsepeti .ts-member-side ul { list-style: none; padding: 0; margin: 0; }
.theme-tatilsepeti .ts-member-side ul li a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  font-size: 14px;
  color: var(--ts-text);
  text-decoration: none;
  border-radius: var(--ts-radius-sm);
  margin-bottom: 2px;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-member-side ul li a i { color: var(--ts-text-soft); width: 18px; text-align: center; }
.theme-tatilsepeti .ts-member-side ul li a:hover { background: var(--ts-orange-light); color: var(--ts-orange); }
.theme-tatilsepeti .ts-member-side ul li a:hover i { color: var(--ts-orange); }
.theme-tatilsepeti .ts-member-side ul li a.active {
  background: var(--ts-orange) !important;
  color: #fff !important;
}
.theme-tatilsepeti .ts-member-side ul li a.active i { color: #fff !important; }

.theme-tatilsepeti .ts-member-content {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  padding: 26px;
  border: 1px solid var(--ts-border);
}
.theme-tatilsepeti .ts-member-content h2 {
  font-size: 20px;
  font-weight: 800;
  color: var(--ts-navy);
  margin: 0 0 18px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--ts-orange);
  display: inline-block;
}

/* ==========================================================================
   21. TABLO STİLİ
   ========================================================================== */
.theme-tatilsepeti .table { font-size: 14px; }
.theme-tatilsepeti .table thead th {
  background: var(--ts-bg);
  color: var(--ts-navy);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 12px;
  letter-spacing: 0.04em;
  border-bottom: 2px solid var(--ts-border-strong);
  padding: 12px;
}
.theme-tatilsepeti .table tbody td {
  padding: 14px 12px;
  border-bottom: 1px solid var(--ts-border);
  vertical-align: middle;
}
.theme-tatilsepeti .table tbody tr:hover { background: var(--ts-orange-light); }

/* ==========================================================================
   22. PAGINATION
   ========================================================================== */
.theme-tatilsepeti .pagination { gap: 4px; }
.theme-tatilsepeti .pagination .page-link {
  color: var(--ts-navy);
  border: 1px solid var(--ts-border);
  border-radius: var(--ts-radius-sm) !important;
  font-weight: 600;
  padding: 8px 14px;
}
.theme-tatilsepeti .pagination .page-link:hover {
  background: var(--ts-orange-light);
  color: var(--ts-orange);
  border-color: var(--ts-orange);
}
.theme-tatilsepeti .pagination .page-item.active .page-link {
  background: var(--ts-orange) !important;
  border-color: var(--ts-orange) !important;
  color: #fff !important;
}

/* ==========================================================================
   23. OWL CAROUSEL — Turuncu nav & dot
   ========================================================================== */
.theme-tatilsepeti .owl-theme .owl-dots .owl-dot span {
  background: var(--ts-border-strong) !important;
  width: 10px; height: 10px;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .owl-theme .owl-dots .owl-dot.active span {
  background: var(--ts-orange) !important;
  width: 30px;
  border-radius: 5px;
}
.theme-tatilsepeti .owl-theme .owl-nav button.owl-prev,
.theme-tatilsepeti .owl-theme .owl-nav button.owl-next {
  background: #fff !important;
  color: var(--ts-orange) !important;
  width: 42px; height: 42px;
  border-radius: 50%;
  box-shadow: var(--ts-shadow);
  border: 1px solid var(--ts-border) !important;
  font-size: 18px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.theme-tatilsepeti .owl-theme .owl-nav button:hover {
  background: var(--ts-orange) !important;
  color: #fff !important;
  border-color: var(--ts-orange) !important;
}

/* ==========================================================================
   24. BLOG & KURUMSAL
   ========================================================================== */
.theme-tatilsepeti .ts-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 991px) { .theme-tatilsepeti .ts-blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .theme-tatilsepeti .ts-blog-grid { grid-template-columns: 1fr; } }

.theme-tatilsepeti .ts-blog-card {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  overflow: hidden;
  border: 1px solid var(--ts-border);
  display: flex;
  flex-direction: column;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .ts-blog-card:hover { transform: translateY(-4px); box-shadow: var(--ts-shadow); }
.theme-tatilsepeti .ts-blog-card .ts-blog-image {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  position: relative;
  background: #f1f3f7;
}
.theme-tatilsepeti .ts-blog-card .ts-blog-image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--ts-transition-slow); display: block; }
.theme-tatilsepeti .ts-blog-card:hover .ts-blog-image img { transform: scale(1.06); }
/* Resim üzeri tarih rozeti — sol üst, beyaz arka, lacivert metin */
.theme-tatilsepeti .ts-blog-card .ts-blog-date-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  background: #fff;
  color: var(--ts-navy);
  font-size: 11.5px;
  font-weight: 700;
  padding: 5px 10px;
  border-radius: 999px;
  box-shadow: 0 2px 10px rgba(10,42,94,0.12);
  letter-spacing: 0.02em;
  display: inline-flex;
  align-items: center;
  z-index: 2;
}
.theme-tatilsepeti .ts-blog-card .ts-blog-date-badge i { color: var(--ts-orange); }
.theme-tatilsepeti .ts-blog-card .ts-blog-body { padding: 16px 18px 18px; flex: 1; display: flex; flex-direction: column; }
.theme-tatilsepeti .ts-blog-card .ts-blog-cat {
  font-size: 11px;
  font-weight: 700;
  color: var(--ts-orange);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 4px;
  display: inline-block;
}
.theme-tatilsepeti .ts-blog-card .ts-blog-title {
  font-size: 16.5px;
  font-weight: 700;
  color: var(--ts-navy);
  margin: 0 0 8px;
  line-height: 1.32;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 44px;
}
.theme-tatilsepeti .ts-blog-card .ts-blog-title a { color: inherit; text-decoration: none; transition: color var(--ts-transition); }
.theme-tatilsepeti .ts-blog-card .ts-blog-title a:hover { color: var(--ts-orange); }
.theme-tatilsepeti .ts-blog-card .ts-blog-excerpt {
  font-size: 13px;
  color: var(--ts-text-soft);
  flex: 1;
  margin: 0 0 12px;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.theme-tatilsepeti .ts-blog-card .ts-blog-meta {
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px dashed var(--ts-border);
  font-size: 12px;
  color: var(--ts-text-muted);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  row-gap: 4px;
}
.theme-tatilsepeti .ts-blog-card .ts-blog-meta-date,
.theme-tatilsepeti .ts-blog-card .ts-blog-meta-author {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}
.theme-tatilsepeti .ts-blog-card .ts-blog-meta-date i,
.theme-tatilsepeti .ts-blog-card .ts-blog-meta-author i { color: var(--ts-text-muted); }
.theme-tatilsepeti .ts-blog-card .ts-blog-meta-cta {
  margin-left: auto;
  color: var(--ts-orange);
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  transition: gap var(--ts-transition);
}
.theme-tatilsepeti .ts-blog-card .ts-blog-meta-cta:hover {
  gap: 8px;
  color: var(--ts-orange-dark);
}

.theme-tatilsepeti .ts-page {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  padding: 36px;
  margin: 32px auto;
  border: 1px solid var(--ts-border);
}
.theme-tatilsepeti .ts-page h1 {
  font-size: 28px;
  font-weight: 800;
  margin: 0 0 18px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--ts-orange);
  display: inline-block;
}
.theme-tatilsepeti .ts-page h2 { font-size: 22px; margin: 24px 0 12px; color: var(--ts-orange); }
.theme-tatilsepeti .ts-page h3 { font-size: 18px; margin: 18px 0 10px; }
.theme-tatilsepeti .ts-page p { font-size: 15px; line-height: 1.7; color: var(--ts-text); margin-bottom: 14px; }
.theme-tatilsepeti .ts-page ul, .theme-tatilsepeti .ts-page ol { padding-left: 22px; line-height: 1.8; }
.theme-tatilsepeti .ts-page a { color: var(--ts-orange); }

/* ==========================================================================
   25. AUTH (Login/Register)
   ========================================================================== */
.theme-tatilsepeti .ts-auth-wrapper {
  min-height: calc(100vh - 200px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 16px;
}
.theme-tatilsepeti .ts-auth-card {
  background: #fff;
  border-radius: var(--ts-radius-xl);
  padding: 36px;
  max-width: 460px;
  width: 100%;
  box-shadow: var(--ts-shadow-lg);
}
.theme-tatilsepeti .ts-auth-card h1 {
  font-size: 24px;
  font-weight: 800;
  text-align: center;
  margin: 0 0 6px;
}
.theme-tatilsepeti .ts-auth-card .ts-auth-subtitle {
  text-align: center;
  font-size: 14px;
  color: var(--ts-text-soft);
  margin-bottom: 22px;
}

/* ==========================================================================
   26. RESPONSIVE — 991 ve altı
   ========================================================================== */
@media (max-width: 991px) {
  .theme-tatilsepeti .ts-hero-title h1 { font-size: 26px; }
  .theme-tatilsepeti .ts-hero-title p { font-size: 14px; }
  .theme-tatilsepeti .main-search { padding: 16px 0 24px !important; min-height: auto !important; }
  .theme-tatilsepeti .main-search .tab-content { padding: 14px !important; }
  .theme-tatilsepeti .main-search .nav.nav-pills .nav-link { padding: 0 12px !important; height: 38px !important; font-size: 12.5px !important; }
  .theme-tatilsepeti .main-search .search-form .search-list { flex-direction: column; }
  .theme-tatilsepeti .main-search .search-form .search-list .form-group { width: 100% !important; }
  .theme-tatilsepeti .main-search .search-form .search-btn { width: 100%; }
  .theme-tatilsepeti .ts-section { padding: 36px 0; }
  .theme-tatilsepeti .ts-section-head .ts-section-title { font-size: 22px; }
  .theme-tatilsepeti .ts-detail-pricing { position: static; margin-top: 20px; }
}
@media (max-width: 575px) {
  .theme-tatilsepeti .ts-detail-title { font-size: 22px; }
  .theme-tatilsepeti .ts-page { padding: 22px 18px; }
  .theme-tatilsepeti .ts-auth-card { padding: 24px 20px; }
}

/* ==========================================================================
   27. EK YARDIMCILAR
   ========================================================================== */
.theme-tatilsepeti .ts-divider { height: 1px; background: var(--ts-border); margin: 24px 0; }
.theme-tatilsepeti .ts-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--ts-orange-light);
  color: var(--ts-orange);
  font-size: 12px;
  font-weight: 700;
  border-radius: var(--ts-radius-pill);
}
.theme-tatilsepeti .ts-chip.success { background: var(--ts-success-light); color: #166534; }
.theme-tatilsepeti .ts-chip.warning { background: var(--ts-warning-light); color: #854D0E; }
.theme-tatilsepeti .ts-chip.danger  { background: var(--ts-danger-light); color: #991B1B; }
.theme-tatilsepeti .ts-chip.navy    { background: var(--ts-navy-soft); color: var(--ts-navy); }

.theme-tatilsepeti .ts-skeleton {
  background: linear-gradient(90deg, var(--ts-border) 25%, #f3f4f6 50%, var(--ts-border) 75%);
  background-size: 200% 100%;
  animation: ts-skeleton-shimmer 1.4s infinite linear;
  border-radius: var(--ts-radius-sm);
}
@keyframes ts-skeleton-shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* Tooltip & focus iyileştirmeleri */
.theme-tatilsepeti :focus-visible { outline: 2px solid var(--ts-orange) !important; outline-offset: 2px; border-radius: var(--ts-radius-sm); }

/* ==========================================================================
   28. ALTYAPI: alt sınıf gizleyicileri / boşluk düzeltmeleri
   ========================================================================== */
.theme-tatilsepeti .border-dark-gray { border-color: var(--ts-border) !important; color: var(--ts-text) !important; }
.theme-tatilsepeti hr { border-color: var(--ts-border); opacity: 1; }
.theme-tatilsepeti .badge { border-radius: var(--ts-radius-sm); font-weight: 700; padding: 5px 10px; }
.theme-tatilsepeti .badge.bg-primary { background: var(--ts-orange) !important; color: #fff; }
.theme-tatilsepeti .badge.bg-secondary { background: var(--ts-navy) !important; color: #fff; }
.theme-tatilsepeti .badge.bg-success { background: var(--ts-success) !important; color: #fff; }
.theme-tatilsepeti .badge.bg-warning { background: var(--ts-warning) !important; color: #1F2937; }
.theme-tatilsepeti .badge.bg-danger  { background: var(--ts-danger) !important; color: #fff; }
.theme-tatilsepeti .badge.bg-info    { background: var(--ts-info) !important; color: #fff; }

/* Eski tema sınıflarının zorunlu nötralize edilmesi */
.theme-tatilsepeti .text-primary { color: var(--ts-orange) !important; }
.theme-tatilsepeti .border-primary { border-color: var(--ts-orange) !important; }

/* ==========================================================================
   29. FERIBOT — Mevcut .ferry-home-card override
   ========================================================================== */
.theme-tatilsepeti .ferry-home-card {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  overflow: hidden;
  box-shadow: var(--ts-shadow-sm);
  border: 1px solid var(--ts-border);
  transition: all var(--ts-transition);
  display: flex;
  flex-direction: column;
}
.theme-tatilsepeti .ferry-home-card:hover {
  border-color: var(--ts-orange-soft);
  box-shadow: var(--ts-shadow);
  transform: translateY(-3px);
}
.theme-tatilsepeti .ferry-home-card__img-wrap {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--ts-navy-soft);
  display: block;
}
.theme-tatilsepeti .ferry-home-card__img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--ts-transition-slow);
}
.theme-tatilsepeti .ferry-home-card:hover .ferry-home-card__img-wrap img { transform: scale(1.06); }
.theme-tatilsepeti .ferry-home-card__img-placeholder {
  width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--ts-navy) 0%, var(--ts-navy-light) 100%);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.85); font-size: 60px;
}
.theme-tatilsepeti .ferry-home-card__route-badge {
  position: absolute;
  bottom: 10px; left: 10px; right: 10px;
  background: rgba(10, 42, 94, 0.85);
  color: #fff;
  padding: 6px 12px;
  border-radius: var(--ts-radius-pill);
  font-size: 12px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(4px);
}
.theme-tatilsepeti .ferry-home-card__body {
  padding: 14px 16px 16px;
  display: flex; flex-direction: column;
  flex: 1;
}
.theme-tatilsepeti .ferry-home-card__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--ts-navy);
  margin: 0 0 8px;
}
.theme-tatilsepeti .ferry-home-card__times {
  display: flex; gap: 12px; flex-wrap: wrap;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px dashed var(--ts-border);
}
.theme-tatilsepeti .ferry-home-card__time-item {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; color: var(--ts-text-soft); font-weight: 600;
}
.theme-tatilsepeti .ferry-home-card__time-item i { color: var(--ts-orange); font-size: 11px; }
.theme-tatilsepeti .ferry-home-card__btn {
  margin-top: auto;
  background: var(--ts-orange) !important;
  background-image: linear-gradient(135deg, var(--ts-orange) 0%, var(--ts-orange-hover) 100%) !important;
  color: #fff !important;
  border: 0;
  padding: 10px 14px;
  border-radius: var(--ts-radius);
  font-weight: 700;
  font-size: 13px;
  text-align: center;
  text-decoration: none;
  display: block;
  transition: all var(--ts-transition);
  box-shadow: 0 4px 12px var(--ts-orange-shadow);
}
.theme-tatilsepeti .ferry-home-card__btn:hover {
  background-image: linear-gradient(135deg, var(--ts-orange-hover) 0%, var(--ts-orange-dark) 100%) !important;
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 20px var(--ts-orange-shadow);
}

/* ==========================================================================
   30. ESKI .modern-card / .list-item / .breadcrumb-custom override
   ========================================================================== */
.theme-tatilsepeti .modern-card {
  background: #fff;
  border-radius: var(--ts-radius-lg) !important;
  overflow: hidden;
  border: 1px solid var(--ts-border) !important;
  box-shadow: var(--ts-shadow-sm) !important;
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .modern-card:hover {
  border-color: var(--ts-orange-soft) !important;
  box-shadow: var(--ts-shadow) !important;
  transform: translateY(-3px);
}
.theme-tatilsepeti .list-item {
  background: #fff;
  border-radius: var(--ts-radius-lg) !important;
  overflow: hidden;
  border: 1px solid var(--ts-border) !important;
}
.theme-tatilsepeti .breadcrumb-custom {
  background: transparent;
  padding: 12px 0;
  margin-bottom: 0;
}
.theme-tatilsepeti .breadcrumb-custom .breadcrumb {
  background: transparent;
  margin: 0;
  padding: 0;
}
.theme-tatilsepeti .breadcrumb-custom .breadcrumb-item a { color: var(--ts-text-soft) !important; font-weight: 500; }
.theme-tatilsepeti .breadcrumb-custom .breadcrumb-item a:hover { color: var(--ts-orange) !important; }
.theme-tatilsepeti .breadcrumb-custom .breadcrumb-item.active { color: var(--ts-navy) !important; font-weight: 700; }

/* ==========================================================================
   31. PAGE CONTENT WRAPPER (otel detail, tur detail, vb.)
   ========================================================================== */
.theme-tatilsepeti .page-content {
  padding: 16px 0 56px;
  background: var(--ts-bg);
  min-height: 60vh;
}

/* ==========================================================================
   32. MAIN-TITLE (eski class) override
   ========================================================================== */
.theme-tatilsepeti .main-title {
  margin-bottom: 24px !important;
}
.theme-tatilsepeti .main-title .fw-bold,
.theme-tatilsepeti .main-title h2,
.theme-tatilsepeti .main-title .title {
  color: var(--ts-navy) !important;
  font-weight: 800 !important;
}
.theme-tatilsepeti .main-title .text-muted {
  color: var(--ts-text-soft) !important;
}

/* ==========================================================================
   33. FERIBOT KATEGORİ HERO + GROUP (.fcat-*)
   ========================================================================== */
.theme-tatilsepeti .fcat-hero {
  background: linear-gradient(135deg, var(--ts-navy) 0%, var(--ts-navy-light) 100%) !important;
  color: #fff !important;
  padding: 36px 0 28px !important;
  position: relative;
  overflow: hidden;
}
.theme-tatilsepeti .fcat-hero::before {
  content: '';
  position: absolute;
  top: -50%; right: -10%;
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(255,107,0,0.18), transparent 70%);
  pointer-events: none;
}
.theme-tatilsepeti .fcat-hero .container { position: relative; z-index: 2; }
.theme-tatilsepeti .fcat-hero__inner { display: flex; align-items: center; gap: 16px; }
.theme-tatilsepeti .fcat-hero__icon {
  font-size: 44px;
  color: var(--ts-orange);
  width: 80px; height: 80px;
  border-radius: 50%;
  background: rgba(255,255,255,0.10);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.theme-tatilsepeti .fcat-hero__title { color: #fff !important; font-size: 28px !important; font-weight: 800; margin: 0 0 4px; }
.theme-tatilsepeti .fcat-hero__sub { color: rgba(255,255,255,0.85) !important; margin: 0; font-size: 15px; }
.theme-tatilsepeti .fcat-breadcrumb { background: transparent !important; padding: 0 !important; }
.theme-tatilsepeti .fcat-breadcrumb .breadcrumb-item,
.theme-tatilsepeti .fcat-breadcrumb .breadcrumb-item a { color: rgba(255,255,255,0.78) !important; font-size: 13px; }
.theme-tatilsepeti .fcat-breadcrumb .breadcrumb-item a:hover { color: var(--ts-orange) !important; }
.theme-tatilsepeti .fcat-breadcrumb .breadcrumb-item.active { color: #fff !important; }

.theme-tatilsepeti .fcat-group {
  background: #fff;
  border-radius: var(--ts-radius-lg);
  border: 1px solid var(--ts-border);
  padding: 22px;
  box-shadow: var(--ts-shadow-sm);
}
.theme-tatilsepeti .fcat-group__header {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
  padding-bottom: 14px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--ts-border);
}
.theme-tatilsepeti .fcat-group__header-left { display: flex; align-items: center; gap: 14px; }
.theme-tatilsepeti .fcat-group__icon-wrap {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--ts-orange-light);
  color: var(--ts-orange);
  font-size: 22px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.theme-tatilsepeti .fcat-group__name { color: var(--ts-navy) !important; font-size: 20px !important; font-weight: 800 !important; margin: 0; }
.theme-tatilsepeti .fcat-group__desc { color: var(--ts-text-soft) !important; margin: 0; font-size: 13px; }
.theme-tatilsepeti .fcat-group__all-link {
  color: var(--ts-orange) !important;
  font-weight: 700;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}
.theme-tatilsepeti .fcat-group__all-link:hover { gap: 8px; }

/* ==========================================================================
   34. TRANSFER LISTE HERO (.tr-hero, .tr-search-card)
   ========================================================================== */
.theme-tatilsepeti .tr-hero {
  background: linear-gradient(135deg, var(--ts-navy) 0%, var(--ts-navy-light) 100%) !important;
  color: #fff !important;
  padding: 36px 0 56px !important;
  position: relative;
  overflow: hidden;
}
.theme-tatilsepeti .tr-hero::before {
  content: '';
  position: absolute;
  top: -50%; left: -10%;
  width: 420px; height: 420px;
  background: radial-gradient(circle, rgba(255,107,0,0.18), transparent 70%);
  pointer-events: none;
}
.theme-tatilsepeti .tr-hero .container { position: relative; z-index: 2; }
.theme-tatilsepeti .tr-hero__title { color: #fff !important; font-weight: 800 !important; font-size: 28px !important; }
.theme-tatilsepeti .tr-hero__sub { color: rgba(255,255,255,0.85) !important; }
.theme-tatilsepeti .tr-hero__breadcrumb,
.theme-tatilsepeti .tr-hero__breadcrumb .breadcrumb-item,
.theme-tatilsepeti .tr-hero__breadcrumb .breadcrumb-item a { color: rgba(255,255,255,0.85) !important; }
.theme-tatilsepeti .tr-hero__breadcrumb .breadcrumb-item a:hover { color: var(--ts-orange) !important; }
.theme-tatilsepeti .tr-hero__breadcrumb .breadcrumb-item.active { color: #fff !important; }
.theme-tatilsepeti .tr-hero__breadcrumb .breadcrumb-item+.breadcrumb-item::before { color: rgba(255,255,255,0.45) !important; }

.theme-tatilsepeti .tr-search-card,
.theme-tatilsepeti .tr-card {
  background: #fff !important;
  border-radius: var(--ts-radius-lg) !important;
  box-shadow: var(--ts-shadow-lg) !important;
  border: 0 !important;
}

/* ==========================================================================
   35. REZERVASYON .progressbar OVERRIDE (mevcut blade yapısı korunuyor)
   ========================================================================== */
.theme-tatilsepeti .progressbar {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px;
  padding: 18px 22px;
  margin: 0;
  background: #fff;
  border-radius: var(--ts-radius-lg);
  border: 1px solid var(--ts-border);
  box-shadow: var(--ts-shadow-sm);
  width: 100%;
  max-width: 760px;
  counter-reset: ts-step;
}
.theme-tatilsepeti .progressbar li {
  position: relative;
  flex: 1 1 0;
  text-align: center;
  font-size: 13px;
  font-weight: 600;
  color: var(--ts-text-soft);
  padding: 10px 6px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  counter-increment: ts-step;
}
.theme-tatilsepeti .progressbar li::before {
  content: counter(ts-step);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--ts-bg);
  color: var(--ts-text-soft);
  font-weight: 800;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--ts-border);
  transition: all var(--ts-transition);
}
.theme-tatilsepeti .progressbar li::after {
  content: '';
  position: absolute;
  top: 26px;
  left: 50%;
  width: 100%;
  height: 2px;
  background: var(--ts-border);
  z-index: -1;
}
.theme-tatilsepeti .progressbar li:last-child::after { display: none; }
.theme-tatilsepeti .progressbar li.active {
  color: var(--ts-orange);
}
.theme-tatilsepeti .progressbar li.active::before {
  background: var(--ts-orange);
  color: #fff;
  border-color: var(--ts-orange);
  box-shadow: 0 4px 14px var(--ts-orange-shadow);
  transform: scale(1.1);
}
.theme-tatilsepeti .progressbar li.completed {
  color: var(--ts-success);
}
.theme-tatilsepeti .progressbar li.completed::before {
  background: var(--ts-success);
  color: #fff;
  border-color: var(--ts-success);
  content: '\f00c';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
}
.theme-tatilsepeti .progressbar li.completed::after { background: var(--ts-success); }

/* ==========================================================================
   36. REZERVASYON BAŞARI EKRANI (.fy-success)
   ========================================================================== */
.theme-tatilsepeti .fy-success {
  background: var(--ts-bg);
  padding: 40px 16px;
  min-height: 60vh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}
.theme-tatilsepeti .fy-success-card {
  background: #fff;
  border-radius: var(--ts-radius-xl);
  border: 1px solid var(--ts-border);
  padding: 32px;
  max-width: 760px;
  width: 100%;
  box-shadow: var(--ts-shadow-lg);
  overflow: hidden;
}
.theme-tatilsepeti .fy-success-header {
  text-align: center;
  padding-bottom: 24px;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--ts-border);
}
.theme-tatilsepeti .fy-check {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: var(--ts-success);
  color: #fff;
  font-size: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  box-shadow: 0 8px 24px rgba(34, 197, 94, 0.30);
  animation: ts-success-pop 0.4s cubic-bezier(0.18, 0.89, 0.32, 1.28);
}
@keyframes ts-success-pop { from { transform: scale(0.5); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.theme-tatilsepeti .fy-success-header h2 {
  color: var(--ts-navy);
  font-size: 24px;
  font-weight: 800;
  margin: 0 0 8px;
}

/* ==========================================================================
   37. REZERVASYON SAYFASI .reservation-page wrapper
   ========================================================================== */
.theme-tatilsepeti .reservation-page {
  background: var(--ts-bg) !important;
}

/* Tab content (Bootstrap) */
.theme-tatilsepeti .nav-tabs .nav-link {
  color: var(--ts-text-soft);
  border-radius: 0;
  border: 0;
  border-bottom: 3px solid transparent;
  font-weight: 600;
  padding: 12px 18px;
}
.theme-tatilsepeti .nav-tabs .nav-link:hover { color: var(--ts-orange); border-color: transparent; }
.theme-tatilsepeti .nav-tabs .nav-link.active {
  color: var(--ts-orange) !important;
  background: transparent !important;
  border-bottom: 3px solid var(--ts-orange) !important;
}

/* ==========================================================================
   38. ANASAYFA HERO — Sol Search Card (4 sekmeli) + Sağ Banner Carousel
   ========================================================================== */
.theme-tatilsepeti .ts-hero {
  position: relative;
  background: linear-gradient(135deg, #f4f6f9 0%, #e8edf5 100%);
  padding: 22px 0 28px;
  margin-bottom: 0;
}
.theme-tatilsepeti .ts-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 10% 30%, rgba(255,107,0,0.06), transparent 45%),
    radial-gradient(circle at 90% 70%, rgba(10,42,94,0.05), transparent 45%);
  pointer-events: none;
}
.theme-tatilsepeti .ts-hero .container { position: relative; z-index: 2; }

.theme-tatilsepeti .ts-hero-grid {
  display: flex;
  flex-direction: row;
  gap: 18px;
  align-items: flex-start;
  width: 100%;
}
@media (max-width: 991px) {
  .theme-tatilsepeti .ts-hero-grid { flex-direction: column; }
}

/* ============== Sol: Hero Search Card (.ts-hsc) — sabit 380px sol kolon ==============
   STRATEJİ (29.04.2026 final):
   • Kart YÜKSEKLİĞİ = sağdaki banner ile EŞİT (align-self: stretch + height: 100%)
   • Form alanları arasındaki DIKEY BOŞLUKLAR otomatik olarak yüksekliği doldurur
   • "OTEL ARA" butonu form'un en ALTINA yapışık (margin-top: auto)
   • Yani: kart kısa olmaz, alt boşluk olmaz, alanlar arası rahat nefes alır. */
.theme-tatilsepeti .ts-hero-search {
  display: flex;
  flex-direction: column;
  flex: 0 0 380px;
  width: 380px;
  max-width: 380px;
  align-self: stretch !important; /* sağ banner ile EŞİT yükseklik */
}
@media (max-width: 991px) {
  .theme-tatilsepeti .ts-hero-search { flex: 1 1 100%; width: 100%; max-width: 100%; }
}
.theme-tatilsepeti .ts-hsc {
  background: #fff !important;
  border-radius: var(--ts-radius-lg) !important;
  box-shadow: var(--ts-shadow-lg) !important;
  overflow: visible !important;
  display: flex;
  flex-direction: column;
  height: 100% !important; /* sağ banner ile eşit dolu */
  border: 1px solid #fff5e9;
  background-image: none !important;
  min-height: 0 !important;
  padding: 0 !important;
  position: relative;
}

/* ==========================================================================
   Anasayfa hero search — DİKEY tab layout (Tatilsepeti/Jolly tarzı):
   • İkon ÜSTTE büyük (22px), metin ALTTA (13.5px)
   • 4 tab eşit genişlik, 380px sol kolona rahat sığar
   • Aktif tab BEYAZ dolu, alta TURUNCU çizgi; pasif tablar açık gri
   ========================================================================== */
/* ==========================================================================
   ANASAYFA HERO SEARCH — Tab + form BÜTÜNLEŞİK (kullanıcı talebi):
   • Wrapper BG: BEYAZ → aktif pill ve alt form ile aynı renk → tek parça izlenimi
   • Pasif pill: açık gri (#eef1f5)  → kontrast = "ben pasifim"
   • Aktif pill: BEYAZ (wrapper ile aynı, görünmez fark) + ÜST 3px TURUNCU vurgu
   • HR/border-bottom YOK → tab şeridi alt formla seamless birleşik
   ========================================================================== */
.theme-tatilsepeti .ts-hsc-tabs.nav.nav-pills,
.theme-tatilsepeti .ts-hsc .ts-hsc-tabs {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  background: #ffffff !important;  /* WRAPPER BEYAZ — aktif pill ile bütünlük */
  border-bottom: 0 !important;     /* HR YOK */
  border-radius: var(--ts-radius-lg) var(--ts-radius-lg) 0 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
  gap: 0 !important;
  justify-content: stretch !important;
  overflow: hidden !important;      /* OVAL üst köşeler için — pill'leri keser */
  width: 100% !important;
  box-sizing: border-box !important;
}
.theme-tatilsepeti .ts-hsc-tabs > li.nav-item {
  flex: 1 1 0 !important;
  display: flex !important;
  margin: 0 !important;
  padding: 0 !important;
  min-width: 0 !important;
  width: 25% !important;
  max-width: 25% !important;
  box-sizing: border-box !important;
}
/* PASİF pill: GRİ bg, lacivert metin/ikon, ÜST 3px transparent (aktifte turuncu olur) */
.theme-tatilsepeti .ts-hsc .ts-hsc-tabs .nav-item .ts-hsc-tab.nav-link,
.theme-tatilsepeti .ts-hsc-tabs .nav-link.ts-hsc-tab,
.theme-tatilsepeti .ts-hsc-tab.nav-link {
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  padding: 8px 4px 6px !important;
  margin: 0 !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  color: var(--ts-navy) !important;
  border: 0 !important;
  border-top: 3px solid transparent !important; /* AKTİF olunca turuncu olur */
  border-radius: 0 !important;
  background: #eef1f5 !important; /* PASİF: AÇIK GRİ */
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
  text-decoration: none !important;
  width: 100% !important;
  height: 60px !important;
  min-height: 60px !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  pointer-events: auto !important;
  outline: 0 !important;
  box-shadow: none !important;
  position: relative;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  border-bottom: 0 !important;
  letter-spacing: 0;
  box-sizing: border-box !important;
  line-height: 1.1 !important;
}
/* Icon — büyük ve belirgin, üstte. PASİF DURUMDA LACİVERT */
.theme-tatilsepeti .ts-hsc-tab.nav-link i {
  font-size: 20px !important;
  color: var(--ts-navy) !important; /* LACİVERT — kullanıcı talebi */
  opacity: 1 !important;
  margin: 0 !important;
  flex-shrink: 0 !important;
  width: auto !important;
  background: transparent !important;
  line-height: 1 !important;
}
/* Span (metin) — altta, ince */
.theme-tatilsepeti .ts-hsc-tab.nav-link span {
  margin: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  min-width: 0 !important;
  display: inline-block !important;
  font-size: 13px !important;
  font-weight: 500 !important; /* İNCE — kullanıcı talebi */
  line-height: 1 !important;
  color: var(--ts-navy) !important;
}
.theme-tatilsepeti .ts-hsc-tab.nav-link:hover {
  background: #e3e8ef !important; /* hover: pasif griden bir tık koyu */
  color: var(--ts-navy) !important;
}
.theme-tatilsepeti .ts-hsc-tab.nav-link:hover i {
  color: var(--ts-orange) !important;
}
.theme-tatilsepeti .ts-hsc-tab.nav-link:hover span {
  color: var(--ts-navy) !important;
}

/* ==================== AKTİF TAB ====================
   • BG: BEYAZ → wrapper (beyaz) ve alt form (beyaz) ile aynı renk = TEK PARÇA
   • ÜST: 3px TURUNCU vurgu çizgisi (aktif olduğunu gösteren UI cue)
   • Alt: HİÇBİR ÇİZGİ YOK → form ile pürüzsüz birleşim
   • İkon: TURUNCU, metin: KALIN lacivert
   ==================================================== */
.theme-tatilsepeti .ts-hsc-tabs .nav-item .ts-hsc-tab.nav-link.active,
.theme-tatilsepeti .ts-hsc-tabs .nav-item .ts-hsc-tab.nav-link.is-active,
.theme-tatilsepeti .ts-hsc-tab.nav-link.active,
.theme-tatilsepeti .ts-hsc-tab.nav-link.is-active {
  background: #ffffff !important; /* BEYAZ — wrapper ve form ile aynı = bütünleşik */
  color: var(--ts-navy) !important;
  border-top-color: var(--ts-orange) !important; /* ÜST 3px TURUNCU vurgu */
  border-bottom: 0 !important;
  box-shadow: none !important;
  position: relative;
  z-index: 2;
}
.theme-tatilsepeti .ts-hsc-tab.nav-link.active i,
.theme-tatilsepeti .ts-hsc-tab.nav-link.is-active i {
  color: var(--ts-orange) !important;
  opacity: 1 !important;
}
.theme-tatilsepeti .ts-hsc-tab.nav-link.active span,
.theme-tatilsepeti .ts-hsc-tab.nav-link.is-active span {
  color: var(--ts-navy) !important;
  font-weight: 700 !important;
}
.theme-tatilsepeti .ts-hsc-tab.nav-link::after { display: none !important; }
.theme-tatilsepeti .ts-hsc-tab.nav-link::before { display: none !important; }
.theme-tatilsepeti .ts-hsc-tab.nav-link:focus,
.theme-tatilsepeti .ts-hsc-tab.nav-link:focus-visible,
.theme-tatilsepeti .ts-hsc-tab.nav-link:active {
  outline: 0 !important;
  box-shadow: none !important;
}

/* Search body — tab-content içinde tab-pane'ler
   AKTİF tab + tab-content + form: HEPSİ BEYAZ → seamless
   tab-content ARTIK kart yüksekliğini DOLDURUR (flex: 1) ve içerideki form
   alanları arasındaki gap'leri form kendisi yönetir. */
.theme-tatilsepeti .ts-hsc-body.tab-content {
  padding: 0 !important;
  background: #ffffff !important;
  flex: 1 1 auto !important; /* kart yüksekliğini DOLDUR */
  display: flex !important;
  flex-direction: column !important;
  position: relative;
  border-radius: 0 0 var(--ts-radius-lg) var(--ts-radius-lg) !important;
  min-height: 0 !important;
}
/* Tab-pane (her tabın içeriği) — yüksekliği DOLDURUR, içinde title + form var */
.theme-tatilsepeti .ts-hsc-body .tab-pane {
  padding: 14px 16px 16px !important;
  flex-direction: column;
  gap: 12px !important;            /* title ile form arası nefes */
  min-height: 0 !important;
  flex: 1 1 auto !important;
}
.theme-tatilsepeti .ts-hsc-body .tab-pane.active {
  display: flex !important;
}
.theme-tatilsepeti .ts-hsc-body .tab-pane:not(.active) {
  display: none !important;
}
/* Form — tab-pane içinde flex 1 alır, kalan tüm yüksekliği doldurur
   Form içindeki BUTON margin-top: auto ile en ALTa yapışır,
   alanlar üstte gap'lerle rahat sıralanır. */
.theme-tatilsepeti .ts-hsc-form {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  gap: 14px !important;            /* alanlar arası rahat dikey boşluk */
  min-height: 0 !important;
}
.theme-tatilsepeti .ts-hsc-field { gap: 6px !important; }
.theme-tatilsepeti .ts-hsc-input-wrap { padding: 11px 12px !important; min-height: 46px !important; }

/* BUTON ALTA YAPIŞIK — class adı .ts-hsc-submit (HTML'de bu class kullanılıyor)
   margin-top: auto → form içindeki kalan dikey boşluğu absorbe eder, buton kart altına yapışır. */
.theme-tatilsepeti .ts-hsc-form .ts-hsc-submit,
.theme-tatilsepeti .ts-hsc-form .ts-hsc-search-btn,
.theme-tatilsepeti .ts-hsc-form button[type="submit"].search-btn,
.theme-tatilsepeti .ts-hsc-form button[type="submit"],
.theme-tatilsepeti .ts-hsc-body .ts-hsc-submit {
  margin-top: auto !important;
  margin-bottom: 0 !important;
  padding: 14px 18px !important;
  height: auto !important;
  min-height: 48px !important;
}
/* Tatil Ara başlığı — kompakt */
.theme-tatilsepeti .ts-hsc-title {
  font-size: 14px !important;
  margin: 0 0 4px !important;
}
.theme-tatilsepeti .ts-hsc-title {
  font-size: 16px;
  font-weight: 800;
  color: var(--ts-navy);
  letter-spacing: -0.2px;
  margin: 0 0 4px;
  display: flex;
  align-items: center;
}
.theme-tatilsepeti .ts-hsc-form {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  background: transparent !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* search-form ve search-list eski wrapper'larını sıfırla */
.theme-tatilsepeti .ts-hsc-form .search-list { all: unset; display: contents; }

.theme-tatilsepeti .ts-hsc-field {
  display: flex !important;
  flex-direction: column;
  gap: 6px;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  height: auto !important;
  width: 100% !important;
  flex: initial !important;
}
.theme-tatilsepeti .ts-hsc-label,
.theme-tatilsepeti .ts-hsc-field > label.form-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--ts-text-soft) !important;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  display: block;
}
.theme-tatilsepeti .ts-hsc-field-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* Input wrap (icon + input/select) — hover/focus halkası HAFİF, turuncu çerçeve YOK */
.theme-tatilsepeti .ts-hsc-input-wrap {
  position: relative;
  display: flex !important;
  align-items: center;
  background: #fafbfc;
  border: 1px solid var(--ts-border);
  border-radius: var(--ts-radius);
  padding: 0 12px;
  transition: border-color .15s ease, background-color .15s ease;
  height: 46px;
  width: 100%;
  text-decoration: none;
  outline: 0;
  box-shadow: none;
}
.theme-tatilsepeti .ts-hsc-input-wrap:hover {
  border-color: #d1d5db;
  background: #fff;
}
.theme-tatilsepeti .ts-hsc-input-wrap:focus-within {
  border-color: #d1d5db;
  background: #fff;
  box-shadow: none;
  outline: 0;
}
.theme-tatilsepeti .ts-hsc-input-wrap input,
.theme-tatilsepeti .ts-hsc-input-wrap select {
  outline: 0 !important;
  box-shadow: none !important;
}
.theme-tatilsepeti .ts-hsc-input-wrap input:focus,
.theme-tatilsepeti .ts-hsc-input-wrap select:focus {
  outline: 0 !important;
  box-shadow: none !important;
  border: 0 !important;
  background: transparent !important;
}
.theme-tatilsepeti .ts-hsc-input-wrap > i {
  color: var(--ts-orange);
  font-size: 14px;
  margin-right: 10px;
  flex-shrink: 0;
}
.theme-tatilsepeti .ts-hsc-input-wrap > input.form-control,
.theme-tatilsepeti .ts-hsc-input-wrap > select.form-select,
.theme-tatilsepeti .ts-hsc-input-wrap > span {
  flex: 1;
  border: 0 !important;
  background: transparent !important;
  font-size: 14px !important;
  color: var(--ts-text) !important;
  font-weight: 600 !important;
  width: 100% !important;
  outline: none;
  padding: 0 !important;
  height: 100% !important;
  line-height: 1.2 !important;
  box-shadow: none !important;
  min-height: 0 !important;
}
.theme-tatilsepeti .ts-hsc-input-wrap input::placeholder { color: var(--ts-text-muted) !important; font-weight: 500 !important; }
.theme-tatilsepeti .ts-hsc-input-wrap > select.form-select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M0 0l5 6 5-6z' fill='%236b7280'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right center !important;
  padding-right: 16px !important;
}
.theme-tatilsepeti .ts-hsc-input-wrap.room-btn {
  cursor: pointer;
  text-decoration: none !important;
  color: var(--ts-text) !important;
}
.theme-tatilsepeti .ts-hsc-input-wrap.room-btn > .ts-hsc-guest-text,
.theme-tatilsepeti .ts-hsc-input-wrap.room-btn > span {
  color: var(--ts-text) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  line-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  height: 46px !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* Yetişkin/çocuk sayı badge'leri ana metinle aynı baseline */
.theme-tatilsepeti .ts-hsc-input-wrap.room-btn .adultCounter,
.theme-tatilsepeti .ts-hsc-input-wrap.room-btn .childrenCounter,
.theme-tatilsepeti .ts-hsc-input-wrap.room-btn .tur-adultCounter,
.theme-tatilsepeti .ts-hsc-input-wrap.room-btn .tur-childrenCounter {
  display: inline !important;
  vertical-align: baseline !important;
  font-weight: 700 !important;
  color: var(--ts-orange) !important;
  font-size: 14px !important;
  line-height: 1 !important;
  position: static !important;
  margin: 0 2px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
}

/* ===== Calentim datepicker popup z-index garantisi (hero üstünde kalsın) ===== */
.calentim-container,
.calentim,
.calentim-popup,
.calentim-table {
  z-index: 99999 !important;
}

/* ===== Hero search içindeki tüm form-control / form-select Bootstrap'in mavi/turuncu glow'u kaldır ===== */
.theme-tatilsepeti .ts-hsc .form-control:focus,
.theme-tatilsepeti .ts-hsc .form-select:focus,
.theme-tatilsepeti .ts-hsc .nav-link:focus,
.theme-tatilsepeti .ts-hsc .btn:focus,
.theme-tatilsepeti .ts-hsc input:focus,
.theme-tatilsepeti .ts-hsc select:focus,
.theme-tatilsepeti .ts-hsc button:focus,
.theme-tatilsepeti .ts-hsc a:focus {
  box-shadow: none !important;
  outline: 0 !important;
}

/* ===== Submit button override ===== */
.theme-tatilsepeti .ts-hsc-submit {
  width: 100%;
  background: linear-gradient(135deg, var(--ts-navy) 0%, var(--ts-navy-light) 100%) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: var(--ts-radius) !important;
  padding: 14px 18px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 0.3px !important;
  cursor: pointer;
  transition: var(--ts-transition);
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  margin: 4px 0 0 !important;
  text-transform: uppercase;
  height: auto !important;
  min-height: 0 !important;
  flex: initial !important;
  box-shadow: none !important;
}
.theme-tatilsepeti .ts-hsc-submit:hover {
  background: linear-gradient(135deg, var(--ts-orange) 0%, var(--ts-orange-hover) 100%) !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(255,107,0,0.30) !important;
}
.theme-tatilsepeti .ts-hsc-submit svg { display: none; }

/* ===== Autocomplete dropdown (otel/tur arama önerileri, transfer noktaları, feribot) ===== */
.theme-tatilsepeti .ts-hsc .search-dropdown-results,
.theme-tatilsepeti .ts-hsc #sf-feribot-ac {
  position: absolute !important;
  top: calc(100% + 4px) !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  z-index: 1050 !important;
  background: #fff !important;
  border: 1px solid var(--ts-border) !important;
  border-radius: var(--ts-radius) !important;
  box-shadow: var(--ts-shadow-xl) !important;
  padding: 8px 0 !important;
  margin: 0 !important;
  max-height: 320px !important;
  overflow-y: auto !important;
}
.theme-tatilsepeti .ts-hsc .search-dropdown-results.show { display: block !important; }
.theme-tatilsepeti .ts-hsc .search-dropdown-results ul li,
.theme-tatilsepeti .ts-hsc #sf-feribot-ac > div,
.theme-tatilsepeti .ts-hsc #sf-feribot-ac > a {
  padding: 8px 14px !important;
  font-size: 13px !important;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--ts-text);
  border-bottom: 1px solid #f3f4f6;
}
.theme-tatilsepeti .ts-hsc .search-dropdown-results ul li:last-child,
.theme-tatilsepeti .ts-hsc #sf-feribot-ac > div:last-child { border-bottom: 0; }
.theme-tatilsepeti .ts-hsc .search-dropdown-results ul li:hover,
.theme-tatilsepeti .ts-hsc #sf-feribot-ac > div:hover {
  background: var(--ts-orange-light);
  color: var(--ts-orange);
}

/* ===== Guest dropdown (oda+misafir) ===== */
.theme-tatilsepeti .ts-hsc .room-guest-dropdown {
  z-index: 1060 !important;
  border: 0 !important;
  border-radius: var(--ts-radius) !important;
  box-shadow: var(--ts-shadow-xl) !important;
  min-width: 280px !important;
  padding: 14px !important;
}
.theme-tatilsepeti .ts-hsc .room-guest-dropdown .col-form-label {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--ts-navy) !important;
  text-transform: uppercase;
}
.theme-tatilsepeti .ts-hsc .quantity-wrapper .qty {
  display: inline-flex !important;
  align-items: center;
  border: 1px solid var(--ts-border);
  border-radius: var(--ts-radius-pill);
  background: #fafbfc;
  overflow: hidden;
}
.theme-tatilsepeti .ts-hsc .quantity-wrapper .value-button {
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-weight: 800;
  font-size: 16px;
  color: var(--ts-orange);
  user-select: none;
  background: transparent;
  border: 0;
}
.theme-tatilsepeti .ts-hsc .quantity-wrapper .value-button:hover { background: var(--ts-orange-light); }
.theme-tatilsepeti .ts-hsc .quantity-wrapper input[type="number"] {
  width: 40px;
  text-align: center;
  border: 0;
  background: transparent;
  font-weight: 700;
  font-size: 14px;
  color: var(--ts-navy);
  outline: none;
  -moz-appearance: textfield;
  appearance: textfield;
}
.theme-tatilsepeti .ts-hsc .quantity-wrapper input[type="number"]::-webkit-inner-spin-button,
.theme-tatilsepeti .ts-hsc .quantity-wrapper input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none; margin: 0;
}
.theme-tatilsepeti .ts-hsc .child-ages-container {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 8px; padding-top: 10px;
  border-top: 1px solid #f3f4f6;
}
.theme-tatilsepeti .ts-hsc .child-ages-container select {
  flex: 1 1 120px;
  border: 1px solid var(--ts-border);
  border-radius: var(--ts-radius-sm);
  padding: 6px 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ts-navy);
  background: #fff;
}

/* ============== Sağ: Hero Banner + Mini Cards ============== */
.theme-tatilsepeti .ts-hero-banner {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
  flex: 1 1 0;
  align-self: stretch;
}

.theme-tatilsepeti .ts-hero-owl {
  border-radius: var(--ts-radius-lg);
  overflow: hidden;
  box-shadow: var(--ts-shadow-lg);
  background: var(--ts-navy);
  flex: 1;
  min-height: 0;
}
.theme-tatilsepeti .ts-hero-owl .owl-stage-outer { height: 100%; border-radius: var(--ts-radius-lg); }
.theme-tatilsepeti .ts-hero-slide {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 8;
  overflow: hidden;
  border-radius: var(--ts-radius-lg);
  text-decoration: none;
}
.theme-tatilsepeti .ts-hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.theme-tatilsepeti .ts-hero-slide:hover img { transform: scale(1.04); }
.theme-tatilsepeti .ts-hero-slide-caption {
  position: absolute;
  left: 24px;
  bottom: 22px;
  background: rgba(10,42,94,0.85);
  color: #fff;
  padding: 10px 18px;
  border-radius: var(--ts-radius);
  max-width: 70%;
  font-size: 14px;
  font-weight: 700;
  backdrop-filter: blur(6px);
  display: inline-block;
  line-height: 1.3;
}
.theme-tatilsepeti .ts-hero-slide-caption span { color: var(--ts-orange); font-weight: 800; }

/* Owl nav/dots over hero */
.theme-tatilsepeti .ts-hero-owl .owl-nav {
  position: absolute;
  top: 50%;
  left: 0; right: 0;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  pointer-events: none;
  margin: 0 !important;
}
.theme-tatilsepeti .ts-hero-owl .owl-nav button {
  pointer-events: auto;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,0.9) !important;
  color: var(--ts-navy) !important;
  margin: 0 14px !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: 14px !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
  transition: var(--ts-transition);
}
.theme-tatilsepeti .ts-hero-owl .owl-nav button:hover {
  background: var(--ts-orange) !important;
  color: #fff !important;
}
.theme-tatilsepeti .ts-hero-owl .owl-dots {
  position: absolute;
  bottom: 12px;
  left: 0; right: 0;
  text-align: center;
}
.theme-tatilsepeti .ts-hero-owl .owl-dots .owl-dot span {
  width: 8px; height: 8px;
  background: rgba(255,255,255,0.6) !important;
  margin: 0 3px !important;
}
.theme-tatilsepeti .ts-hero-owl .owl-dots .owl-dot.active span {
  background: var(--ts-orange) !important;
  width: 24px;
  border-radius: 4px;
}

/* Hero fallback (banner yoksa) */
.theme-tatilsepeti .ts-hero-slide-fallback {
  background: linear-gradient(135deg, var(--ts-navy) 0%, var(--ts-navy-light) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.theme-tatilsepeti .ts-hero-fallback-content {
  text-align: center;
  color: #fff;
  padding: 30px;
}
.theme-tatilsepeti .ts-hero-fallback-content h2 {
  font-size: 32px;
  font-weight: 800;
  margin-bottom: 10px;
}
.theme-tatilsepeti .ts-hero-fallback-content p { font-size: 15px; opacity: 0.85; margin-bottom: 16px; }
.theme-tatilsepeti .ts-hero-fallback-cta {
  display: inline-flex;
  align-items: center;
  background: var(--ts-orange);
  color: #fff;
  padding: 10px 22px;
  border-radius: var(--ts-radius);
  font-weight: 700;
}

/* Hero mini grid (banner altı 2 küçük kart) */
.theme-tatilsepeti .ts-hero-mini-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 575px) {
  .theme-tatilsepeti .ts-hero-mini-grid { grid-template-columns: 1fr; }
}
.theme-tatilsepeti .ts-hero-mini {
  display: flex;
  align-items: center;
  gap: 12px;
  background: #fff;
  border-radius: var(--ts-radius);
  padding: 12px 16px;
  text-decoration: none;
  box-shadow: var(--ts-shadow-sm);
  transition: var(--ts-transition);
  border: 1px solid var(--ts-border);
  min-height: 64px;
}
.theme-tatilsepeti .ts-hero-mini:hover {
  transform: translateY(-2px);
  box-shadow: var(--ts-shadow-lg);
  border-color: transparent;
}
.theme-tatilsepeti .ts-hero-mini-icon {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
  color: #fff;
  flex-shrink: 0;
}
.theme-tatilsepeti .ts-hero-mini-orange .ts-hero-mini-icon { background: linear-gradient(135deg, var(--ts-orange), var(--ts-orange-hover)); }
.theme-tatilsepeti .ts-hero-mini-navy .ts-hero-mini-icon { background: linear-gradient(135deg, var(--ts-navy), var(--ts-navy-light)); }
.theme-tatilsepeti .ts-hero-mini-text { flex: 1; min-width: 0; line-height: 1.3; }
.theme-tatilsepeti .ts-hero-mini-text strong {
  display: block;
  font-size: 14px;
  font-weight: 800;
  color: var(--ts-navy);
}
.theme-tatilsepeti .ts-hero-mini-text span {
  display: block;
  font-size: 12px;
  color: var(--ts-text-soft);
  font-weight: 500;
  margin-top: 1px;
}
.theme-tatilsepeti .ts-hero-mini-arrow {
  color: var(--ts-text-muted);
  font-size: 14px;
  transition: var(--ts-transition);
}
.theme-tatilsepeti .ts-hero-mini:hover .ts-hero-mini-arrow {
  color: var(--ts-orange);
  transform: translateX(3px);
}

/* Mobile: hero search compact ayarı */
@media (max-width: 575px) {
  .theme-tatilsepeti .ts-hero { padding: 14px 0 18px; }
  .theme-tatilsepeti .ts-hsc-body { padding: 14px; gap: 10px; }
  .theme-tatilsepeti .ts-hsc-title { font-size: 15px; }
  .theme-tatilsepeti .ts-hsc-input-wrap { height: 42px; }
  .theme-tatilsepeti .ts-hero-slide-caption { font-size: 12px; padding: 7px 12px; left: 10px; bottom: 10px; max-width: 85%; }
  .theme-tatilsepeti .ts-hero-fallback-content h2 { font-size: 22px; }
}

/* ==========================================================================
   39. 3 BÜYÜK PROMOSYONEL IMAGE KART (.ts-promo-cards)
   ========================================================================== */
.theme-tatilsepeti .ts-promo-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 991px) {
  .theme-tatilsepeti .ts-promo-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575px) {
  .theme-tatilsepeti .ts-promo-cards { grid-template-columns: 1fr; }
}

.theme-tatilsepeti .ts-promo-card {
  position: relative;
  display: block;
  border-radius: var(--ts-radius-lg);
  overflow: hidden;
  text-decoration: none;
  box-shadow: var(--ts-shadow);
  background: linear-gradient(135deg, var(--ts-orange) 0%, var(--ts-navy-light) 100%);
  transition: var(--ts-transition);
  aspect-ratio: 16 / 10;
  isolation: isolate;
  min-height: 0;
  height: 100%; /* grid içinde eşit hizalama */
}
.theme-tatilsepeti .ts-promo-cards { align-items: stretch; }
.theme-tatilsepeti .ts-promo-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--ts-shadow-lg);
}
.theme-tatilsepeti .ts-promo-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.theme-tatilsepeti .ts-promo-card:hover img { transform: scale(1.06); }
.theme-tatilsepeti .ts-promo-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(10,42,94,0.85) 100%);
  z-index: 2;
}
.theme-tatilsepeti .ts-promo-card-body {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 16px 18px;
  z-index: 3;
  color: #fff;
}
.theme-tatilsepeti .ts-promo-card-title {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 8px;
  text-shadow: 0 1px 3px rgba(0,0,0,0.4);
}
.theme-tatilsepeti .ts-promo-card-title span {
  color: var(--ts-orange);
  font-weight: 800;
}
.theme-tatilsepeti .ts-promo-card-cta {
  display: inline-flex;
  align-items: center;
  background: var(--ts-orange);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: var(--ts-radius-pill);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  transition: var(--ts-transition);
}
.theme-tatilsepeti .ts-promo-card:hover .ts-promo-card-cta {
  background: #fff;
  color: var(--ts-orange);
}

/* ==========================================================================
   40. DAİRESEL KATEGORİ THUMBNAILS (.ts-circle-strip)
   YENİ: backend'den görsel gelmediğinde tema adına göre AKILLI ikon + tematik
   GRADIENT + parlama efekti + zarif hover. Düz kahverengi placeholder yerine
   neşeli/kurumsal görsel dil. (29.04.2026)
   ========================================================================== */
/* Strip — 10 daire container'ı EŞIT olarak kaplar (sağda boşluk YOK)
   • Desktop (>=576px): flex:1 ile her item eşit pay alır, gap dağılır
   • Mobile (<576px): yatay scroll, snap ile rahat kaydırma */
.theme-tatilsepeti .ts-circle-strip {
  display: flex;
  gap: 8px;
  width: 100%;
  padding: 12px 0 14px;
  justify-content: space-between; /* eşit yay */
  align-items: flex-start;
  flex-wrap: nowrap;
}

.theme-tatilsepeti .ts-circle-item {
  flex: 1 1 0;          /* eşit pay → toplam genişlik = container */
  min-width: 0;
  max-width: 120px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  transition: transform .25s cubic-bezier(.2,.7,.3,1);
}

@media (max-width: 575px) {
  /* Mobilde yatay scroll-strip moduna dön */
  .theme-tatilsepeti .ts-circle-strip {
    flex-wrap: nowrap;
    overflow-x: auto;
    justify-content: flex-start;
    gap: 12px;
    scrollbar-width: none;
    -ms-overflow-style: none;
    scroll-snap-type: x mandatory;
  }
  .theme-tatilsepeti .ts-circle-strip::-webkit-scrollbar { display: none; }
  .theme-tatilsepeti .ts-circle-item {
    flex: 0 0 auto;
    width: 84px;
    max-width: none;
    scroll-snap-align: start;
  }
}
.theme-tatilsepeti .ts-circle-item:hover {
  transform: translateY(-4px);
}

/* ---- Daire (image VEYA iconic) ---- */
.theme-tatilsepeti .ts-circle-img {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  overflow: hidden;
  position: relative;
  background: var(--ts-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  /* Çift halka: dış beyaz çerçeve + iç soft gölge → derinlik */
  box-shadow:
    0 0 0 3px #ffffff,                       /* iç beyaz halka */
    0 0 0 4px rgba(10,42,94,0.06),           /* çok ince lacivert iz */
    0 8px 18px -4px rgba(15,23,42,0.18),     /* ana gölge */
    0 2px 4px rgba(15,23,42,0.06);           /* mikro detay */
  transition: box-shadow .25s ease, transform .25s ease;
}
.theme-tatilsepeti .ts-circle-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  position: relative;
  z-index: 2;
}
/* Iconic (görsel yok) — büyük FA ikon ortada, beyaz */
.theme-tatilsepeti .ts-circle-iconic .ts-circle-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 2;
  color: #ffffff;
  font-size: 32px;
  text-shadow: 0 2px 6px rgba(0,0,0,0.18);
  transition: transform .3s cubic-bezier(.2,.7,.3,1);
}
.theme-tatilsepeti .ts-circle-img:not(.ts-circle-iconic) .ts-circle-icon { display: none; }

/* Üstten alta diyagonal beyaz "shine" — kurumsal cam efekti */
.theme-tatilsepeti .ts-circle-shine {
  position: absolute;
  top: -10%;
  left: -20%;
  width: 80%;
  height: 60%;
  background: linear-gradient(135deg, rgba(255,255,255,0.35) 0%, rgba(255,255,255,0) 60%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 3;
  transform: rotate(-12deg);
  filter: blur(2px);
}

/* Hover: lift + ikon hafif scale + dış halka turuncuya yaklaşır */
.theme-tatilsepeti .ts-circle-item:hover .ts-circle-img {
  box-shadow:
    0 0 0 3px #ffffff,
    0 0 0 5px rgba(255,107,0,0.25),
    0 12px 24px -6px rgba(255,107,0,0.30),
    0 2px 6px rgba(15,23,42,0.10);
}
.theme-tatilsepeti .ts-circle-item:hover .ts-circle-icon {
  transform: scale(1.10) rotate(-3deg);
}

/* ---- Etiket ---- */
.theme-tatilsepeti .ts-circle-label {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ts-navy);
  text-align: center;
  line-height: 1.25;
  max-width: 102px;
  letter-spacing: -0.01em;
  transition: color .2s ease;
}
.theme-tatilsepeti .ts-circle-label span { color: var(--ts-orange); font-weight: 700; }
.theme-tatilsepeti .ts-circle-item:hover .ts-circle-label { color: var(--ts-orange); }

/* ==========================================================================
   TEMATİK GRADIENT'LER — neşeli, kurumsal, sayfaya uyumlu (lacivert+turuncu ailesi)
   ========================================================================== */
/* Sahil/deniz: turkuaz → açık turuncu (yaz neşesi) */
.theme-tatilsepeti .ts-circle-grad-beach {
  background: linear-gradient(135deg, #2EC4B6 0%, #56C2C8 40%, #FF9966 100%);
}
/* Aile: sıcak peach → mercan (sıcaklık, sevinç) */
.theme-tatilsepeti .ts-circle-grad-family {
  background: linear-gradient(135deg, #FF8A65 0%, #FF6B6B 100%);
}
/* Aquaparklı: canlı okyanus mavisi → camgöbeği */
.theme-tatilsepeti .ts-circle-grad-water {
  background: linear-gradient(135deg, #2E86DE 0%, #00C9DB 100%);
}
/* Balayı: yumuşak gül pembesi → mor (romantik) */
.theme-tatilsepeti .ts-circle-grad-romance {
  background: linear-gradient(135deg, #F368E0 0%, #FF7AA2 100%);
}
/* Termal: warm bordo → mor (rahatlatıcı) */
.theme-tatilsepeti .ts-circle-grad-thermal {
  background: linear-gradient(135deg, #C44569 0%, #6F1E51 100%);
}
/* Kapadokya: toprak → altın (toprak tonu, balon havası) */
.theme-tatilsepeti .ts-circle-grad-cappadocia {
  background: linear-gradient(135deg, #F39C12 0%, #C0392B 100%);
}
/* Kış: ice mavi → derin mavi (serin, dingin) */
.theme-tatilsepeti .ts-circle-grad-winter {
  background: linear-gradient(135deg, #74B9FF 0%, #0984E3 100%);
}
/* Yurt dışı: gökyüzü → derin mor (uçuş hissi) */
.theme-tatilsepeti .ts-circle-grad-abroad {
  background: linear-gradient(135deg, #6C5CE7 0%, #A29BFE 100%);
}
/* Ocean / Gemi: derin lacivert → cam yeşili */
.theme-tatilsepeti .ts-circle-grad-ocean {
  background: linear-gradient(135deg, #0A2A5E 0%, #00B894 100%);
}
/* Kültür / tarih: krem → terra cotta */
.theme-tatilsepeti .ts-circle-grad-culture {
  background: linear-gradient(135deg, #B8860B 0%, #8B4513 100%);
}
/* Ekonomik: zümrüt yeşil → açık yeşil (tasarruf) */
.theme-tatilsepeti .ts-circle-grad-budget {
  background: linear-gradient(135deg, #00B894 0%, #55EFC4 100%);
}
/* Erken rezervasyon: lacivert → turuncu (marka renkleri) */
.theme-tatilsepeti .ts-circle-grad-early {
  background: linear-gradient(135deg, #0A2A5E 0%, #FF6B00 100%);
}
/* Son dakika: kırmızı → koyu turuncu (acele) */
.theme-tatilsepeti .ts-circle-grad-lastmin {
  background: linear-gradient(135deg, #EE5A24 0%, #EA2027 100%);
}
/* Lüks / butik: koyu mor → altın */
.theme-tatilsepeti .ts-circle-grad-lux {
  background: linear-gradient(135deg, #2C2C54 0%, #D4AF37 100%);
}
/* Her şey dahil: turuncu → mercan */
.theme-tatilsepeti .ts-circle-grad-allinc {
  background: linear-gradient(135deg, #FF6B00 0%, #FF8E53 100%);
}
/* Şehir: zarif kömür → açık gri-mavi (kurumsal) */
.theme-tatilsepeti .ts-circle-grad-city {
  background: linear-gradient(135deg, #1F2C45 0%, #57667E 100%);
}
/* Doğa: çayır yeşili → orman */
.theme-tatilsepeti .ts-circle-grad-nature {
  background: linear-gradient(135deg, #58B368 0%, #1B5E20 100%);
}
/* Default fallback: marka lacivert → marka turuncu (kurumsal kimlik) */
.theme-tatilsepeti .ts-circle-grad-default {
  background: linear-gradient(135deg, #0A2A5E 0%, #2E4A7E 100%);
}

@media (max-width: 575px) {
  /* circle-item mobil width yukarıda (4103) ayarlandı; sadece daire/label boyut ek bilgisi */
  .theme-tatilsepeti .ts-circle-img { width: 72px; height: 72px; }
  .theme-tatilsepeti .ts-circle-iconic .ts-circle-icon { font-size: 24px; }
  .theme-tatilsepeti .ts-circle-label { font-size: 11px; max-width: 84px; }
}

/* Anasayfada hero-section'ın hemen altındaki section'ların margin-top'unu 0'a yakın tut */
.theme-tatilsepeti .ts-hero + .ts-section,
.theme-tatilsepeti .ts-hero + .ts-section-tight {
  padding-top: 22px;
}
.theme-tatilsepeti .ts-section-tight {
  padding: 18px 0;
}
