/* style.css - light theme matching requested layout */

/* Core container */
.cfs-container {
  max-width: 920px;
  margin: 20px auto;
  padding: 10px;
}
.flight-search-form {
  background: #ffffff;
  border-radius: 12px;
  padding: 18px;
  box-shadow: 0 6px 24px rgba(20,20,40,0.06);
  font-family: "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: #1f2937;
}

/* Trip type */
.trip-type {
  display:flex;
  gap:8px;
  margin-bottom:14px;
}
.trip-btn {
  flex:1;
  background:#f4f4f6;
  border:1px solid #e6e6eb;
  padding:10px 12px;
  border-radius:8px;
  cursor:pointer;
  font-weight:600;
  color:#374151;
}
.trip-btn.active {
  background:#111827;
  color:#fff;
  box-shadow: 0 4px 8px rgba(0,0,0,0.08);
}

/* Rows */
.row { display:flex; gap:14px; margin-bottom:12px; }
.col { flex:1; min-width:0; }
.row-airports .col-air { position:relative; }

/* Labels */
.flight-search-form label { display:block; margin-bottom:6px; font-size:13px; color:#374151; }

/* Inputs */
.input-with-icon { display:flex; gap:8px; align-items:center; }
.input-with-icon input { flex:1; padding:12px 14px; border:1px solid #e6e6eb; border-radius:8px; font-size:15px; background:#fff; color:#111827; }
.input-with-icon button#swap-btn {
  background:#fff; border:1px solid #e6e6eb; padding:8px 10px; border-radius:8px; cursor:pointer;
}

/* Date inputs */
.row-dates .col input { width:100%; padding:12px 14px; border-radius:8px; border:1px solid #e6e6eb; background:#fff; }

/* Cabin toggle */
.cabin-toggle { display:flex; gap:8px; margin-top:6px; }
.cabin-option { flex:1; border:1px solid #e6e6eb; padding:10px; border-radius:8px; background:#fafafa; cursor:pointer; font-weight:600; color:#374151; }
.cabin-option.active { background:#111827; color:#fff; border-color:#111827; }

/* Passengers */
.passengers-btn { width:100%; padding:12px 14px; border-radius:8px; border:1px solid #e6e6eb; background:#fff; cursor:pointer; text-align:left; color:#111827; }
.passengers-panel {
  position:absolute;
  background:#fff;
  border:1px solid #e6e6eb;
  box-shadow:0 8px 24px rgba(20,20,40,0.06);
  padding:12px;
  border-radius:10px;
  right:0;
  width:280px;
  z-index:1000;
}
.pass-row { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid #f0f0f4; }
.pass-row:last-child { border-bottom:none; }
.stepper { display:flex; align-items:center; gap:8px; }
.stepper button { width:34px; height:34px; border-radius:6px; border:1px solid #e6e6eb; background:#fff; cursor:pointer; font-weight:700; color:#111827; }
.stepper span { min-width:22px; text-align:center; display:inline-block; }

/* Pass actions */
.pass-actions { text-align:right; margin-top:8px; }
#passengers-done { padding:8px 12px; border-radius:8px; border:none; background:#111827; color:#fff; cursor:pointer; }

/* Autocomplete suggestions */
.autocomplete-suggestions {
  position:absolute;
  top:100%;
  left:0;
  margin-top:8px;
  width:100%;
  background:#fff;
  border:1px solid #e6e6eb;
  border-radius:8px;
  box-shadow:0 8px 24px rgba(20,20,40,0.06);
  max-height:220px;
  overflow:auto;
  z-index:999;
}
.autocomplete-suggestion { padding:10px 12px; cursor:pointer; color:#111827; }
.autocomplete-suggestion:hover { background:#f6f6f8; }

/* Focused item style for keyboard nav */
.autocomplete-suggestion.focused { background:#eef2ff; }

/* Search button */
.search-btn {
  width:100%;
  padding:14px;
  border-radius:10px;
  border:none;
  background:#111827;
  color:#fff;
  font-weight:700;
  font-size:16px;
  cursor:pointer;
}

/* Tiny helpers */
.hidden { display:none !important; }

/* Responsive */
@media (max-width:760px) {
  .row { flex-direction:column; }
  .passengers-panel { right:10px; left:10px; width:auto; }
}