/* flight-price-checker.css — extends shared.css */
:root { --cat-color: hsl(210,85%,52%); }

/* Accent overrides */
.plan-card::before { background: var(--cat-color); }
.plan-price { color: var(--cat-color); }
.plan-checkbox-wrap input { accent-color: var(--cat-color); }
.compare-bar { border-top-color: var(--cat-color); }
.compare-bar-info span { color: var(--cat-color); }
.cat-badge { background: hsla(var(--cat-h),var(--cat-s),var(--cat-l),.1); color: var(--cat-color); border-color: hsla(var(--cat-h),var(--cat-s),var(--cat-l),.25); }


/* ---- FLIGHT SEARCH FORM ---- */
.flight-form-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem;
  max-width: 700px;
  margin: 0 auto 3rem;
  box-shadow: var(--shadow-md);
}
.flight-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}
.flight-form-row .form-group { margin-bottom: 0; }
.flight-form-card select { cursor: pointer; }
.flight-submit { width: 100%; justify-content: center; padding: 0.8rem; font-size: 0.95rem; margin-top: 0.5rem; }
.flight-results-title { font-size: 1rem; font-weight: 700; margin-bottom: 1.25rem; color: var(--muted-fg); letter-spacing: 0.05em; }
.flight-disclaimer { text-align: center; color: var(--muted-fg); font-size: 0.85rem; margin-top: 2rem; padding: 0 1rem; }

@media (max-width: 560px) {
  .flight-form-card { padding: 1.25rem; }
  .flight-form-row { grid-template-columns: 1fr; gap: 0.85rem; margin-bottom: 0.85rem; }
}

/* ---- MODALS ---- */
.modal{display:none;position:fixed;inset:0;background:rgba(2,8,23,0.72);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:9999;justify-content:center;align-items:center;padding:1rem}
.modal.active{display:flex}
.modal-content{background:#fff;border:1px solid var(--border,#e2e8f0);border-radius:20px;width:100%;max-height:88vh;overflow-y:auto;animation:modalIn .25s cubic-bezier(.34,1.56,.64,1);scrollbar-width:none;box-shadow:0 24px 64px rgba(0,0,0,.3)}
.modal-content::-webkit-scrollbar{display:none}
@keyframes modalIn{from{opacity:0;transform:translateY(-18px) scale(.97)}to{opacity:1;transform:none}}
.modal-header{padding:1.35rem 1.5rem;border-bottom:1px solid var(--border,#e2e8f0);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;border-radius:20px 20px 0 0;z-index:1}
.modal-header h3{font-size:1.05rem;font-weight:800;display:flex;align-items:center;color:#0f172a;gap:.5rem;letter-spacing:-.01em}
.modal-close{background:#f1f5f9;border:none;width:32px;height:32px;border-radius:8px;cursor:pointer;color:#64748b;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.modal-close:hover{background:#fee2e2;color:#ef4444}
.modal-body{padding:1.5rem}
@media(max-width:480px){.modal{align-items:flex-end;padding:0}.modal-content{border-radius:20px 20px 0 0;max-height:92vh}.modal-header{border-radius:20px 20px 0 0}}
