/* ============================================================
   despegar — RETOMAR · EXPLORAR · RESULTADOS · BEFORE
   ============================================================ */

/* section band inside the app (secondary stripes) -------------- */
.app-band { padding: 40px 44px; }
.app-band.alt { background: #f8fafd; border-top: 1px solid var(--line-soft); }
.band-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 20px; }
.band-title { display: flex; align-items: center; gap: 11px; }
.band-title h3 { font-size: 20px; letter-spacing: -0.02em; }
.band-title .kbadge {
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--tw-primary); background: var(--blue-50); border-radius: 6px; padding: 4px 9px; font-weight: 600;
}
.band-head .more { font-size: 13px; font-weight: 600; color: var(--tw-primary); text-decoration: none; }
.band-sub { font-size: 13.5px; color: var(--slate-500); margin-top: -12px; margin-bottom: 20px; }

/* RETOMAR ------------------------------------------------------- */
.retomar-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 16px; }
.rcard {
  background: #fff; border: 1px solid var(--line); border-radius: 15px;
  padding: 18px 20px; box-shadow: var(--sh-sm); transition: box-shadow .2s, transform .2s, border-color .2s;
  cursor: pointer;
}
.rcard:hover { box-shadow: var(--sh-md); transform: translateY(-2px); border-color: var(--blue-200); }
.rcard .rtop { display: flex; align-items: center; gap: 9px; margin-bottom: 14px; }
.rcard .rico {
  width: 30px; height: 30px; border-radius: 9px; display: flex; align-items: center; justify-content: center;
  background: var(--blue-50); color: var(--tw-primary);
}
.rcard .rico svg { width: 16px; height: 16px; }
.rcard .rico.warm { background: var(--coral-100); color: var(--coral-600); }
.rcard .rlabel { font-size: 11.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--slate-400); }

/* recent search big card */
.recent-route { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.recent-route .city { text-align: center; }
.recent-route .city .code { font-size: 22px; font-weight: 800; letter-spacing: -0.02em; }
.recent-route .city .nm { font-size: 12px; color: var(--slate-500); font-weight: 500; }
.recent-route .pathline { flex: 1; display: flex; align-items: center; gap: 6px; color: var(--slate-300); }
.recent-route .pathline .ln { flex: 1; height: 2px; background: repeating-linear-gradient(90deg, var(--slate-300) 0 5px, transparent 5px 10px); }
.recent-route .pathline svg { width: 16px; height: 16px; color: var(--tw-primary); }
.recent-meta { display: flex; gap: 8px; flex-wrap: wrap; }
.recent-meta .m { font-size: 12px; font-weight: 600; color: var(--slate-600); background: #f4f7fb; border-radius: 7px; padding: 5px 10px; }
.recent-cta { margin-top: 15px; display: flex; align-items: center; justify-content: space-between; }
.recent-cta .pr { font-size: 13px; color: var(--slate-500); }
.recent-cta .pr b { color: var(--ink); font-size: 15px; }
.recent-cta .go { font-size: 13px; font-weight: 700; color: var(--tw-accent); display: flex; align-items: center; gap: 5px; }
.recent-cta .go svg { width: 14px; height: 14px; }

/* price alert card */
.alert-price { display: flex; align-items: baseline; gap: 8px; margin-top: 4px; }
.alert-price .now { font-size: 26px; font-weight: 800; letter-spacing: -0.03em; }
.alert-price .was { font-size: 14px; color: var(--slate-400); text-decoration: line-through; }
.alert-drop { display: inline-flex; align-items: center; gap: 5px; margin-top: 10px; font-size: 12.5px; font-weight: 700; color: #138a4e; background: #e6f6ec; border-radius: 8px; padding: 5px 10px; }
.alert-drop svg { width: 13px; height: 13px; }
.rcard .rfoot { font-size: 12px; color: var(--slate-500); margin-top: 13px; }

/* saved card */
.saved-thumb { height: 70px; border-radius: 11px; margin-bottom: 12px; position: relative; overflow: hidden;
  background: var(--ph-stripes), linear-gradient(140deg, var(--blue-100), var(--blue-50)); }
.saved-list { display: flex; flex-direction: column; gap: 9px; }
.saved-list .sv { display: flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 600; color: var(--slate-700); }
.saved-list .sv .heart { width: 15px; height: 15px; color: var(--coral-500); }

/* EXPLORAR ------------------------------------------------------ */
.explore-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.budget-row { display: flex; gap: 10px; margin-bottom: 22px; flex-wrap: wrap; }
.budget-chip {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  border: 1.5px solid var(--line); background: #fff; border-radius: 999px;
  padding: 9px 16px; font-size: 13px; font-weight: 600; color: var(--slate-600); transition: all .15s;
}
.budget-chip.on { border-color: var(--tw-primary); background: var(--blue-50); color: var(--tw-primary); }
.budget-chip:hover:not(.on) { border-color: var(--blue-200); }

.dest-card {
  position: relative; border-radius: 15px; overflow: hidden; cursor: pointer;
  height: 230px; box-shadow: var(--sh-sm); transition: transform .25s, box-shadow .25s;
}
.dest-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.dest-card .photo { position: absolute; inset: 0; background: var(--ph-stripes), linear-gradient(160deg, var(--blue-200), var(--tw-primary)); }
.dest-card.c2 .photo { background: var(--ph-stripes), linear-gradient(160deg, var(--coral-200), var(--coral-500)); }
.dest-card.c3 .photo { background: var(--ph-stripes), linear-gradient(160deg, #bfe6cf, #2e9e63); }
.dest-card.c4 .photo { background: var(--ph-stripes), linear-gradient(160deg, var(--blue-100), var(--celeste)); }
.dest-card .scrim { position: absolute; inset: 0; background: linear-gradient(transparent 38%, rgba(8,20,40,.78)); }
.dest-card .ph-tag {
  position: absolute; top: 12px; left: 12px; font-family: var(--font-mono); font-size: 10px;
  color: rgba(255,255,255,.82); background: rgba(8,20,40,.32); border: 1px solid rgba(255,255,255,.25);
  border-radius: 6px; padding: 3px 8px; backdrop-filter: blur(3px);
}
.dest-card .dinfo { position: absolute; left: 16px; right: 16px; bottom: 15px; color: #fff; }
.dest-card .dname { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; }
.dest-card .dwhen { font-size: 12px; color: rgba(255,255,255,.8); }
.dest-card .dprice { margin-top: 8px; display: flex; align-items: baseline; gap: 5px; }
.dest-card .dprice .from { font-size: 11px; color: rgba(255,255,255,.78); }
.dest-card .dprice .amt { font-size: 19px; font-weight: 800; letter-spacing: -0.02em; }

:root { --ph-stripes: repeating-linear-gradient(135deg, rgba(255,255,255,.07) 0 9px, transparent 9px 18px); }

/* ---------------------------------------------------------------
   FLIGHT RESULTS
   --------------------------------------------------------------- */
.results-top { padding: 20px 32px; background: #fff; border-bottom: 1px solid var(--line-soft); display: flex; align-items: center; gap: 18px; }
.results-route { display: flex; align-items: center; gap: 12px; }
.results-route .rt-city { font-size: 17px; font-weight: 800; letter-spacing: -0.02em; }
.results-route svg { width: 17px; height: 17px; color: var(--tw-primary); }
.results-top .rt-meta { font-size: 13px; color: var(--slate-500); font-weight: 500; }
.results-top .rt-meta b { color: var(--slate-700); font-weight: 600; }
.results-top .edit-search { margin-left: auto; font-size: 13px; font-weight: 600; color: var(--tw-primary); border: 1px solid var(--line); border-radius: 10px; padding: 9px 15px; background: #fff; cursor: pointer; display: flex; align-items: center; gap: 7px; }
.results-top .edit-search svg { width: 14px; height: 14px; }

.results-body { display: grid; grid-template-columns: 248px 1fr; gap: 24px; padding: 24px 32px 36px; background: #f8fafd; }

/* filters */
.filters { display: flex; flex-direction: column; gap: 18px; }
.filter-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 17px 18px; box-shadow: var(--sh-sm); }
.filter-card h5 { font-size: 13px; font-weight: 700; letter-spacing: .02em; margin-bottom: 14px; display: flex; align-items: center; justify-content: space-between; }
.filter-card h5 .clear { font-size: 11px; color: var(--slate-400); font-weight: 600; cursor: pointer; }
.fopt { display: flex; align-items: center; gap: 10px; padding: 7px 0; font-size: 13px; color: var(--slate-700); cursor: pointer; }
.fopt .chk { width: 18px; height: 18px; border-radius: 6px; border: 1.5px solid var(--slate-300); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .15s; }
.fopt .chk svg { width: 11px; height: 11px; color: #fff; opacity: 0; }
.fopt.on .chk { background: var(--tw-primary); border-color: var(--tw-primary); }
.fopt.on .chk svg { opacity: 1; }
.fopt .fcount { margin-left: auto; font-size: 12px; color: var(--slate-400); font-weight: 600; }
.fopt:hover { color: var(--ink); }

/* price slider mock */
.price-track { height: 4px; border-radius: 2px; background: var(--line); position: relative; margin: 14px 4px 8px; }
.price-track .fillbar { position: absolute; left: 12%; right: 26%; top: 0; bottom: 0; background: var(--tw-primary); border-radius: 2px; }
.price-track .knob { position: absolute; top: 50%; width: 16px; height: 16px; border-radius: 50%; background: #fff; border: 2px solid var(--tw-primary); transform: translate(-50%,-50%); box-shadow: var(--sh-sm); }
.price-track .knob.a { left: 12%; }
.price-track .knob.b { left: 74%; }
.price-vals { display: flex; justify-content: space-between; font-size: 12px; font-weight: 600; color: var(--slate-600); }

/* sort bar */
.sort-bar { display: flex; gap: 9px; margin-bottom: 16px; align-items: center; }
.sort-bar .slabel { font-size: 12.5px; color: var(--slate-500); font-weight: 600; margin-right: 2px; }
.sort-pill { font-size: 12.5px; font-weight: 600; color: var(--slate-600); border: 1.5px solid var(--line); background: #fff; border-radius: 10px; padding: 8px 14px; cursor: pointer; display: flex; flex-direction: column; gap: 1px; min-width: 96px; }
.sort-pill.on { border-color: var(--tw-primary); background: var(--blue-50); color: var(--tw-primary); }
.sort-pill .sp-sub { font-size: 11px; font-weight: 500; color: var(--slate-400); }
.sort-pill.on .sp-sub { color: var(--blue-500); }
.sort-bar .count { margin-left: auto; font-size: 13px; color: var(--slate-500); }
.sort-bar .count b { color: var(--slate-700); }

/* flight card */
.flights { display: flex; flex-direction: column; gap: 12px; }
.flight {
  background: #fff; border: 1px solid var(--line); border-radius: 15px;
  display: grid; grid-template-columns: 1fr 196px; overflow: hidden;
  box-shadow: var(--sh-sm); transition: box-shadow .2s, border-color .2s, transform .2s;
}
.flight:hover { box-shadow: var(--sh-md); border-color: var(--blue-200); transform: translateY(-1px); }
.flight.best { border-color: var(--tw-primary); box-shadow: 0 0 0 1px var(--tw-primary), var(--sh-md); }
.flight .fmain { padding: 18px 22px; }
.flight .ftag { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--tw-primary); background: var(--blue-50); border-radius: 6px; padding: 4px 9px; margin-bottom: 13px; }
.flight .ftag.cheap { color: #138a4e; background: #e6f6ec; }
.flight .airline { display: flex; align-items: center; gap: 11px; margin-bottom: 14px; }
.flight .al-logo { width: 30px; height: 30px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 12px; color: #fff; flex-shrink: 0; }
.flight .al-name { font-size: 13px; font-weight: 600; color: var(--slate-600); }
.flight .al-flt { font-size: 11.5px; color: var(--slate-400); }

.fsched { display: flex; align-items: center; gap: 18px; }
.fsched .seg { text-align: left; }
.fsched .seg .time { font-size: 22px; font-weight: 800; letter-spacing: -0.02em; }
.fsched .seg .ap { font-size: 12px; color: var(--slate-500); font-weight: 600; }
.fsched .dur { flex: 1; text-align: center; min-width: 120px; }
.fsched .dur .dtime { font-size: 12px; color: var(--slate-500); font-weight: 600; margin-bottom: 5px; }
.fsched .dur .dline { height: 2px; background: var(--line); position: relative; border-radius: 2px; }
.fsched .dur .dline::before, .fsched .dur .dline::after { content: ""; position: absolute; top: 50%; transform: translateY(-50%); width: 6px; height: 6px; border-radius: 50%; background: var(--slate-300); }
.fsched .dur .dline::before { left: 0; } .fsched .dur .dline::after { right: 0; }
.fsched .dur .stop-dot { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 7px; height: 7px; border-radius: 50%; background: var(--coral-500); border: 2px solid #fff; }
.fsched .dur .stops { font-size: 11.5px; font-weight: 600; margin-top: 5px; }
.fsched .dur .stops.direct { color: #138a4e; }
.fsched .dur .stops.one { color: var(--slate-500); }

.fextra { display: flex; gap: 14px; margin-top: 15px; padding-top: 13px; border-top: 1px solid var(--line-soft); }
.fextra .fx { display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--slate-500); }
.fextra .fx svg { width: 14px; height: 14px; }
.fextra .fx.ok { color: #138a4e; }
.fextra .fx.no { color: var(--slate-400); }

.fprice { background: #fbfcfe; border-left: 1px solid var(--line-soft); padding: 18px 20px; display: flex; flex-direction: column; justify-content: center; align-items: flex-end; text-align: right; }
.fprice .ptotal { font-size: 11px; color: var(--slate-400); font-weight: 600; }
.fprice .pusd { font-size: 26px; font-weight: 800; letter-spacing: -0.03em; color: var(--ink); }
.fprice .pars { font-size: 12px; color: var(--slate-500); font-weight: 600; margin-top: 1px; }
.fprice .pnight { font-size: 11px; color: var(--slate-400); margin-top: 3px; }
.fprice .select { margin-top: 14px; width: 100%; background: var(--tw-accent); color: #fff; border: none; border-radius: 11px; padding: 11px 0; font-family: inherit; font-weight: 700; font-size: 14px; cursor: pointer; box-shadow: 0 5px 14px rgba(232,67,31,.3); transition: box-shadow .2s; }
.fprice .select:hover { box-shadow: 0 9px 20px rgba(232,67,31,.42); }
.flight:not(.best) .fprice .select { background: #fff; color: var(--tw-primary); border: 1.5px solid var(--line); box-shadow: none; }
.flight:not(.best) .fprice .select:hover { border-color: var(--tw-primary); box-shadow: none; }
