:root{font-family:Inter,Segoe UI,Arial,sans-serif;color:#111827;line-height:1.5}*{box-sizing:border-box}body{margin:0;background:#f8fafc;color:#111827}.app{min-height:100vh}.navbar-wrap{position:sticky;top:0;z-index:20;background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #e5e7eb}.navbar{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.25rem;padding:.9rem 1.5rem}.navbar-logo{font-size:1.35rem;font-weight:800;color:#111827;text-decoration:none;letter-spacing:.2px}.navbar-links{display:flex;align-items:center;gap:1.15rem}.navbar-links a{color:#374151;text-decoration:none;font-weight:600;font-size:.95rem}.navbar-links a:hover{color:#111827}.navbar-actions{display:flex;align-items:center;gap:.55rem}.btn{border-radius:999px;border:1px solid transparent;padding:.5rem .85rem;font-size:.85rem;font-weight:600;cursor:pointer}.btn-ghost{background:transparent;color:#1f2937}.btn-ghost:hover{background:#f3f4f6}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8}.btn-outline{border-color:#d1d5db;background:#fff;color:#111827}.btn-outline:hover{border-color:#9ca3af}.content{padding:0}.auth-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;background:#11182780;padding:1rem}.auth-modal{width:min(420px,100%);background:#fff;border-radius:14px;padding:1.15rem;box-shadow:0 24px 60px #0f172a40}.auth-modal h2{margin:0;font-size:1.3rem}.auth-modal p{margin:.45rem 0 .85rem;color:#4b5563}.auth-form{display:grid;gap:.85rem}.auth-form label{display:grid;gap:.35rem;font-size:.9rem;font-weight:600;color:#374151}.auth-form input{border:1px solid #d1d5db;border-radius:10px;padding:.7rem .8rem;font:inherit;outline:none}.auth-form input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb24}.auth-modal-actions{display:flex;justify-content:flex-end;gap:.55rem}.home-page{width:100%}.hero-section{position:relative;min-height:540px;display:grid;place-items:center;padding:2rem 1rem;background-image:url(https://images.unsplash.com/photo-1512918728675-ed5a9ecdebfd?auto=format&fit=crop&w=1600&q=80);background-size:cover;background-position:center}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#11182780,#11182747)}.hero-content{position:relative;z-index:1;width:100%;max-width:930px;text-align:center;color:#fff}.hero-content h1{margin:1rem auto 1.3rem;max-width:780px;font-size:clamp(2rem,4.3vw,3.2rem);line-height:1.15;letter-spacing:-.3px}.hero-tabs{display:inline-flex;align-items:center;gap:.4rem;border-radius:999px;background:#ffffff29;padding:.35rem}.hero-tab{border:0;background:transparent;color:#fff;font-weight:600;font-size:.95rem;padding:.5rem 1rem;border-radius:999px;cursor:pointer}.hero-tab-active{background:#fff;color:#111827}.hero-search{margin:0 auto;max-width:760px;display:flex;align-items:center;background:#fff;border-radius:999px;padding:.4rem;box-shadow:0 12px 28px #11182733}.hero-search input{flex:1;border:none;outline:none;font-size:.96rem;padding:.85rem 1rem;color:#111827;border-radius:999px}.hero-search button{border:none;border-radius:999px;background:#ef4444;color:#fff;font-weight:600;font-size:.95rem;padding:.85rem 1.4rem;cursor:pointer}.hero-search button:hover{background:#dc2626}.city-section{max-width:1200px;margin:0 auto;padding:3rem 1.5rem 4rem}.section-header{margin-bottom:1.4rem}.section-header h2{margin:0;font-size:1.7rem;letter-spacing:-.2px}.section-header p{margin:.45rem 0 0;color:#4b5563}.city-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.city-card{display:block;background:#fff;border-radius:14px;overflow:hidden;text-decoration:none;color:#111827;box-shadow:0 8px 24px #0f172a14;transition:transform .2s ease,box-shadow .2s ease}.city-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px #0f172a24}.city-card img{width:100%;height:150px;object-fit:cover}.city-card-name{padding:.9rem .95rem;font-size:1rem;font-weight:700}.city-page{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 3rem}.city-page-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1.2rem}.city-page-header h1{margin:0;font-size:clamp(1.6rem,3.5vw,2.15rem);letter-spacing:-.2px}.city-page-header p{margin:0;color:#4b5563;font-weight:600}.property-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.property-card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 8px 24px #0f172a14;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;outline:none}.property-card:hover,.property-card:focus-visible{transform:translateY(-3px);box-shadow:0 14px 30px #0f172a24}.property-card-image-wrap{position:relative}.property-card-image{width:100%;height:190px;object-fit:cover;display:block}.image-nav{position:absolute;top:50%;transform:translateY(-50%);width:2rem;height:2rem;border:none;border-radius:999px;background:#1118279e;color:#fff;font-size:1.2rem;line-height:1;cursor:pointer}.image-nav-left{left:.6rem}.image-nav-right{right:.6rem}.image-nav:hover{background:#111827cc}.image-indicator{position:absolute;right:.6rem;bottom:.6rem;border-radius:999px;background:#111827a6;color:#fff;padding:.18rem .5rem;font-size:.73rem;font-weight:600}.property-card-body{padding:.85rem .95rem 1rem}.property-card-body h3{margin:0;font-size:1.25rem;letter-spacing:-.15px}.property-meta{margin:.25rem 0 0;color:#374151;font-size:.93rem;font-weight:600}.property-address{margin:.35rem 0 0;color:#4b5563;font-size:.92rem}.empty-state{padding:2rem 1rem;background:#fff;border-radius:12px;border:1px solid #e5e7eb;text-align:center}.empty-state h2{margin:0}.empty-state p{margin:.5rem 0 0;color:#4b5563}.property-page{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 3rem}.property-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:1.25rem;align-items:start}.property-main{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 8px 24px #0f172a14}.property-gallery{padding:1rem;border-bottom:1px solid #e5e7eb}.property-hero-image{width:100%;height:min(480px,48vw);min-height:260px;object-fit:cover;border-radius:10px;display:block}.property-thumbnails{margin-top:.7rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(84px,1fr));gap:.55rem}.thumbnail-btn{border:2px solid transparent;background:#fff;border-radius:8px;overflow:hidden;padding:0;cursor:pointer}.thumbnail-btn img{width:100%;height:64px;object-fit:cover;display:block}.thumbnail-btn-active{border-color:#2563eb}.property-info{padding:1rem 1.1rem 1.2rem}.property-detail-address{margin:0;color:#4b5563;font-weight:600}.property-info h1{margin:.4rem 0 0;font-size:clamp(1.7rem,4vw,2.25rem);letter-spacing:-.3px}.property-detail-meta{margin:.5rem 0 0;color:#1f2937;font-weight:700}.property-detail-description{margin:.85rem 0 0;color:#374151;line-height:1.7}.contact-panel{background:#fff;border-radius:14px;box-shadow:0 8px 24px #0f172a14;padding:1rem;position:sticky;top:82px}.contact-panel h2{margin:0 0 .8rem;font-size:1.2rem}.contact-form{display:grid;gap:.75rem}.contact-form label{display:grid;gap:.35rem;font-size:.9rem;color:#374151;font-weight:600}.contact-form input,.contact-form textarea{width:100%;border:1px solid #d1d5db;border-radius:10px;padding:.7rem .8rem;font:inherit;color:#111827;outline:none;background:#fff}.contact-form input:focus,.contact-form textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb24}.contact-form textarea{resize:vertical}.request-btn{border:none;border-radius:10px;background:#2563eb;color:#fff;font-size:.96rem;font-weight:700;padding:.75rem 1rem;cursor:pointer}.request-btn:hover{background:#1d4ed8}@media (max-width: 980px){.navbar{flex-wrap:wrap;justify-content:center;padding:.8rem 1rem}.navbar-links,.navbar-actions{justify-content:center}.property-layout{grid-template-columns:1fr}.contact-panel{position:static}}@media (max-width: 720px){.hero-section{min-height:470px;padding:1.25rem .8rem}.hero-search{flex-direction:column;border-radius:14px;padding:.55rem}.hero-search input,.hero-search button{width:100%;border-radius:10px}.hero-search button{margin-top:.45rem}.city-section{padding:2.4rem 1rem 3.2rem}.city-page{padding:1.5rem 1rem 2.4rem}.city-page-header{flex-direction:column;align-items:flex-start;margin-bottom:1rem}.property-page{padding:1.5rem 1rem 2.4rem}.property-gallery{padding:.75rem}.property-info{padding:.9rem .9rem 1rem}}
