/* TripGozy — Itineraries Listing Page CSS */

.hero{
  position:relative;
  min-height:580px;
  display:flex;align-items:center;
  overflow:hidden;
}
/* photo background */
.hero-bg-img{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1524492412937-b28074a5d7da?w=1440&q=75&auto=format&fit=crop')
    center 42%/cover no-repeat;
}
/* gradient: strong on left for text, lightens toward right */
.hero-bg-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(
    108deg,
    rgba(7,24,41,.95) 0%,
    rgba(7,24,41,.80) 42%,
    rgba(7,24,41,.50) 68%,
    rgba(7,24,41,.25) 100%
  );
}
.hero::before{display:none}
/* decorative country flags strip */
.hero-flags{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  margin-bottom:22px;
}
.hero-flag-pill{
  display:flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);
  border-radius:999px;padding:6px 16px;font-size:14px;font-weight:600;
  color:#fff;cursor:pointer;transition:background .18s,border-color .18s;
}
.hero-flag-pill:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3)}
.hero-flag-pill.active{background:rgba(240,171,66,.18);border-color:#F0AB42;color:#F0AB42}
.hero-inner{position:relative;z-index:2;width:100%;padding:72px 0 64px}
.hero-layout{display:grid;grid-template-columns:1fr auto;align-items:center;gap:48px}
.hero-left{}
.hero-bc{display:flex;align-items:center;gap:7px;font-size:14px;
  color:rgba(255,255,255,.45);margin-bottom:20px;flex-wrap:wrap}
.hero-bc a{color:rgba(255,255,255,.52);transition:color .15s}
.hero-bc a:hover{color:#fff}
.hero-bc-sep{color:rgba(255,255,255,.25)}
.hero-h1{font-family:var(--f-display);font-size:clamp(36px,4.5vw,56px);font-weight:700;
  color:#fff;line-height:1.08;letter-spacing:-.03em;margin-bottom:14px}
.hero-h1 em{color:#F0AB42;font-style:italic}
.hero-sub{font-size:19px;font-weight:300;color:rgba(255,255,255,.72);
  line-height:1.68;max-width:520px;margin-bottom:28px}
.hero-btns{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
/* right: feature strip */
.hero-right{}
.hero-feature-strip{
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.16);
  border-radius:20px;
  padding:26px 28px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  min-width:300px;
}
.hfs-label{font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:rgba(255,255,255,.42);margin-bottom:18px}
.hfs-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px;
  padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.09)}
.hfs-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.hfs-icon{font-size:22px;flex-shrink:0;margin-top:1px}
.hfs-title{font-size:15px;font-weight:700;color:#fff;margin-bottom:3px;line-height:1.2}
.hfs-desc{font-size:13px;color:rgba(255,255,255,.6);line-height:1.5}

/* ═══════════════════════════════
   FILTER BAR — DESKTOP
═══════════════════════════════ */

/* Shell */
.filter-bar {
  background: #fff;
  border-top: 1px solid var(--c-silver);
  border-bottom: 1px solid var(--c-silver);
  padding: 16px 0;
  position: sticky; top: 64px; z-index: 90;
  box-shadow: 0 2px 10px rgba(7,24,41,.06);
}

/* Two-row column layout */
.filter-inner {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Each row — flex-wrap so future countries auto-add */
.filter-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

/* Section label */
.filter-group-label {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--c-mist);
  white-space: nowrap;
  flex-shrink: 0;
  margin-right: 2px;
  min-width: 64px;      /* aligns labels in both rows */
}

/* Chips — desktop */
.filter-chip {
  height: 38px;
  padding: 0 18px;
  border-radius: 999px;
  font-size: 14px; font-weight: 600;
  color: var(--c-slate);
  border: 1.5px solid var(--c-cloud, #D1D5DB);
  background: #fff;
  cursor: pointer;
  transition: all .18s;
  white-space: nowrap;
  line-height: 1;
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 5px;
}
.filter-chip:hover {
  border-color: var(--c-primary-600, #1E5082);
  color: var(--c-primary-800);
  background: var(--c-primary-50);
}
.filter-chip.active {
  background: var(--c-primary-800);
  color: #fff;
  border-color: var(--c-primary-800);
  box-shadow: 0 2px 8px rgba(14,42,71,.20);
}
/* count badge inside chip */
.chip-count {
  font-size: 11px; font-weight: 700;
  background: rgba(255,255,255,.22);
  border-radius: 999px;
  padding: 1px 6px;
  margin-left: 2px;
  line-height: 1.4;
}
.filter-chip:not(.active) .chip-count {
  background: var(--c-silver);
  color: var(--c-stone);
}

/* Separator between duration and sort */
.filter-sep {
  width: 1px; height: 22px;
  background: var(--c-silver);
  flex-shrink: 0; align-self: center;
  margin: 0 10px;
}

/* Sort — far right of row 2 */
.filter-sort {
  display: flex; align-items: center; gap: 8px;
  margin-left: auto; flex-shrink: 0;
}
.filter-sort-label {
  font-size: 13px; color: var(--c-stone); white-space: nowrap;
}
.filter-sort-select {
  font-family: var(--f-body);
  font-size: 14px; font-weight: 600;
  color: var(--c-primary-800);
  border: 1.5px solid var(--c-cloud, #D1D5DB);
  border-radius: 8px;
  height: 38px;
  padding: 0 34px 0 14px;
  background: #fff;
  cursor: pointer;
  outline: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  white-space: nowrap;
}

/* Active filter summary row */
.filter-active-row {
  display: none;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px dashed var(--c-silver);
}
.filter-active-row.visible { display: flex; }
.active-tag {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--c-primary-100);
  color: var(--c-primary-800);
  border-radius: 999px;
  font-size: 13px; font-weight: 600;
  padding: 4px 10px;
}
.active-tag-remove {
  background: none; border: none; cursor: pointer;
  font-size: 14px; line-height: 1; color: var(--c-primary-600,#1E5082);
  padding: 0; margin-left: 2px; opacity: .7;
  transition: opacity .15s;
}
.active-tag-remove:hover { opacity: 1; }
.clear-all-btn {
  background: none; border: none; cursor: pointer;
  font-size: 13px; font-weight: 700;
  color: var(--c-stone); padding: 4px 8px;
  border-radius: 6px; transition: color .15s, background .15s;
  margin-left: auto;
}
.clear-all-btn:hover { color: var(--c-primary-800); background: var(--c-primary-50); }

/* ═══════════════════════════════
   MOBILE FILTER — bottom sheet
═══════════════════════════════ */

/* Trigger bar — shown on mobile instead of filter-bar */
.mobile-filter-bar {
  display: none;
  background: #fff;
  border-top: 1px solid var(--c-silver);
  border-bottom: 1px solid var(--c-silver);
  padding: 10px 0;
  position: sticky; top: 56px; z-index: 90;
  box-shadow: 0 2px 8px rgba(7,24,41,.06);
}
.mobile-filter-inner {
  display: flex; align-items: center; gap: 10px;
}
.mobile-filter-btn {
  display: flex; align-items: center; gap: 8px;
  height: 44px;
  padding: 0 18px;
  border-radius: 10px;
  border: 1.5px solid var(--c-cloud, #D1D5DB);
  background: #fff;
  font-family: var(--f-body);
  font-size: 15px; font-weight: 600;
  color: var(--c-slate);
  cursor: pointer;
  transition: all .18s;
  flex: 1; justify-content: center;
}
.mobile-filter-btn:hover, .mobile-filter-btn.has-filter {
  border-color: var(--c-primary-800);
  color: var(--c-primary-800);
  background: var(--c-primary-50);
}
.mobile-filter-btn.has-filter { background: var(--c-primary-800); color: #fff; border-color: var(--c-primary-800); }
.mobile-filter-count {
  background: var(--c-accent-600);
  color: #fff; font-size: 11px; font-weight: 700;
  width: 18px; height: 18px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
}
.mobile-sort-btn {
  display: flex; align-items: center; gap: 6px;
  height: 44px; padding: 0 16px;
  border-radius: 10px;
  border: 1.5px solid var(--c-cloud, #D1D5DB);
  background: #fff;
  font-family: var(--f-body);
  font-size: 15px; font-weight: 600;
  color: var(--c-slate);
  cursor: pointer;
  white-space: nowrap;
  appearance: none;
  outline: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}

/* Bottom sheet overlay */
.sheet-overlay {
  display: none;
  position: fixed; inset: 0; z-index: 998;
  background: rgba(7,24,41,.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.sheet-overlay.open { display: block; }

/* Bottom sheet */
.filter-sheet {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 999;
  background: #fff;
  border-radius: 22px 22px 0 0;
  padding: 0;
  max-height: 85vh;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform .32s cubic-bezier(.22,.61,.36,1);
  box-shadow: 0 -8px 40px rgba(7,24,41,.18);
}
.filter-sheet.open {
  display: block;
  transform: translateY(0);
}
/* Sheet handle */
.sheet-handle {
  width: 40px; height: 4px;
  background: var(--c-cloud, #D1D5DB);
  border-radius: 2px;
  margin: 14px auto 0;
}
/* Sheet header */
.sheet-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 22px 14px;
  border-bottom: 1px solid var(--c-silver);
}
.sheet-title {
  font-family: var(--f-display);
  font-size: 20px; font-weight: 500;
  color: var(--c-primary-800);
  letter-spacing: -.015em;
}
.sheet-close {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--c-snow);
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: var(--c-stone);
  transition: background .15s;
}
.sheet-close:hover { background: var(--c-silver); }

/* Sheet sections */
.sheet-section {
  padding: 20px 22px 0;
}
.sheet-section-label {
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--c-stone);
  margin-bottom: 12px;
}
/* Radio-style option rows */
.sheet-options {
  display: flex; flex-direction: column; gap: 2px;
  margin-bottom: 20px;
}
.sheet-option {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 16px;
  border-radius: 12px;
  cursor: pointer;
  transition: background .15s;
  border: none; background: none; width: 100%;
  text-align: left;
  font-family: var(--f-body);
}
.sheet-option:hover { background: var(--c-snow); }
.sheet-option.selected { background: var(--c-primary-50); }
.sheet-option-left {
  display: flex; align-items: center; gap: 10px;
  font-size: 16px; font-weight: 500; color: var(--c-ink);
}
.sheet-option-count {
  font-size: 14px; font-weight: 600; color: var(--c-stone);
}
.sheet-option.selected .sheet-option-left { color: var(--c-primary-800); font-weight: 700; }
.sheet-option.selected .sheet-option-count { color: var(--c-primary-600, #1E5082); }
/* checkmark */
.sheet-check {
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid var(--c-silver);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: all .15s;
}
.sheet-option.selected .sheet-check {
  background: var(--c-primary-800);
  border-color: var(--c-primary-800);
}
.sheet-check-icon {
  display: none; color: #fff; font-size: 12px; font-weight: 700;
}
.sheet-option.selected .sheet-check-icon { display: block; }

.sheet-divider { height: 1px; background: var(--c-silver); margin: 4px 22px; }

/* Sheet footer CTA */
.sheet-footer {
  padding: 16px 22px 28px;
  display: grid; grid-template-columns: 1fr 2fr; gap: 10px;
  border-top: 1px solid var(--c-silver);
  position: sticky; bottom: 0;
  background: #fff;
}
.sheet-clear {
  height: 52px; border-radius: 12px;
  border: 1.5px solid var(--c-cloud, #D1D5DB);
  background: #fff; font-family: var(--f-body);
  font-size: 15px; font-weight: 600; color: var(--c-slate);
  cursor: pointer; transition: all .18s;
}
.sheet-clear:hover { border-color: var(--c-primary-800); color: var(--c-primary-800); }
.sheet-apply {
  height: 52px; border-radius: 12px;
  border: none; background: var(--c-primary-800);
  color: #fff; font-family: var(--f-body);
  font-size: 16px; font-weight: 700;
  cursor: pointer; transition: background .18s;
}
.sheet-apply:hover { background: var(--c-primary-700); }


/* ═══════════════════════════════
   RESULTS BAR
═══════════════════════════════ */
.results-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:28px 0 28px;gap:16px;
}
.results-count{font-size:16px;color:var(--c-stone)}
.results-count strong{color:var(--c-primary-800);font-weight:700}
.active-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.active-filter-tag{
  display:flex;align-items:center;gap:6px;
  padding:4px 12px;background:var(--c-primary-100);
  border-radius:999px;font-size:13px;font-weight:600;
  color:var(--c-primary-800);
}
.active-filter-remove{cursor:pointer;opacity:.6;font-size:14px;line-height:1;
  transition:opacity .15s;border:none;background:none;color:inherit;padding:0}
.active-filter-remove:hover{opacity:1}

/* ═══════════════════════════════
   ITINERARY GRID
═══════════════════════════════ */
.itin-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:48px;
}

/* ─── Individual card ─── */
.itin-card{
  background:#fff;border-radius:20px;overflow:hidden;
  box-shadow:0 2px 10px rgba(7,24,41,.07);
  transition:transform .28s,box-shadow .28s;
}
.itin-card:hover{transform:translateY(-5px);box-shadow:0 12px 36px rgba(7,24,41,.14)}
/* hide filtered-out cards */
.itin-card.hidden{display:none}

.itin-card-link{display:flex;flex-direction:column;height:100%;text-decoration:none;color:inherit}

.itin-img-wrap{overflow:hidden;position:relative;flex-shrink:0}
.itin-img{width:100%;height:210px;object-fit:cover;display:block;transition:transform .5s}
.itin-card:hover .itin-img{transform:scale(1.06)}
.itin-country-badge{
  position:absolute;top:14px;left:14px;
  background:rgba(7,24,41,.7);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  color:#fff;font-size:12px;font-weight:700;
  padding:4px 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
}

.itin-body{padding:20px 22px 22px;flex:1;display:flex;flex-direction:column}
.itin-meta{margin-bottom:10px}
.itin-days{font-size:13px;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--c-stone)}
.itin-title{font-family:var(--f-display);font-size:19px;font-weight:500;
  color:var(--c-primary-800);line-height:1.3;margin-bottom:10px;
  letter-spacing:-.015em}
.itin-desc{font-size:15px;color:var(--c-stone);line-height:1.65;
  flex:1;margin-bottom:14px}
.itin-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.tag{padding:3px 10px;background:var(--c-snow);border:1px solid var(--c-silver);
  border-radius:999px;font-size:12px;font-weight:600;color:var(--c-stone)}
.itin-cta{
  display:flex;align-items:center;gap:6px;
  font-size:15px;font-weight:700;color:var(--c-secondary-700);
  padding-top:14px;border-top:1px solid var(--c-silver);
  transition:gap .2s;
}
.itin-card:hover .itin-cta{gap:10px}
.arr{font-size:16px;transition:transform .2s}
.itin-card:hover .arr{transform:translateX(3px)}

/* hidden batch (load more) */
.itin-extra{display:none}
.itin-extra.visible{display:contents}

/* ═══════════════════════════════
   LOAD MORE
═══════════════════════════════ */
.load-more-wrap{text-align:center;margin-bottom:72px}
.load-more-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 36px;font-size:16px;font-weight:600;font-family:var(--f-body);
  color:var(--c-primary-800);border:2px solid var(--c-primary-800);
  background:#fff;border-radius:10px;cursor:pointer;
  transition:all .2s;
}
.load-more-btn:hover{background:var(--c-primary-800);color:#fff}
.load-more-btn.hidden{display:none}
.load-more-count{font-size:14px;color:var(--c-stone);margin-top:12px;display:block}

/* ═══════════════════════════════
   NO RESULTS
═══════════════════════════════ */
.no-results{
  display:none;text-align:center;padding:72px 24px;grid-column:1/-1;
}
.no-results.visible{display:block}
.no-results-icon{font-size:48px;margin-bottom:16px}
.no-results-title{font-family:var(--f-display);font-size:24px;font-weight:500;
  color:var(--c-primary-800);margin-bottom:8px}
.no-results-sub{font-size:17px;color:var(--c-stone);margin-bottom:24px}

/* ═══════════════════════════════
   BOTTOM CTA BAND
═══════════════════════════════ */
.cta-band{background:var(--c-primary-800);padding:76px 0;
  position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;right:-50px;top:-50px;
  width:280px;height:280px;border-radius:50%;background:rgba(201,123,16,.07)}
.cta-band::after{content:'';position:absolute;left:-70px;bottom:-70px;
  width:340px;height:340px;border-radius:50%;background:rgba(14,107,92,.06)}
.cta-inner{position:relative;z-index:1;text-align:center;max-width:600px;margin:0 auto}
.cta-eyebrow{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  color:#F0AB42;margin-bottom:14px}
.cta-title{font-family:var(--f-display);font-size:clamp(28px,3.8vw,44px);font-weight:700;
  color:#fff;line-height:1.12;letter-spacing:-.03em;margin-bottom:14px}
.cta-title em{color:#F0AB42;font-style:italic}
.cta-sub{font-size:18px;font-weight:300;color:rgba(255,255,255,.62);
  margin-bottom:34px;line-height:1.65}
.cta-btns{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.cta-trust{font-size:13px;color:rgba(255,255,255,.32);margin-top:16px}

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media(max-width:1024px){
  .itin-grid{grid-template-columns:repeat(2,1fr)}
  .hero-layout{grid-template-columns:1fr}
  .hero-right{display:none}
}
@media(max-width:768px){
  .itin-grid{grid-template-columns:1fr}
  .filter-bar{display:none}           /* hide desktop filter on mobile */
  .mobile-filter-bar{display:block}   /* show mobile trigger bar */
  .hero{padding:48px 0 40px}
  .results-bar{flex-direction:column;align-items:flex-start;gap:10px}
}
@media(max-width:480px){
  .hero-h1{font-size:36px}
}

