.properties-page{min-height:100vh;background:#fff;padding-top:72px;padding-bottom:80px}.page-wrap{max-width:1440px;margin:0 auto}@media (min-width:768px){.page-wrap{display:flex;align-items:flex-start;gap:28px}}.filters-sidebar{position:fixed;bottom:0;left:0;right:0;z-index:1001;transform:translateY(100%);transition:transform .32s cubic-bezier(.32,.72,0,1);background:#fff;border-radius:20px 20px 0 0;max-height:82vh;overflow-y:auto}.filters-sidebar.mobile-open{transform:translateY(0)}.filters-sidebar--tall{max-height:100vh;top:0;border-radius:0;overflow:hidden}@media (min-width:768px){.filters-sidebar{position:sticky!important;width:280px;flex-shrink:0;transform:translateY(0)!important;background:transparent;border-radius:0;overflow-y:auto;overflow-x:hidden}.filters-sidebar,.filters-sidebar--tall{top:140px;max-height:calc(100vh - 160px)}.filters-sidebar--tall{overflow:auto}}.content-area{flex:1;min-width:0}.toolbar{display:flex;align-items:center;justify-content:space-between;padding-bottom:16px}.sort-select{height:38px;padding:0 28px 0 12px;border:1.5px solid #e5e7eb;border-radius:8px;font-size:12px;font-weight:600;color:#1a1a1a;letter-spacing:.03em;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:13px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;outline:none;transition:border-color .15s ease}.sort-select:focus{border-color:#304a61}.results-count{font-size:12px;font-weight:600;color:#6b7280;letter-spacing:.05em;text-transform:uppercase}.properties-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:28px 24px;padding:24px 16px 0;max-width:1440px;margin:0 auto}@media (min-width:640px){.properties-grid{grid-template-columns:repeat(2,minmax(0,1fr));padding:24px 24px 0}}@media (min-width:1024px){.properties-grid{grid-template-columns:repeat(3,minmax(0,1fr));padding:28px 32px 0}}@media (min-width:1280px){.properties-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.prop-card{display:flex;flex-direction:column;cursor:pointer;border-radius:12px;overflow:hidden;background:#fff;transition:box-shadow .2s ease}.prop-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.08)}.card-img-wrap{position:relative;width:100%;padding-top:66.66%;border-radius:12px;overflow:hidden;background:#f3f4f6}.img-badge{left:10px;background:hsla(0,0%,100%,.92);color:#1a1a1a;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;padding:4px 10px;border-radius:100px;pointer-events:none}.fav-btn,.img-badge{position:absolute;top:10px;z-index:15;backdrop-filter:blur(6px)}.fav-btn{right:10px;width:32px;height:32px;border-radius:50%;background:hsla(0,0%,100%,.85);display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:background .15s ease,transform .15s ease;color:#9ca3af}.fav-btn:hover{background:#fff;transform:scale(1.08)}.fav-btn .material-symbols-outlined{font-size:18px;font-variation-settings:"FILL" 0,"wght" 400}.fav-btn.active{color:#e11d48}.fav-btn.active .material-symbols-outlined{font-variation-settings:"FILL" 1,"wght" 400}.card-body{padding:12px 2px 0;flex:1;display:flex;flex-direction:column;gap:3px}.card-location{display:flex;align-items:center;gap:3px;font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.07em}.card-location .material-symbols-outlined{font-size:13px;color:#9ca3af}.card-name{font-size:15px;font-weight:600;color:#1a1a1a;line-height:1.3;margin-top:2px}.card-features{gap:12px;margin-top:6px}.card-feat,.card-features{display:flex;align-items:center}.card-feat{gap:4px;font-size:12px;font-weight:500;color:#6b7280}.card-feat .material-symbols-outlined{font-size:14px;color:#9ca3af}.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid #f3f4f6}.price-num{font-size:15px;font-weight:700;color:#1a1a1a}.price-unit{font-size:12px;color:#9ca3af;font-weight:500}.card-cta{display:flex;align-items:center;gap:2px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#304a61;transition:color .15s ease}.prop-card:hover .card-cta{color:#1a2a3a}@media (min-width:768px){.page-wrap .content-area .properties-grid{grid-template-columns:repeat(2,minmax(0,1fr));padding:0}}.filter-card{background:#fff;border:1.5px solid #f0f0f0;border-radius:14px;overflow:hidden}.filter-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;border-bottom:1px solid #f3f4f6}.filter-card-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:800;color:#1a1a1a;text-transform:uppercase;letter-spacing:.12em}.filter-card-title .material-symbols-outlined{font-size:16px;color:#304a61}.filter-reset{font-size:11px;font-weight:700;color:#9ca3af;background:none;border:none;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:color .15s;padding:0}.filter-reset:hover{color:#304a61}.filter-section{padding:14px 18px;border-bottom:1px solid #f3f4f6}.filter-label{font-size:10px;font-weight:800;color:#9ca3af;text-transform:uppercase;letter-spacing:.14em;margin-bottom:10px}.location-list{display:flex;flex-direction:column;gap:2px}.loc-btn{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;cursor:pointer;text-align:left;padding:7px 6px;border-radius:8px;font-size:13px;font-weight:500;color:#374151;transition:background .12s,color .12s}.loc-btn:hover{background:#f3f4f6;color:#1a1a1a}.loc-btn.active{color:#304a61;font-weight:700}.loc-btn.active .loc-dot{background:#304a61;box-shadow:0 0 0 3px rgba(48,74,97,.15)}.loc-dot{width:7px;height:7px;border-radius:50%;background:#d1d5db;flex-shrink:0;transition:background .15s,box-shadow .15s}.price-display{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.price-val{font-size:15px;font-weight:700;color:#1a1a1a}.range-wrap{position:relative;height:4px;background:#e5e7eb;border-radius:99px;overflow:visible}.range-fill{position:absolute;top:0;left:0;height:100%;background:#304a61;border-radius:99px;pointer-events:none}.range-input{position:absolute;top:50%;left:0;width:100%;transform:translateY(-50%);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer;margin:0;z-index:2}.range-input::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#304a61;border:2.5px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.18);cursor:pointer}.range-input::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#304a61;border:2.5px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.18);cursor:pointer}.bed-options{display:flex;flex-wrap:wrap;gap:6px}.bed-btn{padding:5px 13px;border:1.5px solid #e5e7eb;border-radius:99px;font-size:12px;font-weight:600;color:#374151;background:#fff;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.bed-btn:hover{border-color:#304a61;color:#304a61}.bed-btn.active{background:#304a61;border-color:#304a61;color:#fff}.type-options{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.type-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px 8px;border:1.5px solid #e5e7eb;border-radius:10px;font-size:10px;font-weight:700;color:#374151;text-transform:capitalize;background:#fff;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.type-btn.active,.type-btn:hover{border-color:#304a61;color:#304a61}.type-btn.active{background:rgba(48,74,97,.07)}.type-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#f3f4f6;color:#374151;transition:background .15s,color .15s}.type-btn.active .type-icon{background:rgba(48,74,97,.12);color:#304a61}.apply-btn{width:100%;padding:12px;background:#304a61;color:#fff;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;border:none;border-radius:8px;cursor:pointer;transition:background .15s}.apply-btn:hover{background:#1a2a3a}