/* ===== Filter modal (shared) ===== */
.modal{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: clamp(12px, 2.5vw, 24px);
  overflow: auto;
  z-index: 1000;
}
.modal.open{ display: flex; }

.panel{
  background: var(--panel, #1c1c1c);
  border-radius: 16px;
  width: min(1000px, 100%);
  max-width: 100%;
  max-height: min(85vh, 100%);
  padding: 16px;
  box-shadow: 0 24px 72px rgba(0,0,0,.25);
  color: var(--ink, #f5f5f5);
  overflow: auto;
}
.panel h2{ margin: 4px 0 12px 0; }

.field{ display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; min-width: 0; }

.price-range-shell{
  display:grid;
  grid-template-columns:minmax(96px, 118px) minmax(0, 1fr) minmax(96px, 118px);
  align-items:center;
  gap:12px;
}
.price-range-input{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
}
.price-range-input__label{
  font-size:12px;
  font-weight:700;
  color:rgba(255,255,255,.72);
  letter-spacing:.01em;
}
.price-range-slider{
  position:relative;
  min-width:0;
  height:44px;
  display:flex;
  align-items:center;
}
.price-range-slider__track,
.price-range-slider__fill{
  position:absolute;
  left:0;
  right:0;
  height:6px;
  border-radius:999px;
  pointer-events:none;
}
.price-range-slider__track{
  background:rgba(255,255,255,.12);
  box-shadow:inset 0 1px 3px rgba(0,0,0,.25);
}
.price-range-slider__fill{
  left:0;
  width:100%;
  background:linear-gradient(90deg,#ffd700,#ffed4e,#fff8dc);
  box-shadow:0 0 0 1px rgba(255,215,0,.12);
}
.price-range-slider input[type="range"]{
  position:absolute;
  left:0;
  width:100%;
  margin:0;
  pointer-events:none;
  appearance:none;
  -webkit-appearance:none;
  background:transparent;
  height:44px;
}
.price-range-slider input[type="range"]::-webkit-slider-thumb{
  appearance:none;
  -webkit-appearance:none;
  width:18px;
  height:18px;
  margin-top:-6px;
  border-radius:50%;
  border:2px solid #111;
  background:#ffd700;
  box-shadow:0 4px 10px rgba(0,0,0,.3);
  pointer-events:auto;
  cursor:pointer;
}
.price-range-slider input[type="range"]::-moz-range-thumb{
  width:18px;
  height:18px;
  border-radius:50%;
  border:2px solid #111;
  background:#ffd700;
  box-shadow:0 4px 10px rgba(0,0,0,.3);
  pointer-events:auto;
  cursor:pointer;
}
.price-range-slider input[type="range"]::-webkit-slider-runnable-track{
  height:6px;
  background:transparent;
}
.price-range-slider input[type="range"]::-moz-range-track{
  height:6px;
  background:transparent;
}

.field-row{ display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width:640px){
  .field-row{ grid-template-columns: 1fr; }
  .price-range-shell{
    grid-template-columns:minmax(78px, 96px) minmax(0, 1fr) minmax(78px, 96px);
    gap:8px;
  }
  .price-range-input__label{
    font-size:11px;
  }
}

/* Mobile-specific panel sizing */
@media (max-width: 720px){
  .modal{
    padding: 10px;
    align-items: stretch;
  }
  .panel{
    width: 100%;
    min-height: min(100%, calc(100dvh - 20px));
    max-height: none;
    border-radius: 14px;
  }
}

fieldset{
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  margin: 14px 0;
  padding: 16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.015)),
    #161616;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}
legend{
  padding: 0 8px;
  color: var(--ink, #f5f5f5);
  opacity: .9;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -.01em;
}

.toggle-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  gap:14px;
}
.toggle-grid--quick{
  margin-top: 4px;
}
.toggle-grid--compact{
  grid-template-columns:repeat(auto-fit, minmax(min(100%, 168px), 1fr));
  gap:12px;
}
.toggle-grid--pets{
  grid-template-columns:repeat(auto-fit, minmax(min(100%, 160px), max-content));
  gap:10px;
  align-items:start;
}
.amenities, .parking-list, .nearby-list{
  columns: initial;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  gap: 14px;
}
.toggle-option{
  position:relative;
  display:flex;
  align-items:center;
  gap:14px;
  min-height:60px;
  margin:0;
  padding:16px 18px;
  border:1px solid rgba(255,255,255,.05);
  border-radius:20px;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.045), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.008)),
    #151515;
  color:rgba(255,255,255,.92);
  line-height:1.35;
  cursor:pointer;
  overflow:hidden;
  transition:
    transform .18s ease,
    border-color .18s ease,
    background .18s ease,
    box-shadow .18s ease,
    color .18s ease,
    filter .18s ease;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    inset 0 -1px 0 rgba(255,255,255,.015),
    0 14px 24px rgba(0,0,0,.22);
}
.toggle-option::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(255,255,255,.02), transparent 42%, rgba(255,215,0,.03));
  opacity:.9;
  pointer-events:none;
}
.toggle-option--quick{
  min-height:58px;
}
.toggle-option--compact{
  min-height:48px;
  padding:12px 14px;
  gap:10px;
  border-radius:16px;
}
.toggle-option--compact .toggle-option__label{
  font-size:14px;
  font-weight:650;
  text-wrap:pretty;
}
.toggle-option--list{
  min-height:64px;
}
.toggle-option--pet{
  min-height:44px;
  padding:10px 14px;
  gap:10px;
  border-radius:16px;
}
.toggle-option__label{
  position:relative;
  z-index:1;
  min-width:0;
  font-size:15px;
  font-weight:700;
  letter-spacing:-.01em;
  text-wrap:balance;
  color:rgba(255,255,255,.92);
}
.toggle-option--list .toggle-option__label{
  font-size:14px;
  font-weight:650;
  color:#ececec;
}
.toggle-option--pet .toggle-option__label{
  font-size:14px;
  font-weight:650;
  color:#ececec;
}
.toggle-option:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.12);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.06), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.012)),
    #1a1a1a;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    inset 0 -1px 0 rgba(255,255,255,.018),
    0 18px 28px rgba(0,0,0,.28);
}
.toggle-option input{
  position:absolute;
  inset:0;
  margin:0;
  opacity:0;
  cursor:pointer;
  z-index:2;
}
.toggle-option__indicator{
  position:relative;
  z-index:1;
  width:20px;
  height:20px;
  flex:0 0 20px;
  border-radius:7px;
  border:1.5px solid rgba(255,255,255,.26);
  background:rgba(255,255,255,.035);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 2px 6px rgba(0,0,0,.18);
  transition:
    border-color .18s ease,
    background .18s ease,
    box-shadow .18s ease,
    transform .18s ease;
}
.toggle-option__indicator::after{
  content:"";
  position:absolute;
  inset:4px;
  border-radius:4px;
  background:#ffd700;
  transform:scale(.45);
  opacity:0;
  transition:transform .18s ease, opacity .18s ease, border-radius .18s ease;
}
.toggle-option:has(input[type="radio"]) .toggle-option__indicator{
  border-radius:999px;
}
.toggle-option:has(input[type="radio"]) .toggle-option__indicator::after{
  inset:5px;
  border-radius:999px;
}
.toggle-option:has(input:checked){
  border-color: rgba(255,215,0,.34);
  background:
    radial-gradient(circle at top left, rgba(255,240,176,.09), transparent 36%),
    linear-gradient(135deg, rgba(255,215,0,.14), rgba(255,237,78,.045) 42%, rgba(255,255,255,.02)),
    #19160d;
  color:#fff6d4;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    inset 0 -1px 0 rgba(255,215,0,.08),
    0 18px 30px rgba(0,0,0,.3);
}
.toggle-option:has(input:checked) .toggle-option__label{
  color:#fff9e8;
}
.toggle-option:has(input:checked) .toggle-option__indicator{
  border-color: rgba(255,215,0,.9);
  background:rgba(255,215,0,.12);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    0 0 0 4px rgba(255,215,0,.08);
}
.toggle-option:has(input:checked) .toggle-option__indicator::after{
  transform:scale(1);
  opacity:1;
}
.toggle-option:has(input:focus-visible){
  outline: 2px solid rgba(255,215,0,.45);
  outline-offset: 2px;
}
@supports not selector(:has(*)){
  .toggle-option input{
    position:static;
    inset:auto;
    opacity:1;
    width:18px;
    height:18px;
    flex:0 0 18px;
    accent-color:#ffd700;
  }
  .toggle-option__indicator{
    display:none;
  }
}

.sticky-bar{
  position: sticky;
  bottom: 0;
  background: transparent;
  border-top: none;
  padding: 10px;
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
@media (max-width: 720px){
  .sticky-bar{ flex-wrap: wrap; }
}

.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 16px;
  min-height: 36px;
  border-radius: 20px;
  border: none;
  background: #8a8a8a;
  color: #111111;
  cursor: pointer;
  text-decoration: none;
  line-height: 1;
}
.btn.secondary{
  background: #181818;
  color: var(--ink, #f5f5f5);
  border: 1px solid var(--muted, #3a3a3a);
}

/* Primary action in filter modal – gold gradient */
#filterModal .btn[type="submit"]{
  background: linear-gradient(90deg,#ffd700,#ffed4e,#fff8dc);
  color: #1a1a1a;
  border: none;
  font-weight: 700;
}
#filterModal .btn[type="submit"]:hover{
  background: linear-gradient(90deg,#ffe033,#fff077,#fff8dc);
}

.panel input[type="number"],
.panel select,
.panel input[type="text"]{
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 14px;
  box-sizing: border-box; /* prevent overflow beyond grid cell */
  background: #181818;
  color: var(--ink, #f5f5f5);
}

.panel input[type="number"]:focus,
.panel select:focus,
.panel input[type="text"]:focus{
  outline:none;
  border-color: rgba(255,215,0,.4);
  box-shadow: 0 0 0 3px rgba(255,215,0,.12);
}

.soft-hr{ border: 0; border-top: 1px solid #eee; margin: 16px 0; }
