.btn-filter{background-color:#fff;color:#374151;padding:.5rem 1rem;border-radius:.25rem;font-weight:500;border:1px solid #d1d5db;transition:all .3s}.btn-filter:hover,.btn-filter.active{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.property-card{display:flex;flex-direction:column;transition:none!important;position:relative;overflow:hidden;border-radius:12px;background-color:#fff;box-shadow:0 4px 10px #0000001a;max-width:500px;margin:0 auto}.property-card:hover{transform:none!important;box-shadow:0 4px 10px #0000001a!important}.property-top-section{position:relative;height:280px;overflow:hidden;cursor:pointer;text-decoration:none;color:inherit;transition:none}.property-top-section:hover{text-decoration:none;color:inherit}.property-image{position:relative;height:100%;overflow:hidden;border-radius:12px 12px 0 0}.property-top-section .property-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .4s ease}.property-top-section:hover .property-image img{transform:scale(1.08)}.property-features-panel{position:absolute;left:0;width:100%;display:flex;justify-content:space-around;padding:10px;background-color:#3b82f6e6;transition:all .3s ease;z-index:10}@media (min-width: 640px){.property-features-panel{bottom:-100px}.property-top-section:hover .property-features-panel{bottom:0}}@media (max-width: 639px){.property-features-panel{bottom:0;padding:8px}}.feature-item{display:flex;align-items:center;justify-content:center;gap:5px;color:#fff;font-size:.85rem}.feature-icon{color:#dbeafe}.property-view-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#2196f3e6;border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.property-top-section:hover .property-view-overlay{opacity:1;transform:translate(-50%,-50%) scale(1.1)}.view-icon{color:#fff;font-size:1.5rem}.property-info-section{padding:16px!important;background:#fff!important;display:flex!important;flex-direction:column!important;justify-content:space-between!important;flex:1!important;min-height:140px!important}.property-title{width:100%!important;display:flex!important;flex-direction:column!important;gap:8px!important;flex:1!important}.property-name{font-size:1.125rem!important;font-weight:600!important;line-height:1.4!important;color:#1f2937!important;margin:0!important;width:100%!important;height:2.8em!important;overflow:hidden!important;display:-webkit-box!important;-webkit-line-clamp:2!important;-webkit-box-orient:vertical!important}.property-badges{display:flex!important;gap:6px!important;flex-wrap:wrap!important;min-height:24px!important;align-items:flex-start!important}.property-badge-info{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.badge-recent{background:#f0fdf4!important;color:#15803d!important;border-color:#22c55e!important}.badge-updated{background:#eff6ff!important;color:#1d4ed8!important}.badge-reduced{background-color:#e3f2fd;color:#0d47a1}.badge-urgent{background-color:#bbdefb;color:#1565c0;animation:pulse 2s infinite}.badge-exclusive{background-color:#1976d2;color:#fff}.badge-tour{background-color:#42a5f5;color:#fff}.badge-new-construction{background-color:#90caf9;color:#0d47a1}.badge-investment{background-color:#1e88e5;color:#fff}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 640px){.property-badge-info{font-size:.6875rem;padding:.1875rem .375rem}}.property-address{font-size:.875rem!important;color:#6b7280!important;margin:0!important;display:flex!important;align-items:flex-start!important;gap:6px!important;min-height:2.4em!important;line-height:1.4!important}.property-address i{color:#1976d2!important;font-size:.75rem!important;margin-top:2px!important;flex-shrink:0!important}.property-address span{overflow:hidden!important;display:-webkit-box!important;-webkit-line-clamp:2!important;-webkit-box-orient:vertical!important}.property-bottom-row{display:flex!important;justify-content:space-between!important;align-items:center!important;margin-top:auto!important;padding-top:8px!important;flex-shrink:0!important}.property-price-display{font-size:1.25rem!important;font-weight:700!important;color:#1976d2!important}.favorite-toggle{background:none!important;border:none!important;cursor:pointer!important;padding:8px!important;border-radius:50%!important;transition:all .3s ease!important;color:#9ca3af!important;font-size:1.4rem!important;min-width:40px!important;height:40px!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important}.favorite-toggle i.bookmark,i.fa-bookmark{cursor:pointer!important}.favorite-toggle:hover{background:#e3f2fd!important;color:#1976d2!important}.favorite-toggle.active{color:#1976d2!important;background:#e3f2fd!important}.favorite-toggle.active i{font-weight:900!important}.favorite-toggle i{font-weight:400!important;cursor:pointer!important}.favorite-toggle.active i{font-weight:900!important;cursor:pointer!important}.filter-dormitorio,.filter-bano{transition:all .2s}.filter-dormitorio.active,.filter-bano.active{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.filter-dormitorio:hover,.filter-bano:hover{background-color:#eff6ff;border-color:#3b82f6}.pagination-item{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;margin:0 5px;font-weight:500;transition:all .3s;color:#374151;text-decoration:none}.pagination-item:hover{background-color:#eff6ff;color:#3b82f6}.pagination-item.active{background-color:#3b82f6;color:#fff}.filter-tag{display:inline-flex;align-items:center;background-color:#eff6ff;color:#1e40af;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.filter-tag .remove-filter{margin-left:.5rem;cursor:pointer;color:#6b7280;transition:color .2s}.filter-tag .remove-filter:hover{color:#ef4444}@media (max-width: 1023px){#filters-panel{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}#filters-panel.show{transform:translate(0)}}.loading{opacity:.6;pointer-events:none}input,select,button{transition:all .2s ease}input:focus,select:focus{outline:none;ring:2px;ring-color:#3b82f6;border-color:#3b82f6}input[type=checkbox]{width:1rem;height:1rem;color:#3b82f6;border-radius:.25rem}input[type=radio]{width:1rem;height:1rem;color:#3b82f6}@media (max-width: 639px){.property-info-section{padding:12px!important;min-height:120px!important}.property-name{font-size:1rem!important;height:2.6em!important}.property-address{font-size:.75rem!important;min-height:2.2em!important}.property-price-display{font-size:1.1rem!important}.favorite-toggle{font-size:1.2rem!important;min-width:36px!important;height:36px!important;padding:6px!important}}.grid.grid-cols-1.md\:grid-cols-2.xl\:grid-cols-3{align-items:stretch!important}.grid.grid-cols-1.md\:grid-cols-2.xl\:grid-cols-3 .property-card{height:100%!important;display:flex!important;flex-direction:column!important}.property-top-section{height:280px!important;flex-shrink:0!important}.property-info-section{flex:1!important;display:flex!important;flex-direction:column!important;justify-content:space-between!important;padding:16px!important;min-height:120px!important}@media (max-width: 768px){.grid.grid-cols-1.md\:grid-cols-2.xl\:grid-cols-3 .property-card{min-height:400px!important}.property-top-section{height:250px!important}}@media (min-width: 640px) and (max-width: 768px){.property-name{height:2.7em!important}.property-address{min-height:2.3em!important}}.extra-checkbox-text{font-size:.875rem;color:#374151;font-weight:500;line-height:1.3}.extra-checkbox-item{display:flex;align-items:center;gap:.75rem;padding:1rem!important;background:#fff;border-radius:.5rem;cursor:pointer;transition:all .2s ease;position:relative}.extra-checkbox-item:hover{background:#f0f9ff;border-color:#2196f3}.extra-checkbox-item input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.extra-checkbox-custom{width:20px;height:20px;border:2px solid #d1d5db;border-radius:.25rem;background:#fff;position:relative;transition:all .2s ease;flex-shrink:0}.extra-checkbox-item input[type=checkbox]:checked+.extra-checkbox-custom{background:#2196f3;border-color:#2196f3}.extra-checkbox-item input[type=checkbox]:checked+.extra-checkbox-custom:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.extra-checkbox-text{font-size:.875rem;color:#374151;font-weight:500;line-height:1.3;flex:1}.extra-checkbox-item input[type=checkbox]:checked~.extra-checkbox-text{color:#1976d2}.extra-checkbox-item:has(input[type=checkbox]:checked){background:#f0f9ff!important}.extra-checkbox-item.checked{background:#f0f9ff!important}footer .footer-contact-form input[type=text],footer .footer-contact-form input[type=email],footer .footer-contact-form textarea{background-color:#374151!important;border:1px solid #4b5563!important;color:#fff!important;border-radius:.375rem!important}footer .footer-contact-form input[type=text]:focus,footer .footer-contact-form input[type=email]:focus,footer .footer-contact-form textarea:focus{border-color:#3b82f6!important;background-color:#374151!important;box-shadow:none!important}footer .footer-contact-form input[type=text]:hover,footer .footer-contact-form input[type=email]:hover,footer .footer-contact-form textarea:hover{background-color:#4b5563!important}footer .footer-contact-form input[type=text]::-moz-placeholder,footer .footer-contact-form input[type=email]::-moz-placeholder,footer .footer-contact-form textarea::-moz-placeholder{color:#9ca3af!important}footer .footer-contact-form input[type=text]::placeholder,footer .footer-contact-form input[type=email]::placeholder,footer .footer-contact-form textarea::placeholder{color:#9ca3af!important}@media (max-width: 767px){.extra-checkbox-item{width:100%!important;padding:.75rem!important;gap:.75rem;margin-bottom:.5rem;max-width:none!important;min-width:100%!important;box-sizing:border-box}.extra-checkbox-custom{width:18px;height:18px}.extra-checkbox-text{font-size:.875rem;flex:1;text-align:left}.extra-checkbox-item{left:0;right:0}}@media (min-width: 768px) and (max-width: 1023px){.extra-checkbox-item{padding:.625rem;width:100%;max-width:none}}@media (min-width: 1024px){.extra-checkbox-item{width:auto;max-width:none}}@media (max-width: 767px){.extra-checkbox-item{grid-column:1 / -1;flex-basis:100%;flex-grow:1}#extra-features,.extra-features-container,.checkbox-container{width:100%!important;max-width:none!important}.extra-checkbox-item{flex:0 0 100%;width:100%}}@media (max-width: 767px){.extra-checkbox-item+.extra-checkbox-item{margin-top:.5rem}.extra-checkbox-item{min-height:48px;padding:.75rem 1rem}.extra-checkbox-item:active{background:#e3f2fd;transform:scale(.98)}}:root{--blue-50: #E3F2FD;--blue-100: #BBDEFB;--blue-200: #90CAF9;--blue-300: #64B5F6;--blue-400: #42A5F5;--blue-500: #2196F3;--blue-600: #1E88E5;--blue-700: #1976D2;--blue-800: #1565C0;--blue-900: #0D47A1}.filters-panel-mobile{position:fixed;top:0;left:0;width:100%;max-width:380px;height:100vh;background:#fff;z-index:50;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:2px 0 25px #00000026}.filters-panel-mobile.show{transform:translate(0)}.filters-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:40;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s ease-in-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.filters-overlay.show{opacity:1;visibility:visible}.btn-primary{background:var(--blue-500);color:#fff;padding:12px 24px;border-radius:8px;font-weight:500;transition:all .2s ease;border:none;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary:hover{background:var(--blue-600);transform:translateY(-1px);box-shadow:0 4px 12px #2196f34d}.btn-primary:active{background:var(--blue-700);transform:translateY(0)}.btn-primary:focus{outline:none;ring:2px solid var(--blue-500);ring-offset:2px}.btn-secondary{background:transparent;color:var(--blue-500);padding:12px 24px;border-radius:8px;font-weight:500;border:1px solid var(--blue-500);transition:all .2s ease;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-secondary:hover{background:var(--blue-50);color:var(--blue-600);border-color:var(--blue-600);transform:translateY(-1px)}.btn-secondary:active{transform:translateY(0)}.mobile-filters-btn{background:var(--blue-500);color:#fff;padding:12px 16px;border-radius:8px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;transition:all .2s ease;width:100%;position:relative}.mobile-filters-btn:hover{background:var(--blue-600);transform:translateY(-1px);box-shadow:0 4px 12px #2196f34d}.mobile-filters-btn:active{transform:translateY(0)}.active-filters-count{background:#ef4444;color:#fff;font-size:.75rem;font-weight:700;padding:4px 8px;border-radius:9999px;margin-left:8px;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;animation:pulse 1s ease-in-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.input-focus:focus{outline:none!important;border-color:var(--blue-500)!important;box-shadow:0 0 0 2px #2196f333!important}.form-input{width:100%;padding:12px 16px;border:1px solid #D1D5DB;border-radius:8px;font-size:14px;transition:all .2s ease;background:#fff}.form-input:hover{border-color:var(--blue-300)}.form-input:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 2px #2196f333}.form-input::-moz-placeholder{color:#9ca3af}.form-input::placeholder{color:#9ca3af}.form-select{width:100%;padding:12px 40px 12px 16px;border:1px solid #D1D5DB;border-radius:8px;font-size:14px;background:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:all .2s ease;cursor:pointer}.form-select:hover{border-color:var(--blue-300)}.form-select:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 2px #2196f333}.form-checkbox,.form-radio{width:18px;height:18px;margin-right:12px;accent-color:var(--blue-500);cursor:pointer}.form-checkbox:checked,.form-radio:checked{background-color:var(--blue-500);border-color:var(--blue-500)}.form-label{display:flex;align-items:center;cursor:pointer;padding:8px 0;transition:color .2s ease}.form-label:hover{color:var(--blue-600)}.filter-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #F3F4F6}.filter-section:last-child{border-bottom:none;margin-bottom:0}.filter-title{font-weight:600;color:#374151;margin-bottom:12px;font-size:14px;text-transform:uppercase;letter-spacing:.025em}.filters-panel-mobile::-webkit-scrollbar{width:6px}.filters-panel-mobile::-webkit-scrollbar-track{background:#f3f4f6}.filters-panel-mobile::-webkit-scrollbar-thumb{background:var(--blue-300);border-radius:3px}.filters-panel-mobile::-webkit-scrollbar-thumb:hover{background:var(--blue-400)}@media (max-width: 1023px){.filters-panel-mobile{max-width:100%;width:90%}}@media (max-width: 480px){.filters-panel-mobile{max-width:100%;width:100%}.mobile-filters-btn{padding:14px 16px;font-size:14px}.form-input,.form-select{padding:14px 16px;font-size:16px}}@media (min-width: 1024px){.filters-panel-mobile{position:relative!important;transform:translate(0)!important;width:auto!important;height:auto!important;max-width:none!important;box-shadow:0 4px 6px -1px #0000001a!important;overflow-y:visible!important;border-radius:8px}.filters-overlay,.mobile-filters-btn{display:none!important}}.filter-enter{opacity:0;transform:translateY(10px)}.filter-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}.filter-exit{opacity:1;transform:translateY(0)}.filter-exit-active{opacity:0;transform:translateY(-10px);transition:opacity .3s ease,transform .3s ease}.btn-loading{position:relative;color:transparent!important}.btn-loading:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin-top:-8px;margin-left:-8px;border:2px solid currentColor;border-radius:50%;border-top-color:transparent;animation:btn-spin .8s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}
