/* safari-lodges.css — extends shared.css */
:root { --cat-color: hsl(138,50%,38%); }

/* 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); }


/* ---- FILTERS BAR ---- */
.filters-bar {
  background: white;
  border-bottom: 1px solid var(--border);
  padding: 1rem 1.5rem;
}
.filters-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 0.85rem;
  flex-wrap: wrap;
}
.filters-inner > span { letter-spacing: 0.04em; }
.filter-select {
  padding: 0.55rem 2.2rem 0.55rem 0.9rem;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  font-size: 0.875rem;
  font-family: inherit;
  background: var(--bg);
  color: var(--foreground);
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.filter-select:focus {
  outline: none;
  border-color: var(--cat-color);
  box-shadow: 0 0 0 3px hsla(138,50%,38%,0.12);
}

@media (max-width: 640px) {
  .filters-bar { padding: 0.85rem 1.25rem; }
  .filters-inner { flex-direction: column; align-items: stretch; gap: 0.6rem; }
  .filters-inner > span { text-align: center; }
  .filter-select { width: 100%; font-size: 16px; }
  .filters-inner .btn-primary { width: 100%; justify-content: center; }
}

/* ---- 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}}

.lodge-location { font-size: .82rem; color: #64748b; margin-bottom: .35rem; }
.lodge-non-resident { font-size: .78rem; color: #64748b; margin-top: .15rem; }
