
/* ── Reset & Base ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --accent:#5B3BF5;
  --accent2:#FF2D78;
  --accent-light:#ede9fe;
  --bg:#F4F2EF;
  --surface:#fff;
  --surface2:#F8F7F4;
  --border:#E5E2DC;
  --text:#1A1714;
  --muted:#7A7672;
  --gold:#F59E0B;
  --card-radius:20px;
  --radius:12px;
  --shadow:0 4px 14px rgba(0,0,0,.05);
  --shadow-hover:0 20px 35px -12px rgba(0,0,0,.15);
}
html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);
  min-height:100vh;overflow-x:hidden;
  background-image:url('https://images.unsplash.com/photo-1564013799919-ab600027ffc6?w=1600&q=80');
  background-size:cover;background-position:center;background-attachment:fixed;
  background-blend-mode:overlay;background-color:rgba(244,242,239,0.92);
}
body.dark{background-color:rgba(17,17,16,0.92);}

/* loader keep */
#page-loader{position:fixed;inset:0;background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s .2s}
#page-loader.hidden{opacity:0;pointer-events:none}
.loader{position:relative;width:120px;height:90px;margin:0 auto}
.loader:before{content:"";position:absolute;bottom:30px;left:50px;height:30px;width:30px;border-radius:50%;background:#2a9d8f;animation:loading-bounce .5s ease-in-out infinite alternate}
.loader:after{content:"";position:absolute;right:0;top:0;height:7px;width:45px;border-radius:4px;box-shadow:0 5px 0 #e5e2dc,-35px 50px 0 #e5e2dc,-70px 95px 0 #e5e2dc;animation:loading-step 1s ease-in-out infinite}
@keyframes loading-bounce{0%{transform:scale(1,.7)}40%{transform:scale(.8,1.2)}60%{transform:scale(1,1)}100%{bottom:140px}}
@keyframes loading-step{0%{box-shadow:0 10px 0 rgba(0,0,0,0),0 10px 0 #e5e2dc,-35px 50px 0 #e5e2dc,-70px 90px 0 #e5e2dc}100%{box-shadow:0 10px 0 #e5e2dc,-35px 50px 0 #e5e2dc,-70px 90px 0 #e5e2dc,-70px 90px 0 rgba(0,0,0,0)}}
.loader-label{margin-top:24px;font-family:'Syne',sans-serif;font-size:13px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}

/* ── Nav Loader ── */
.nav-loader{
  position:fixed;top:0;left:0;right:0;height:3px;z-index:9999;
  background:linear-gradient(90deg,var(--accent2),var(--accent),var(--accent2));
  background-size:200% 100%;
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s ease;
}
.nav-loader.active{transform:scaleX(1);animation:loaderSweep 1s ease-in-out infinite}
@keyframes loaderSweep{0%{background-position:0% 0}100%{background-position:200% 0}}

/* Navbar */
nav{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;padding:0 32px}
.nav-inner{max-width:1280px;margin:0 auto;height:70px;display:flex;align-items:center;gap:20px}
.logo{
  font-family:'Syne',sans-serif;font-weight:800;font-size:20px;
  color:var(--text);display:flex;align-items:center;gap:8px;text-decoration:none;
  cursor:pointer;
}
.logo-house{flex-shrink:0;animation:houseBounce 1.5s ease-in-out infinite}
.logo-house .house-door{
  animation:doorShut 1.5s ease-in-out infinite;
  transform-origin:center;
}
@keyframes houseBounce{
  0%,100%{transform:translateY(0)}
  10%{transform:translateY(-6px)}
  20%{transform:translateY(0)}
  30%{transform:translateY(-3px)}
  40%,100%{transform:translateY(0)}
}
@keyframes doorShut{
  0%,40%{transform:scaleX(1)}
  45%{transform:scaleX(0.1)}
  50%{transform:scaleX(1)}
  55%{transform:scaleX(0.3)}
  60%,100%{transform:scaleX(1)}
}
.search-wrap{flex:1;max-width:360px;position:relative}
.search-wrap input{width:100%;padding:10px 16px 10px 40px;border:1.5px solid var(--border);border-radius:40px;font-size:14px;background:var(--surface2);transition:all .2s}
.search-wrap input:focus{border-color:var(--accent);outline:none}
.search-wrap i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:auto;position:relative}
.nav-links a{
  padding:7px 16px;font-size:14px;color:var(--muted);text-decoration:none;
  border-radius:40px;cursor:pointer;transition:all .2s;font-weight:500;
  position:relative;z-index:1;
}
.nav-links a:hover{background:var(--surface2);color:var(--text)}
.nav-links a.active{color:var(--accent);font-weight:600}
.nav-indicator{
  position:absolute;height:32px;border-radius:40px;
  background:rgba(91,59,245,0.1);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(91,59,245,0.12);
  transition:left 0.3s cubic-bezier(.25,.46,.45,.94),
              width 0.3s cubic-bezier(.25,.46,.45,.94);
  pointer-events:none;z-index:0;opacity:0;
}
.nav-links a.active ~ .nav-indicator,.nav-indicator[style*="left"]{opacity:1}
.currency-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid var(--border);border-radius:40px;background:var(--surface);font-size:13px;cursor:pointer;color:var(--text);transition:.2s}
.currency-btn:hover{border-color:var(--accent)}
.login-btn{background:var(--text);color:#fff;border:none;border-radius:40px;padding:9px 24px;font-weight:500;cursor:pointer;transition:.2s}
.login-btn:hover{background:#333}

/* HERO SECTION (replaces theme-row) */
.hero-section{background:linear-gradient(135deg, #0b1a2e, #0c2b3b);border-radius:28px;margin-bottom:40px;overflow:hidden;position:relative;color:white}
.hero-slider{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;border-radius:28px;scrollbar-width:none}
.hero-slider::-webkit-scrollbar{display:none}
.slide-item{min-width:100%;scroll-snap-align:start;position:relative;height:380px;background-size:cover;background-position:center;display:flex;align-items:center;padding:0 48px}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,0.7) 0%,rgba(0,0,0,0.2) 100%)}
.slide-content{position:relative;z-index:2;max-width:550px}
.slide-content h1{font-family:'Syne',sans-serif;font-size:3rem;margin-bottom:16px;font-weight:800}
.slide-content p{font-size:1.05rem;margin-bottom:24px;opacity:0.9}
.hero-dots{position:absolute;bottom:20px;left:0;right:0;display:flex;justify-content:center;gap:12px;z-index:3}
.dot{width:10px;height:10px;background:white;border-radius:50%;opacity:0.5;cursor:pointer}
.dot.active{opacity:1;width:28px;border-radius:20px}
.nav-hero-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.5);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:4;color:white;font-size:1.2rem;transition:all .2s}
.nav-hero-btn:hover{background:var(--accent);color:white}
.prev-btn{left:20px}
.next-btn{right:20px}

/* Sub Nav — iOS 26 Glassmorphism */
.subnav{
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  margin:-16px 32px 0;
  border-radius:16px;
  box-shadow:0 4px 24px rgba(0,0,0,.05);
  padding:0 16px;
  position:relative;
  z-index:10;
  border:1px solid rgba(255,255,255,0.5);
}
.subnav-inner{
  max-width:1248px;margin:0 auto;
  display:flex;align-items:center;gap:2px;
  overflow-x:auto;position:relative;padding:6px 0;
}
.subnav-inner::-webkit-scrollbar{display:none}
.subnav-indicator{
  position:absolute;height:36px;
  border-radius:10px;
  background:rgba(91,59,245,0.1);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(91,59,245,0.12);
  transition:left 0.35s cubic-bezier(.25,.46,.45,.94),
              width 0.35s cubic-bezier(.25,.46,.45,.94);
  pointer-events:none;z-index:0;
}
.cat-btn{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:7px;
  padding:12px 18px;font-size:13.5px;
  color:var(--muted);cursor:pointer;white-space:nowrap;
  background:none;border:none;
  font-family:'DM Sans',sans-serif;transition:color .2s;
  -webkit-tap-highlight-color:transparent;
}
.cat-btn i{font-size:15px}
.cat-btn:hover{color:var(--text)}
.cat-btn.active{color:var(--accent);font-weight:600}
.cat-all{background:none!important;color:var(--muted)!important;border-radius:0!important;margin:0!important;border:none!important;padding:12px 18px!important}
.cat-all.active{color:var(--accent)!important;font-weight:600!important}
.loc-pill{
  margin-left:auto;display:flex;align-items:center;gap:8px;
  border:1.5px solid var(--border);border-radius:40px;
  padding:8px 18px;font-size:13px;cursor:pointer;
  background:rgba(255,255,255,0.6);backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  transition:.2s;position:relative;z-index:1;
}
.loc-pill:hover{border-color:var(--accent)}
.pin{color:var(--accent2)}

body.dark .subnav{background:rgba(28,27,25,0.72);border-color:rgba(255,255,255,0.06)}
body.dark .subnav-indicator{background:rgba(91,59,245,0.18);border-color:rgba(91,59,245,0.2)}
body.dark .loc-pill{background:rgba(28,27,25,0.6)}

/* Content */
.page-wrap{max-width:1280px;margin:0 auto;padding:24px 32px}
.list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap}
.list-heading{font-family:'Syne',sans-serif;font-size:28px;font-weight:800}
.list-sub{font-size:14px;color:var(--muted);margin-top:6px}
.list-actions{display:flex;gap:12px}
.view-btn{width:40px;height:40px;border:1.5px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--surface);transition:.2s}
.view-btn.active,.view-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}

/* ── Filter Button (iOS 26 Glassmorphism) ── */
.filter-btn{
  display:flex;align-items:center;gap:8px;
  padding:10px 20px;
  border:1px solid rgba(255,255,255,0.3);
  border-radius:40px;
  background:rgba(255,255,255,0.65);
  backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);
  font-size:13px;font-weight:600;color:var(--text);
  cursor:pointer;transition:all .2s;
  font-family:'DM Sans',sans-serif;
  box-shadow:0 2px 12px rgba(0,0,0,0.04);
}
.filter-btn:hover{background:rgba(255,255,255,0.85);border-color:var(--accent);box-shadow:0 4px 16px rgba(91,59,245,0.12);}
.filter-btn i{font-size:14px;color:var(--accent)}

/* ── Heart Pop (TikTok-style) ── */
.heart-pop{
  position:fixed;pointer-events:none;z-index:9999;
  font-size:0;color:var(--accent2);
  animation:heartBurst .8s ease-out forwards;
}
@keyframes heartBurst{
  0%{font-size:0;opacity:1;transform:translateY(0) scale(0)}
  30%{font-size:72px;opacity:1;transform:translateY(-20px) scale(1.2)}
  60%{font-size:64px;opacity:.9;transform:translateY(-40px) scale(1)}
  100%{font-size:48px;opacity:0;transform:translateY(-80px) scale(.6)}
}
.heart-pop-ripple{
  position:fixed;pointer-events:none;z-index:9998;
  width:0;height:0;border-radius:50%;
  background:rgba(255,45,120,0.15);
  animation:rippleOut .6s ease-out forwards;
}
@keyframes rippleOut{
  0%{width:0;height:0;opacity:1}
  100%{width:200px;height:200px;opacity:0}
}

/* ── Recent View Section ── */
.recent-section{margin-bottom:28px;padding:16px 20px;background:var(--surface);border-radius:16px;border:1px solid var(--border)}
.recent-header{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.recent-track{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}
.recent-track::-webkit-scrollbar{height:4px}
.recent-track::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}
.recent-item{
  flex-shrink:0;width:160px;border-radius:12px;overflow:hidden;
  border:1px solid var(--border);background:var(--surface2);cursor:pointer;
  transition:.2s;
}
.recent-item:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.recent-item-img{height:90px;background-size:cover;background-position:center}
.recent-item-body{padding:8px 10px}
.recent-item-body .recent-title{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recent-item-body .recent-price{font-size:11px;color:var(--accent);font-weight:700;margin-top:2px}

/* Property Grid */
.prop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px}
.prop-grid.list-view{grid-template-columns:1fr}
.prop-card{background:var(--surface);border-radius:var(--card-radius);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:all .25s ease;animation:fadeUp .5s both}
.prop-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.card-img{height:220px;background-size:cover;background-position:center;position:relative}
.card-tag{
  position:absolute;top:14px;left:14px;
  padding:5px 12px;border-radius:20px;
  font-size:10px;font-weight:700;letter-spacing:.08em;
  background:rgba(255,255,255,0.9);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  color:var(--accent);border:1px solid rgba(91,59,245,0.15);
}
.card-tag.rent{color:var(--accent2);border-color:rgba(255,45,120,0.2)}
.wishlist-btn{position:absolute;top:14px;right:14px;width:36px;height:36px;background:rgba(255,255,255,.95);border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;box-shadow:0 2px 12px rgba(0,0,0,0.1);transition:.2s}
.wishlist-btn.liked i{color:var(--accent2)}
.wishlist-btn i{font-size:16px;color:#aaa}
.card-body{padding:18px}
.card-badge{font-size:10px;font-weight:700;color:var(--accent);letter-spacing:.1em;margin-bottom:8px}
.card-title{font-family:'Syne',sans-serif;font-weight:700;font-size:1.1rem;margin-bottom:10px}
.card-meta{display:flex;gap:18px;font-size:13px;color:var(--muted);margin-bottom:14px}
.card-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:14px;margin-top:4px}
.price{font-weight:800;font-family:'Syne';font-size:1.2rem}
.stars{display:flex;gap:3px;align-items:center;font-size:12px}
.star-on{color:var(--gold)}
.book-btn{
  width:100%;margin-top:12px;padding:10px;
  border:1.5px solid var(--accent);border-radius:12px;
  background:rgba(91,59,245,0.06);color:var(--accent);
  font-size:13px;font-weight:600;cursor:pointer;
  transition:.2s;font-family:'DM Sans',sans-serif;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.book-btn:hover{background:var(--accent);color:#fff}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;visibility:hidden;opacity:0;transition:all .2s}
.modal-overlay.active{visibility:visible;opacity:1}
.modal-container{
  background:var(--surface);max-width:720px;width:92%;
  border-radius:28px;padding:0;overflow:hidden;
  box-shadow:0 30px 60px rgba(0,0,0,0.3);
  transform:scale(0.95);transition:transform .2s;
  position:relative;
}
.modal-overlay.active .modal-container{transform:scale(1)}
.modal-layout{display:flex;min-height:420px}
.modal-left{flex:1;padding:28px}
.modal-img{height:180px;background-size:cover;background-position:center;border-radius:20px;margin-bottom:18px}
.modal-badge{
  display:inline-block;padding:4px 14px;border-radius:20px;
  font-size:11px;font-weight:700;letter-spacing:.08em;
  background:rgba(91,59,245,0.1);color:var(--accent);margin-bottom:10px;
}
.modal-badge.rent{background:rgba(255,45,120,0.1);color:var(--accent2)}
.modal-detail h3{font-family:'Syne';font-size:1.4rem;margin-bottom:10px}
.modal-meta{display:flex;gap:16px;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-size:13px;color:var(--muted);margin-bottom:12px}
.modal-meta span{display:flex;align-items:center;gap:6px}
.modal-detail p{font-size:13.5px;color:var(--muted);line-height:1.6;margin-bottom:12px}
.modal-footer-info{display:flex;gap:20px;font-size:13px;color:var(--muted)}
.modal-right{
  width:260px;padding:28px 24px;
  background:var(--surface2);display:flex;flex-direction:column;
  border-left:1px solid var(--border);
}
.modal-agent{margin-bottom:20px}
.modal-agent h4,.modal-checkout h4{font-family:'Syne';font-size:13px;font-weight:700;margin-bottom:12px;color:var(--text)}
.agent-card{display:flex;gap:14px}
.agent-avatar{
  width:48px;height:48px;border-radius:50%;
  background:rgba(91,59,245,0.1);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.agent-info{display:flex;flex-direction:column;gap:3px;font-size:12.5px;color:var(--muted)}
.agent-info strong{font-size:14px;color:var(--text)}
.agent-contact{display:flex;align-items:center;gap:5px}
.agent-contact i{font-size:11px;width:14px;text-align:center}
.modal-checkout{display:flex;flex-direction:column;gap:8px;margin-bottom:auto}
.checkout-opt{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:12px 14px;border:1.5px solid var(--border);
  border-radius:12px;background:var(--surface);
  font-size:13px;font-weight:500;cursor:pointer;
  transition:.2s;font-family:'DM Sans',sans-serif;color:var(--text);
}
.checkout-opt:hover{border-color:var(--accent);background:rgba(91,59,245,0.04);color:var(--accent)}
.checkout-opt i{font-size:16px;width:20px;text-align:center;color:var(--accent)}
.hire-btn{
  background:var(--accent);color:white;padding:13px;border-radius:14px;
  border:none;font-weight:600;font-size:14px;width:100%;
  margin-top:16px;cursor:pointer;transition:.2s;
  font-family:'DM Sans',sans-serif;display:flex;align-items:center;justify-content:center;gap:8px;
}
.hire-btn:hover{background:#4730d4}
.close-modal{position:absolute;top:16px;right:16px;background:var(--surface);border-radius:30px;width:34px;height:34px;border:none;cursor:pointer;font-size:16px;z-index:10;box-shadow:0 2px 12px rgba(0,0,0,0.08)}

/* ── iOS 26 Dialog (Action Sheet) ── */
.ios-dialog{position:fixed;inset:0;z-index:2000;display:flex;align-items:flex-end;justify-content:center;visibility:hidden;opacity:0;transition:opacity .3s}
.ios-dialog.active{visibility:visible;opacity:1}
.ios-dialog-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.35);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.ios-dialog-sheet{
  position:relative;width:100%;max-width:400px;margin:0 auto;
  background:rgba(255,255,255,0.88);backdrop-filter:blur(30px) saturate(1.4);
  -webkit-backdrop-filter:blur(30px) saturate(1.4);
  border-radius:24px 24px 0 0;padding:12px 24px 36px;
  transform:translateY(100%);transition:transform .45s cubic-bezier(.32,.72,0,1);
  box-shadow:0 -8px 40px rgba(0,0,0,.08);
}
.ios-dialog.active .ios-dialog-sheet{transform:translateY(0)}
.ios-dialog-handle{width:40px;height:5px;background:rgba(0,0,0,0.12);border-radius:10px;margin:0 auto 20px}
.ios-dialog-icon{text-align:center;font-size:36px;margin-bottom:8px;line-height:1}
.ios-dialog-title{font-family:'Syne',sans-serif;font-size:22px;font-weight:700;text-align:center;margin-bottom:8px}
.ios-dialog-msg{font-size:14.5px;color:var(--muted);text-align:center;margin-bottom:20px;line-height:1.5}
.ios-dialog-field{margin-bottom:16px}
.ios-dialog-input{
  width:100%;padding:14px 16px;border:1.5px solid var(--border);
  border-radius:14px;font-size:16px;background:rgba(255,255,255,0.5);
  backdrop-filter:blur(4px);transition:.2s;font-family:'DM Sans',sans-serif;
  box-sizing:border-box;
}
.ios-dialog-input:focus{border-color:var(--accent);outline:none}
.ios-dialog-actions{display:flex;flex-direction:column;gap:8px}
.ios-dialog-btn{
  width:100%;padding:15px;border-radius:14px;border:none;
  font-size:16px;font-weight:600;cursor:pointer;transition:.15s;
  font-family:'DM Sans',sans-serif;text-align:center;
}
.ios-dialog-btn.primary{background:var(--accent);color:#fff}
.ios-dialog-btn.primary:hover{background:#4730d4}
.ios-dialog-btn.secondary{background:var(--surface2);color:var(--text)}
.ios-dialog-btn.secondary:hover{background:var(--border)}
.ios-dialog-btn.danger{background:var(--accent2);color:#fff}
.ios-dialog-btn.danger:hover{background:#d82362}
.ios-dialog-btn.option{
  background:rgba(91,59,245,0.08);color:var(--accent);
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:16px;
}
.ios-dialog-btn.option:hover{background:rgba(91,59,245,0.15)}
.ios-dialog-btn.option i{font-size:18px}

body.dark .ios-dialog-sheet{background:rgba(28,27,25,0.9)}
body.dark .ios-dialog-handle{background:rgba(255,255,255,0.12)}
body.dark .ios-dialog-input{background:rgba(255,255,255,0.06);border-color:var(--border);color:var(--text)}
body.dark .ios-dialog-btn.secondary{background:var(--surface2);color:var(--text)}

/* ── Location Dropdown ── */
.loc-dropdown{
  min-width:190px;
  background:rgba(255,255,255,0.88);backdrop-filter:blur(30px) saturate(1.4);
  -webkit-backdrop-filter:blur(30px) saturate(1.4);
  border-radius:14px;border:1px solid rgba(255,255,255,0.4);
  box-shadow:0 12px 48px rgba(0,0,0,.12);
  padding:6px;z-index:300;display:none;overflow:hidden;
  position:fixed;
}
.loc-dropdown.active{display:block;animation:locFadeIn .2s ease}
@keyframes locFadeIn{from{opacity:0;transform:translateY(-6px) scale(0.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.loc-opt{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:11px 14px;border:none;background:none;
  font-size:13.5px;color:var(--text);cursor:pointer;
  border-radius:10px;transition:.15s;font-family:'DM Sans',sans-serif;
  white-space:nowrap;
}
.loc-opt:hover{background:rgba(91,59,245,0.08);color:var(--accent)}
.loc-opt.active{background:rgba(91,59,245,0.1);color:var(--accent);font-weight:600}
.loc-opt i{width:18px;text-align:center;font-size:14px}

body.dark .loc-dropdown{background:rgba(28,27,25,0.9);border-color:rgba(255,255,255,0.06)}

/* ── Currency Dropdown ── */
.cur-dropdown{
  min-width:140px;
  background:rgba(255,255,255,0.88);backdrop-filter:blur(30px) saturate(1.4);
  -webkit-backdrop-filter:blur(30px) saturate(1.4);
  border-radius:14px;border:1px solid rgba(255,255,255,0.4);
  box-shadow:0 12px 48px rgba(0,0,0,.12);
  padding:6px;z-index:300;display:none;overflow:hidden;
  position:fixed;
}
.cur-dropdown.active{display:block;animation:locFadeIn .2s ease}
.cur-opt{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:11px 14px;border:none;background:none;
  font-size:13.5px;color:var(--text);cursor:pointer;
  border-radius:10px;transition:.15s;font-family:'DM Sans',sans-serif;
  white-space:nowrap;
}
.cur-opt:hover{background:rgba(91,59,245,0.08);color:var(--accent)}
.cur-opt.active{background:rgba(91,59,245,0.1);color:var(--accent);font-weight:600}
.cur-opt i{width:18px;text-align:center;font-size:14px}

body.dark .cur-dropdown{background:rgba(28,27,25,0.9);border-color:rgba(255,255,255,0.06)}

/* ── Mobile Search (hidden on desktop) ── */
.mobile-search-btn{display:none}
.mobile-search-panel{display:none}

/* Footer */
.footer{background:var(--surface);border-top:1px solid var(--border);margin-top:60px;padding:48px 32px 32px}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px}
.footer-brand p{color:var(--muted);margin-top:12px}
.footer-links h4{margin-bottom:16px;font-family:'Syne';font-weight:700}
.footer-links a{display:block;color:var(--muted);text-decoration:none;margin-bottom:10px;font-size:14px}
.footer-links a:hover{color:var(--accent)}
.copyright{text-align:center;padding-top:40px;color:var(--muted);font-size:13px}

/* Dark mode */
body.dark{--bg:#111110;--surface:#1C1B19;--surface2:#232220;--border:#2E2D2A;--text:#F0EDE8;--muted:#9E9A95;}
body.dark .filter-btn{background:rgba(28,27,25,0.7);border-color:rgba(255,255,255,0.08)}
body.dark .filter-btn:hover{background:rgba(28,27,25,0.85);border-color:rgba(91,59,245,0.4)}

/* ── Mobile: 400px–800px (iOS 26 Toolbar Nav) ── */
@media(max-width:800px){
  /* Nav → iOS 26 Toolbar */
  nav{
    padding:0 12px;
    background:rgba(255,255,255,0.78);
    backdrop-filter:blur(24px) saturate(1.4);
    -webkit-backdrop-filter:blur(24px) saturate(1.4);
    border-bottom:none;box-shadow:0 1px 0 rgba(0,0,0,0.06);
  }
  body.dark nav{background:rgba(28,27,25,0.82)}
  .nav-inner{height:56px;gap:6px}
  .logo{font-size:17px;gap:5px}
  .logo svg{width:22px;height:22px}

  .search-wrap{flex:none;max-width:none}
  .search-wrap input{display:none}
  .search-wrap .fa-magnifying-glass{display:none}
  .mobile-search-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:var(--surface2);color:var(--muted);cursor:pointer;font-size:15px;transition:.2s;flex-shrink:0}
  .mobile-search-btn:hover{background:var(--border);color:var(--text)}

  .nav-links{gap:0}
  .nav-links a{padding:6px 12px;font-size:13px}
  .nav-links a[data-nav]{padding:6px 10px}
  #contactNavBtn{display:none}
  .nav-indicator{height:28px}

  .currency-btn{padding:6px 10px;font-size:12px;gap:4px}
  .currency-btn .fa-chevron-down{display:none}

  .login-btn{padding:8px 14px;font-size:12px}

  /* Mobile Search Panel */
  .mobile-search-panel{
    display:none;position:fixed;top:56px;left:0;right:0;z-index:199;
    background:rgba(255,255,255,0.95);
    backdrop-filter:blur(24px) saturate(1.4);
    -webkit-backdrop-filter:blur(24px) saturate(1.4);
    padding:12px 16px;border-bottom:1px solid var(--border);
    animation:slideDown .25s ease;
  }
  body.dark .mobile-search-panel{background:rgba(28,27,25,0.95)}
  .mobile-search-panel.active{display:block}
  @keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
  .mobile-search-inner{
    display:flex;align-items:center;gap:10px;
    background:var(--surface2);border-radius:12px;
    padding:0 14px;border:1.5px solid var(--border);
  }
  .mobile-search-inner:focus-within{border-color:var(--accent)}
  .mobile-search-inner input{
    flex:1;padding:12px 0;border:none;background:none;
    font-size:16px;font-family:'DM Sans',sans-serif;
    outline:none;color:var(--text);
  }
  .mobile-search-inner i{color:var(--muted);font-size:16px}
  .mobile-search-close{
    background:none;border:none;color:var(--muted);
    cursor:pointer;font-size:18px;padding:4px;
  }

  /* Hero */
  .hero-section{margin:0 12px 20px!important;border-radius:20px}
  .slide-item{height:260px;padding:0 20px}
  .slide-content h1{font-size:1.6rem!important}
  .slide-content p{font-size:.9rem!important}
  .hero-dots{bottom:14px}
  .nav-hero-btn{width:32px;height:32px;font-size:.9rem}
  .prev-btn{left:10px}
  .next-btn{right:10px}

  /* Subnav */
  .subnav{margin:-10px 12px 0;padding:0 8px;border-radius:12px}
  .subnav-inner{padding:4px 0;gap:0}
  .cat-btn{padding:10px 12px;font-size:12px}
  .cat-btn i{font-size:13px}
  .loc-pill{padding:6px 12px;font-size:12px;gap:4px}
  .loc-pill span{font-size:11px}
  .loc-dropdown{min-width:160px!important;font-size:12px}

  /* Content */
  .page-wrap{padding:16px 12px}
  .list-heading{font-size:22px}
  .list-sub{font-size:13px}
  .list-header{margin-bottom:20px;gap:12px}
  .list-actions{gap:8px}
  .filter-btn{padding:8px 14px;font-size:12px;border-radius:30px}

  /* Recent */
  .recent-item{width:120px}
  .recent-item-img{height:72px}
  .recent-item-body{padding:6px 8px}
  .recent-item-body .recent-title{font-size:11px}
  .recent-item-body .recent-price{font-size:10px}

  /* Grid */
  .prop-grid{grid-template-columns:1fr;gap:16px}

  /* Modal */
  .modal-container{max-width:480px;border-radius:20px}
  .modal-layout{flex-direction:column}
  .modal-right{width:100%;border-left:none;border-top:1px solid var(--border)}
  .modal-img{height:150px}
  .modal-detail h3{font-size:1.2rem}

  /* Footer */
  .footer{padding:32px 16px 24px}
  .footer-inner{gap:24px;grid-template-columns:1fr}

  /* Dropdowns */
  .cur-dropdown{min-width:120px!important}
}

@media(max-width:400px){
  nav{padding:0 8px}
  .nav-inner{gap:4px}
  .logo{font-size:15px}
  .logo svg{width:18px;height:18px}
  .nav-links a[data-nav]{padding:5px 8px;font-size:11px}
  .currency-btn{padding:4px 8px;font-size:11px}
  .login-btn{padding:6px 10px;font-size:11px}
  .slide-item{height:220px;padding:0 16px}
  .slide-content h1{font-size:1.3rem!important}
  .slide-content p{font-size:.8rem!important}
  .cat-btn{padding:8px 10px;font-size:11px}
  .page-wrap{padding:12px 8px}
  .list-heading{font-size:18px}
  .modal-container{border-radius:16px}
  .mobile-search-panel{top:52px}
}

/* ── iOS 26 Chat Room ── */
.chat-overlay{
  position:fixed;inset:0;z-index:3000;
  display:flex;align-items:flex-end;justify-content:center;
  visibility:hidden;opacity:0;
  transition:opacity .3s;
}
.chat-overlay.active{visibility:visible;opacity:1}
.chat-container{
  width:100%;max-width:500px;height:82vh;max-height:700px;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(30px) saturate(1.4);
  -webkit-backdrop-filter:blur(30px) saturate(1.4);
  border-radius:24px 24px 0 0;
  display:flex;flex-direction:column;
  transform:translateY(100%);
  transition:transform .5s cubic-bezier(.32,.72,0,1);
  overflow:hidden;
}
.chat-overlay.active .chat-container{transform:translateY(0)}

.chat-header{
  display:flex;align-items:center;gap:12px;
  padding:16px 16px 12px;
  border-bottom:1px solid rgba(0,0,0,0.06);
  flex-shrink:0;
}
.chat-back-btn,.chat-header-close{
  width:34px;height:34px;border-radius:50%;
  border:none;background:var(--surface2);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text);font-size:16px;transition:.2s;flex-shrink:0;
}
.chat-back-btn:hover,.chat-header-close:hover{background:var(--border)}
.chat-header-agent{display:flex;align-items:center;gap:10px;flex:1}
.chat-avatar{
  width:38px;height:38px;border-radius:50%;
  background:rgba(91,59,245,0.1);color:var(--accent);
  display:flex;align-items:center;justify-content:center;font-size:17px;
}
.chat-agent-detail{display:flex;flex-direction:column;gap:1px}
.chat-agent-name{font-size:14px;font-weight:600;color:var(--text)}
.chat-agent-status{font-size:11px;color:var(--muted)}

.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;scroll-behavior:smooth}
.chat-messages{display:flex;flex-direction:column;gap:8px;margin-top:auto}
.chat-msg{
  max-width:82%;padding:10px 14px;border-radius:18px;
  font-size:14px;line-height:1.55;word-wrap:break-word;
  animation:chatIn .3s ease;position:relative;
}
@keyframes chatIn{from{opacity:0;transform:translateY(8px) scale(0.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.chat-msg.bot{
  align-self:flex-start;
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(0,0,0,0.04);
  color:var(--text);border-bottom-left-radius:4px;
}
.chat-msg.user{
  align-self:flex-end;
  background:var(--accent);color:#fff;
  border-bottom-right-radius:4px;
}
.chat-msg.agent{
  align-self:flex-start;
  background:rgba(91,59,245,0.08);
  border:1px solid rgba(91,59,245,0.1);
  color:var(--text);border-bottom-left-radius:4px;
}
.chat-msg.system{
  align-self:center;
  background:rgba(0,0,0,0.04);
  color:var(--muted);font-size:11px;
  padding:6px 14px;border-radius:20px;
  max-width:90%;text-align:center;
}
.chat-msg-time{
  font-size:10px;color:inherit;opacity:0.55;
  margin-top:4px;display:block;
}
.chat-msg-text strong{font-weight:600}
.chat-msg.user .chat-msg-text{color:#fff}

.chat-footer{
  padding:10px 16px 20px;
  border-top:1px solid rgba(0,0,0,0.06);
  flex-shrink:0;
}
.chat-input-group{
  display:flex;align-items:center;gap:8px;
  background:var(--surface2);
  border-radius:24px;padding:4px 4px 4px 16px;
  border:1.5px solid var(--border);transition:.2s;
}
.chat-input-group:focus-within{border-color:var(--accent)}
.chat-input-group input{
  flex:1;border:none;background:none;
  font-size:15px;font-family:'DM Sans',sans-serif;
  outline:none;color:var(--text);
}
.chat-send-btn{
  width:38px;height:38px;border-radius:50%;
  border:none;background:var(--accent);color:#fff;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:15px;transition:.2s;flex-shrink:0;
}
.chat-send-btn:hover{background:#4730d4}

.chat-typing{
  align-self:flex-start;
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(0,0,0,0.04);
  border-radius:18px;border-bottom-left-radius:4px;
  padding:12px 18px;display:flex;gap:5px;align-items:center;
}
.chat-typing span{
  width:7px;height:7px;border-radius:50%;
  background:var(--muted);
  animation:typBounce 1.3s ease-in-out infinite;
}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typBounce{
  0%,60%,100%{transform:translateY(0)}
  30%{transform:translateY(-7px)}
}

.chat-quick-replies{
  display:flex;flex-wrap:wrap;gap:6px;
  align-self:flex-start;margin-top:2px;
  animation:chatIn .3s ease;
}
.chat-quick-btn{
  padding:8px 14px;border-radius:20px;
  border:1.5px solid var(--accent);
  background:rgba(91,59,245,0.06);
  color:var(--accent);font-size:12px;font-weight:500;
  cursor:pointer;transition:.15s;
  font-family:'DM Sans',sans-serif;
}
.chat-quick-btn:hover{background:rgba(91,59,245,0.12)}

body.dark .chat-container{background:rgba(28,27,25,0.92)}
body.dark .chat-msg.bot{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.06)}
body.dark .chat-typing{background:rgba(255,255,255,0.06)}
body.dark .chat-msg.system{background:rgba(255,255,255,0.04)}

/* ── iOS 26 Sign Up Modal ── */
.signup-overlay{
  position:fixed;inset:0;z-index:4000;
  display:flex;align-items:flex-end;justify-content:center;
  visibility:hidden;opacity:0;transition:opacity .3s;
}
.signup-overlay.active{visibility:visible;opacity:1}
.signup-container{
  width:100%;max-width:480px;max-height:90vh;overflow-y:auto;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(30px) saturate(1.4);
  -webkit-backdrop-filter:blur(30px) saturate(1.4);
  border-radius:28px 28px 0 0;
  transform:translateY(100%);
  transition:transform .5s cubic-bezier(.32,.72,0,1);
  padding:8px 24px 32px;
}
.signup-overlay.active .signup-container{transform:translateY(0)}
.signup-handle{width:40px;height:5px;background:rgba(0,0,0,0.1);border-radius:10px;margin:0 auto 16px}

.signup-header{text-align:center;margin-bottom:24px}
.signup-header-icon{
  width:56px;height:56px;border-radius:50%;
  background:rgba(91,59,245,0.1);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin:0 auto 12px;
}
.signup-header h3{font-family:'Syne',sans-serif;font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}
.signup-header p{font-size:13.5px;color:var(--muted);line-height:1.4}

.signup-body{display:flex;flex-direction:column;gap:14px}
.signup-field{}
.signup-field label{display:block;font-size:12px;font-weight:600;color:var(--text);margin-bottom:5px}
.signup-input{
  width:100%;padding:13px 14px;
  border:1.5px solid var(--border);border-radius:12px;
  font-size:15px;font-family:'DM Sans',sans-serif;
  background:rgba(255,255,255,0.5);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  transition:.2s;color:var(--text);box-sizing:border-box;
}
.signup-input:focus{border-color:var(--accent);outline:none}
.signup-input::placeholder{color:var(--muted)}
.signup-error{
  font-size:12.5px;color:var(--accent2);text-align:center;
  min-height:0;padding:0;transition:.2s;display:none;
}
.signup-error.show{display:block;padding:4px 0}
.signup-submit{
  width:100%;padding:15px;border:none;border-radius:14px;
  background:var(--accent);color:#fff;font-size:16px;font-weight:600;
  cursor:pointer;font-family:'DM Sans',sans-serif;
  transition:.2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px;
}
.signup-submit:hover{background:#4730d4}

.signup-footer{text-align:center;margin-top:16px;display:flex;flex-direction:column;gap:10px}
.signup-footer span{font-size:12.5px;color:var(--muted)}
.signup-link{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-size:12.5px;padding:0;font-family:'DM Sans',sans-serif}
.signup-link:hover{text-decoration:underline}
.signup-cancel{
  background:none;border:1.5px solid var(--border);border-radius:12px;
  padding:11px;font-size:14px;color:var(--text);cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:.2s;width:100%;
}
.signup-cancel:hover{background:var(--surface2)}

body.dark .signup-container{background:rgba(28,27,25,0.92)}
body.dark .signup-handle{background:rgba(255,255,255,0.1)}
body.dark .signup-input{background:rgba(255,255,255,0.06);border-color:var(--border)}
