/* PGTribes — Global stylesheet (mobile-first, responsive) */
:root{
  --primary:#d11f1f;--primary-dark:#a31a1a;--secondary:#e23b3b;
  --bg:#f8fafc;--surface:#ffffff;--text:#0f172a;--muted:#64748b;
  --border:#e2e8f0;--good:#16a34a;--bad:#dc2626;--warn:#f59e0b;
  --radius:14px;--shadow:0 4px 20px rgba(15,23,42,.06);
  --r-shadow:0 8px 30px rgba(209,31,31,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;color:var(--text);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.container{max-width:1180px;margin:0 auto;padding:0 16px}
.container.narrow{max-width:680px}
.muted{color:var(--muted)}
.hidden{display:none!important}
.good{color:var(--good)}.bad{color:var(--bad)}

/* TOPBAR */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.72);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid rgba(226,232,240,.6);
  transition:box-shadow .25s ease,background .25s ease,border-color .25s ease;
}
.topbar.is-scrolled{
  background:rgba(255,255,255,.88);
  border-bottom-color:rgba(226,232,240,.9);
  box-shadow:0 6px 24px rgba(15,23,42,.07);
}
.topbar .nav{display:flex;align-items:center;justify-content:space-between;height:68px;gap:16px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;color:var(--primary);transition:transform .2s ease}
.brand:hover{transform:scale(1.03)}
.brand small{font-weight:500;font-size:12px;background:var(--primary);color:#fff;padding:3px 8px;border-radius:6px}
.logo-dot{width:14px;height:14px;background:var(--primary);border-radius:50%;display:inline-block}
.brand-logo{height:40px;width:auto;display:block}

/* Nav links — pill hover + animated underline */
.primary{display:flex;align-items:center;gap:4px}
.primary a{
  position:relative;color:var(--text);font-weight:500;font-size:15px;
  padding:8px 14px;border-radius:10px;line-height:1;
  display:inline-flex;align-items:center;gap:6px;
  transition:color .18s ease,background .18s ease;
}
.primary a:hover{color:var(--primary);background:rgba(209,31,31,.06);text-decoration:none}
.primary a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;
  background:var(--primary);border-radius:2px;
  transform:scaleX(0);transform-origin:center;transition:transform .2s ease;
}
.primary a:hover::after{transform:scaleX(1)}

.auth-cta{display:flex;align-items:center;gap:10px}
.auth-cta .btn{display:inline-flex;align-items:center;gap:7px}

/* BUTTONS */
.btn{display:inline-block;padding:10px 18px;border-radius:10px;font-weight:600;border:1px solid var(--border);background:#fff;cursor:pointer;transition:all .15s;text-align:center}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow);text-decoration:none}
.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn.primary:hover{background:var(--primary-dark)}
.btn.ghost{background:#fff;color:var(--text)}
.btn.full{display:block;width:100%}
.btn.small{padding:6px 12px;font-size:13px}

/* Header CTA buttons — modern pill style */
.auth-cta .btn{border-radius:12px;padding:9px 16px;font-size:14px;font-weight:600;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease}
.auth-cta .btn.ghost{background:rgba(255,255,255,.6);border-color:var(--border);color:var(--text)}
.auth-cta .btn.ghost:hover{border-color:var(--primary);color:var(--primary);background:#fff;box-shadow:0 4px 14px rgba(15,23,42,.06)}
.auth-cta .btn.primary{
  background:linear-gradient(135deg,var(--secondary),var(--primary));
  border-color:transparent;color:#fff;
  box-shadow:0 6px 16px rgba(209,31,31,.28);
}
.auth-cta .btn.primary:hover{
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  box-shadow:0 10px 24px rgba(209,31,31,.36);transform:translateY(-1px)
}
.auth-cta .btn [data-lucide],.auth-cta .btn svg{width:16px;height:16px}
/* Auth buttons live in the slide-down menu on mobile only (see media query) */
.nav-auth{display:none}

/* HERO */
.hero{padding:80px 0 60px;background:linear-gradient(135deg,#fef5f5 0%,#fdeaea 100%);text-align:center}
.hero h1{font-size:48px;line-height:1.1;margin-bottom:16px}
.hero .grad{background:linear-gradient(90deg,#d11f1f,#e23b3b);-webkit-background-clip:text;color:transparent}
.hero .lead{font-size:18px;color:var(--muted);margin-bottom:32px}
.search-bar{background:#fff;border-radius:16px;padding:8px;display:flex;gap:8px;max-width:760px;margin:0 auto;box-shadow:var(--r-shadow)}
.search-bar input,.search-bar select{flex:1;border:0;padding:12px 14px;font-size:15px;outline:0}
.search-bar .btn{padding:12px 24px}
.trust{margin-top:24px;display:flex;justify-content:center;gap:20px;flex-wrap:wrap;color:var(--muted);font-size:14px}

/* SECTIONS */
.features,.featured,.cities{padding:60px 0}
.features h2,.featured h2,.cities h2,.cta h2{font-size:32px;margin-bottom:32px;text-align:center}
.grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.feat{background:#fff;padding:24px;border-radius:var(--radius);box-shadow:var(--shadow)}
.feat h3{font-size:18px;margin-bottom:8px}

/* PG CARD */
.pg-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.2s;color:var(--text);display:block}
.pg-card:hover{transform:translateY(-4px);box-shadow:var(--r-shadow);text-decoration:none}
.pg-card .cover{height:180px;background:linear-gradient(135deg,#ee8f8f,#e23b3b);background-size:cover;background-position:center;position:relative}
.pg-card .badge{position:absolute;top:12px;left:12px;background:#fff;color:var(--primary);padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700}
.pg-card .meta{padding:16px}
.pg-card h3{font-size:17px;margin-bottom:4px}
.pg-card .loc,.pg-card .rating{font-size:13px;color:var(--muted)}
.pg-card .amen{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.pg-card .amen span{background:#f1f5f9;padding:3px 8px;border-radius:5px;font-size:11px}
.pg-card .price{font-weight:700;color:var(--primary);margin-top:8px;font-size:18px}

/* CITIES */
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.city-pill{background:#fff;padding:16px;border-radius:10px;display:flex;flex-direction:column;align-items:center;color:var(--text);box-shadow:var(--shadow)}
.city-pill small{color:var(--muted);font-size:12px}

/* CTA */
.cta{padding:80px 0;background:linear-gradient(135deg,var(--primary),#e23b3b);color:#fff;text-align:center}
.cta p{margin:12px 0 24px;opacity:.9}
.cta .btn.primary{background:#fff;color:var(--primary)}

/* FOOTER — modern dark with gradient accent, newsletter CTA, trust strip */
.footer{
  position:relative;overflow:hidden;margin-top:80px;
  background:radial-gradient(1200px 600px at -10% -20%, rgba(209,31,31,.28), transparent 60%),
             radial-gradient(900px 500px at 110% -10%, rgba(226,59,59,.18), transparent 55%),
             linear-gradient(180deg, #0b1024 0%, #070a18 100%);
  color:#cbd5e1;font-size:14px;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer::before{
  content:"";position:absolute;inset:0 0 auto 0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(232,90,90,.7), rgba(226,59,59,.6), transparent);
}
.footer-glow{
  position:absolute;inset:auto -10% -40% 50%;transform:translateX(-50%);
  width:120%;height:240px;border-radius:50%;
  background:radial-gradient(closest-side, rgba(232,90,90,.18), transparent 70%);
  filter:blur(40px);pointer-events:none;
}

/* Newsletter CTA strip */
.footer-cta{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;
  padding:36px 24px;margin:36px auto 0;
  background:linear-gradient(135deg, rgba(209,31,31,.55), rgba(30,27,75,.7));
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  box-shadow:0 20px 60px -20px rgba(209,31,31,.45);
  backdrop-filter:blur(6px);
}
.footer-cta-text h3{
  color:#fff;font-size:22px;font-weight:700;margin:0 0 6px;letter-spacing:-.01em;
}
.footer-cta-text p{color:#f3bcbc;margin:0;max-width:48ch}
.footer-cta-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cta-input-wrap{
  position:relative;display:inline-flex;align-items:center;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:12px;padding:0 14px 0 40px;height:48px;min-width:280px;
  transition:border-color .2s, background .2s;
}
.cta-input-wrap:focus-within{border-color:rgba(238,143,143,.6);background:rgba(255,255,255,.1)}
.cta-input-icon{position:absolute;left:14px;color:#ee8f8f}
.footer-cta-form input{
  background:transparent;border:none;outline:none;color:#fff;font-size:14px;width:100%;
}
.footer-cta-form input::placeholder{color:#94a3b8}
.footer-cta-form button{
  display:inline-flex;align-items:center;gap:8px;height:48px;padding:0 20px;
  background:linear-gradient(135deg, #e85a5a, #e23b3b);
  color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer;
  box-shadow:0 8px 24px -8px rgba(226,59,59,.6);
  transition:transform .15s, box-shadow .2s;
}
.footer-cta-form button:hover{transform:translateY(-1px);box-shadow:0 12px 28px -10px rgba(226,59,59,.7)}

/* Main grid */
.footer-main{position:relative;z-index:1;padding:56px 16px 24px}
.footer-grid{
  display:grid;
  grid-template-columns:1.6fr repeat(3, 1fr) 1.2fr;
  gap:40px;margin-bottom:48px;
}
.footer-brand .brand-footer{
  display:inline-flex;align-items:center;margin-bottom:16px;
}
.footer-brand .footer-logo{
  height:42px;width:auto;
  background:#fff;padding:9px 14px;border-radius:12px;
  box-shadow:0 6px 20px rgba(0,0,0,.28);
}
.footer-brand p{color:#94a3b8;line-height:1.6;margin:0 0 20px;max-width:36ch}

.footer-social{display:flex;gap:10px}
.footer-social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:10px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  color:#cbd5e1;transition:all .2s ease;
}
.footer-social a:hover{
  color:#fff;border-color:rgba(238,143,143,.5);
  background:linear-gradient(135deg, rgba(232,90,90,.25), rgba(226,59,59,.2));
  transform:translateY(-2px);
}
.footer-social svg{width:18px;height:18px}

.footer-col h4{
  color:#fff;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  margin:0 0 16px;
}
.footer-col a{
  display:flex;align-items:center;gap:8px;
  color:#94a3b8;padding:6px 0;font-size:14px;text-decoration:none;
  transition:color .15s, transform .15s;
}
.footer-col a:hover{color:#fff;transform:translateX(2px)}
.footer-col a svg{opacity:.6}

.footer-contact .footer-contact-row{
  display:flex;align-items:center;gap:10px;
  color:#cbd5e1;padding:8px 0;font-size:14px;text-decoration:none;
  transition:color .15s;
}
a.footer-contact-row:hover{color:#fff}
.footer-contact-row svg{color:#ee8f8f;flex-shrink:0}

/* Trust strip */
.footer-trust{
  display:flex;flex-wrap:wrap;gap:8px 28px;justify-content:center;
  padding:24px 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.trust-item{
  display:inline-flex;align-items:center;gap:8px;
  color:#cbd5e1;font-size:13px;font-weight:500;
}
.trust-item svg{color:#34d399}

/* Bottom bar */
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
  padding:24px 0 8px;
}
.copy{color:#64748b;font-size:13px;margin:0}
.footer-legal{display:flex;flex-wrap:wrap;gap:6px 20px}
.footer-legal a{color:#94a3b8;font-size:13px;text-decoration:none;transition:color .15s}
.footer-legal a:hover{color:#fff}
.footer-made{color:#64748b;font-size:13px;margin:0;display:inline-flex;align-items:center;gap:6px}
.footer-made .heart{color:#d11f1f;animation:heartbeat 1.6s ease-in-out infinite}
@keyframes heartbeat{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}

/* Responsive */
@media (max-width: 980px){
  .footer-grid{grid-template-columns:repeat(2, 1fr);gap:32px}
  .footer-brand{grid-column:1/-1}
}
@media (max-width: 640px){
  .footer-cta{flex-direction:column;align-items:flex-start;padding:28px 20px;border-radius:16px}
  .footer-cta-form{width:100%}
  .cta-input-wrap{flex:1;min-width:0}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{justify-content:center;text-align:center}
  .footer-bottom > *{width:100%;justify-content:center}
  .footer-legal{justify-content:center}
}

/* FLASH */
.flash{padding:12px 20px;margin:12px 16px;border-radius:8px;font-weight:500}
.flash.success{background:#dcfce7;color:#166534;border:1px solid #86efac}
.flash.error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}

/* FORMS */
.card-form{background:#fff;padding:24px;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px;margin:20px 0}
.card-form label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--text);font-weight:500}
.card-form input,.card-form select,.card-form textarea{padding:11px 14px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-family:inherit}
.card-form input:focus,.card-form select:focus,.card-form textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(209,31,31,.1)}
.grid-2{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.chips{display:flex;flex-wrap:wrap;gap:12px}
.chips label{flex-direction:row!important;align-items:center;gap:6px;font-weight:400;background:#f1f5f9;padding:6px 12px;border-radius:8px}

/* AUTH */
.auth-page{padding:60px 0}
.auth-card{background:#fff;padding:36px;border-radius:var(--radius);box-shadow:var(--r-shadow);max-width:480px;margin:0 auto}
.auth-card h1{margin-bottom:8px}
.auth-card .alt{margin-top:12px;text-align:center;font-size:14px}
.auth-card .small{font-size:12px}

/* SEARCH PAGE */
.search-page{display:grid;grid-template-columns:280px 1fr;gap:24px;padding:24px 16px}
.filters{background:#fff;padding:20px;border-radius:var(--radius);box-shadow:var(--shadow);height:fit-content;position:sticky;top:80px}
.filters h3{margin-bottom:16px}
.filters label{display:block;margin-bottom:12px;font-size:14px}
.filters input,.filters select{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:7px;margin-top:4px}
.amen-filters{display:flex;flex-direction:column;gap:6px;margin:12px 0;font-size:14px}
.results h2{margin-bottom:16px}
.empty{padding:40px;text-align:center;color:var(--muted)}

/* PG DETAIL */
.pg-detail{padding:24px 16px}
.cover-large{height:340px;border-radius:var(--radius);background-size:cover;background-position:center;background-image:linear-gradient(135deg,#ee8f8f,#e23b3b);position:relative;display:flex;align-items:flex-end}
.cover-large .overlay{background:linear-gradient(0deg,rgba(0,0,0,.65),transparent);padding:40px 32px;color:#fff;width:100%;border-radius:0 0 var(--radius) var(--radius)}
.cover-large h1{font-size:36px}
.pg-grid{display:grid;grid-template-columns:1fr 360px;gap:32px;margin-top:24px}
.book-card{background:#fff;padding:24px;border-radius:var(--radius);box-shadow:var(--r-shadow);position:sticky;top:80px;height:fit-content}
.book-card .price{font-size:24px;font-weight:700;color:var(--primary)}
.book-card .deposit{color:var(--muted);font-size:14px;margin-bottom:16px}
.amen-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin:12px 0}
.amen-grid li{background:#f1f5f9;padding:10px;border-radius:8px;font-size:14px}
.rooms-table,.data-table{width:100%;border-collapse:collapse;margin:12px 0;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.rooms-table th,.data-table th{background:#f8fafc;text-align:left;padding:12px;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.rooms-table td,.data-table td{padding:12px;border-top:1px solid var(--border);font-size:14px}
.status{padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;display:inline-block}
.status.available,.status.active,.status.paid,.status.vacant,.status.resolved,.status.approved,.status.success,.status.verified{background:#dcfce7;color:#166534}
.status.full,.status.overdue,.status.blocked,.status.rejected,.status.failed{background:#fee2e2;color:#991b1b}
.status.maintenance,.status.cleaning,.status.pending,.status.new,.status.partial,.status.in_progress,.status.notice{background:#fef3c7;color:#92400e}
.status.vacated,.status.closed,.status.inactive,.status.blacklisted{background:#e2e8f0;color:#475569}
.pri{padding:3px 10px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase}
.pri.urgent{background:#dc2626;color:#fff}.pri.high{background:#e23b3b;color:#fff}
.pri.medium{background:#fbbf24;color:#0f172a}.pri.low{background:#94a3b8;color:#fff}
.review{background:#f8fafc;padding:14px;border-radius:8px;margin-bottom:8px}
.page{padding:40px 16px}
.page h3{margin:20px 0 8px}
.page ul{margin-left:24px;line-height:1.8}

@media (max-width:900px){
  .hero h1{font-size:32px}
  .search-bar{flex-direction:column}
  .pg-grid,.search-page{grid-template-columns:1fr}
  .filters{position:static}
}

/* =========================================================================
   ICONS  (Lucide, replaces <i data-lucide="…"> with <svg>)
   ========================================================================= */
[data-lucide],
.i-xs,.i-sm,.i-md,.i-lg{
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  stroke-width:2;vertical-align:middle;color:currentColor
}
.i-xs{width:14px;height:14px}
.i-sm{width:16px;height:16px}
.i-md{width:20px;height:20px}
.i-lg{width:24px;height:24px}
/* Default size if no class set (e.g. inside feature-icon, city-pin, city-arrow) */
.feature-icon [data-lucide], .feature-icon svg{width:26px;height:26px;stroke-width:2}
.city-pin [data-lucide], .city-pin svg{width:20px;height:20px}
.city-arrow [data-lucide], .city-arrow svg{width:18px;height:18px}
.badge [data-lucide], .badge svg{width:13px;height:13px;margin-right:2px;vertical-align:-2px}
.amen [data-lucide], .amen svg{width:12px;height:12px;margin-right:3px;vertical-align:-1px}
.loc [data-lucide], .loc svg{width:13px;height:13px;margin-right:4px;vertical-align:-2px;color:var(--muted)}

/* =========================================================================
   MODERN HOMEPAGE  (hero-v2, features, how-it-works, cities-v2, cta-v2)
   ========================================================================= */
.section{padding:clamp(48px,8vw,96px) 0}
.section-head{text-align:center;max-width:760px;margin:0 auto clamp(28px,5vw,48px)}
.section-head h2{font-size:clamp(24px,4vw,36px);line-height:1.2;margin:8px 0 12px}
.section-head .muted{font-size:clamp(14px,2vw,16px);line-height:1.6}
.kicker{display:inline-block;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary);background:rgba(209,31,31,.08);padding:6px 14px;border-radius:999px}
.kicker-light{background:rgba(255,255,255,.18);color:#fff}

/* HERO V2 */
.hero-v2{position:relative;overflow:hidden;padding:clamp(60px,10vw,120px) 0 clamp(40px,7vw,80px);text-align:center;isolation:isolate;
  background:
    radial-gradient(900px 520px at 12% -8%, rgba(255,255,255,.9), transparent 60%),
    radial-gradient(700px 480px at 88% 4%, rgba(248,214,214,.65), transparent 58%),
    radial-gradient(640px 520px at 50% 118%, rgba(226,59,59,.10), transparent 60%),
    linear-gradient(135deg,#fff5f5 0%,#fdeaea 52%,#fbe2e2 100%)}
/* Subtle dotted grid overlay for depth */
.hero-v2::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(rgba(209,31,31,.07) 1px,transparent 1px);
  background-size:26px 26px;
  -webkit-mask-image:radial-gradient(ellipse 75% 70% at 50% 38%,#000 35%,transparent 78%);
  mask-image:radial-gradient(ellipse 75% 70% at 50% 38%,#000 35%,transparent 78%)}
/* Seamless fade into the section below */
.hero-v2::after{content:"";position:absolute;left:0;right:0;bottom:0;height:120px;z-index:0;pointer-events:none;background:linear-gradient(180deg,transparent,var(--bg))}
.hero-v2 .blob{position:absolute;border-radius:50%;filter:blur(72px);opacity:.55;pointer-events:none;z-index:0;animation:floaty 14s ease-in-out infinite}
.hero-v2 .blob-1{width:420px;height:420px;background:#f3bcbc;top:-120px;left:-120px}
.hero-v2 .blob-2{width:380px;height:380px;background:#f8d6d6;bottom:-160px;right:-100px;animation-delay:-5s}
.hero-v2 .blob-3{width:280px;height:280px;background:#eeacac;top:30%;right:35%;animation-delay:-9s}
@keyframes floaty{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-30px) scale(1.06)}}
.hero-inner{position:relative;z-index:1}
.hero-badge{position:relative;display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.72);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.9);color:var(--primary);padding:8px 17px;border-radius:999px;font-size:13px;font-weight:600;margin-bottom:20px;box-shadow:0 6px 20px -6px rgba(209,31,31,.22),inset 0 1px 0 rgba(255,255,255,.6)}
.hero-badge [data-lucide],.hero-badge svg{color:#e23b3b;filter:drop-shadow(0 0 6px rgba(226,59,59,.5));animation:badgeZap 2.6s ease-in-out infinite}
@keyframes badgeZap{0%,100%{opacity:1}50%{opacity:.5}}
.hero-title{font-size:clamp(32px,6vw,56px);line-height:1.05;font-weight:800;margin-bottom:18px;letter-spacing:-.02em}
.hero-title .grad{background:linear-gradient(100deg,#d11f1f 0%,#e23b3b 28%,#ff6b6b 50%,#e23b3b 72%,#d11f1f 100%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradSweep 6s linear infinite}
@keyframes gradSweep{to{background-position:220% center}}
.hero-title .brk{display:none}
@media (min-width:720px){.hero-title .brk{display:inline}}
.hero-lead{font-size:clamp(15px,2.2vw,19px);color:var(--muted);max-width:680px;margin:0 auto 32px;line-height:1.6}

/* Search bar v2 */
.search-bar-v2{position:relative;background:#fff;border-radius:20px;padding:8px;display:grid;grid-template-columns:1.4fr 1fr 1fr auto;gap:6px;max-width:880px;margin:0 auto;box-shadow:0 24px 60px -16px rgba(209,31,31,.28),0 6px 16px rgba(15,23,42,.06);border:1px solid rgba(255,255,255,.9);align-items:stretch;transition:box-shadow .25s,transform .25s}
/* Soft gradient glow ring behind the bar */
.search-bar-v2::before{content:"";position:absolute;inset:-2px;z-index:-1;border-radius:22px;background:linear-gradient(120deg,rgba(209,31,31,.45),rgba(255,107,107,.25),rgba(226,59,59,.45));opacity:0;filter:blur(14px);transition:opacity .3s}
.search-bar-v2:focus-within{transform:translateY(-2px);box-shadow:0 30px 70px -16px rgba(209,31,31,.34),0 8px 20px rgba(15,23,42,.07)}
.search-bar-v2:focus-within::before{opacity:1}
.search-field{display:flex;flex-direction:column;padding:8px 14px;text-align:left;border-radius:14px;transition:background .15s;cursor:text;min-width:0}
.search-field:hover,.search-field:focus-within{background:#fef5f5}
.search-field + .search-field{border-left:1px solid var(--border)}
.sf-label{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--muted);text-transform:uppercase;margin-bottom:2px}
.search-field input,.search-field select{border:0;outline:0;font-size:15px;background:transparent;padding:2px 0;font-family:inherit;color:var(--text);width:100%}
.search-field select{cursor:pointer}
.search-go{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 26px;border-radius:12px;font-size:15px;border:0;min-height:54px;background:linear-gradient(135deg,var(--primary),#e23b3b);color:#fff;font-weight:700;transition:transform .15s,box-shadow .2s,filter .15s}
.search-go:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(209,31,31,.35);filter:brightness(1.05)}
.search-go-icon{font-size:18px}

/* Hero stats strip */
.hero-stats{margin-top:36px;display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-width:680px;margin-left:auto;margin-right:auto}
.hstat{display:flex;flex-direction:column;align-items:center;padding:16px 8px;background:rgba(255,255,255,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.7);border-radius:16px;box-shadow:0 6px 18px -10px rgba(209,31,31,.18);transition:transform .2s,box-shadow .2s,border-color .2s}
.hstat:hover{transform:translateY(-3px);border-color:rgba(226,59,59,.35);box-shadow:0 16px 30px -14px rgba(209,31,31,.32)}
.hstat strong{font-size:clamp(18px,3vw,24px);font-weight:800;line-height:1.1;background:linear-gradient(135deg,#d11f1f,#e23b3b);-webkit-background-clip:text;background-clip:text;color:transparent}
.hstat span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;text-align:center}

/* Features v2 */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feature-card{background:#fff;padding:26px 26px 22px;border-radius:18px;border:1px solid var(--border);transition:transform .2s,box-shadow .2s,border-color .2s;position:relative;overflow:hidden;display:flex;flex-direction:column;color:var(--text);text-decoration:none}
.feature-card::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(209,31,31,.04));opacity:0;transition:opacity .25s;pointer-events:none}
.feature-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px -18px rgba(209,31,31,.22);border-color:transparent;text-decoration:none}
.feature-card:hover::after{opacity:1}
/* Top accent bar reveals on hover */
.fc-accent{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),#e23b3b);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.feature-card:hover .fc-accent{transform:scaleX(1)}
.fc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:16px}
.fc-tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;white-space:nowrap;letter-spacing:.2px}
.fc-tag [data-lucide],.fc-tag svg{width:11px;height:11px}
.tag-tenant{background:rgba(37,99,235,.1);color:#2563eb}
.tag-owner{background:rgba(209,31,31,.1);color:var(--primary)}
.tag-trust{background:#dcfce7;color:#15803d}
.tag-both{background:#fef3c7;color:#b45309}
.tag-ai{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#7c3aed}
.fc-link{margin-top:auto;padding-top:14px;display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:700;color:var(--primary);opacity:.85;transition:gap .15s,opacity .15s}
.fc-link [data-lucide],.fc-link svg{transition:transform .15s}
.feature-card:hover .fc-link{opacity:1;gap:8px}
.feature-card:hover .fc-link [data-lucide],.feature-card:hover .fc-link svg{transform:translateX(2px)}
.feature-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;background:#f1f5f9;transition:transform .2s}
.feature-card:hover .feature-icon{transform:scale(1.06) rotate(-3deg)}
.feature-icon.icon-1{background:linear-gradient(135deg,#fde9e9,#f7d8d8)}
.feature-icon.icon-2{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}
.feature-icon.icon-3{background:linear-gradient(135deg,#fdeaea,#f8d6d6)}
.feature-icon.icon-4{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}
.feature-icon.icon-5{background:linear-gradient(135deg,#fef3c7,#fde68a)}
.feature-icon.icon-6{background:linear-gradient(135deg,#fdeaea,#f7d8d8)}
.feature-card h3{font-size:18px;margin-bottom:6px;font-weight:700}
.feature-card p{font-size:14px;color:var(--muted);line-height:1.6}

/* How it works */
.how-it-works{background:linear-gradient(180deg,#fff,#fef5f5)}
.steps-grid{position:relative;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
/* Dotted connector line behind the cards (desktop) */
.steps-line{display:none;position:absolute;top:64px;left:14%;right:14%;height:2px;background:repeating-linear-gradient(90deg,#f3bcbc 0 8px,transparent 8px 16px);z-index:0}
@media (min-width:780px){.steps-line{display:block}}
.step{position:relative;z-index:1;padding:26px 24px 22px;background:#fff;border-radius:18px;border:1px solid var(--border);transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column;overflow:hidden}
.step::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),#e23b3b);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.step:hover{transform:translateY(-4px);box-shadow:0 24px 48px -18px rgba(209,31,31,.2);border-color:transparent}
.step:hover::before{transform:scaleX(1)}
.step-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;font-size:16px;font-weight:800;letter-spacing:.5px;color:#fff;background:linear-gradient(135deg,var(--primary),#e23b3b);border-radius:50%;box-shadow:0 8px 18px -6px rgba(209,31,31,.5)}
.step-ico{width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,#fde9e9,#f7d8d8);color:#b81f1f;display:flex;align-items:center;justify-content:center;transition:transform .2s}
.step-ico [data-lucide],.step-ico svg{width:22px;height:22px}
.step:hover .step-ico{transform:scale(1.08) rotate(-3deg)}
.step h3{font-size:18px;margin-bottom:8px;font-weight:700}
.step p{font-size:14px;color:var(--muted);line-height:1.6}
.step-tag{margin-top:14px;display:inline-flex;align-items:center;gap:5px;align-self:flex-start;font-size:11.5px;font-weight:700;color:#15803d;background:#dcfce7;padding:5px 11px;border-radius:999px}
.step-tag [data-lucide],.step-tag svg{width:12px;height:12px}

/* Feature/PG card extras for verified badge */
.pg-card .badge-verified{left:auto;right:12px;background:#dcfce7;color:#166534}

/* Cities v2 */
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.city-pill-v2{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:12px;color:var(--text);transition:transform .15s,border-color .15s,box-shadow .2s}
.city-pill-v2:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:var(--shadow);text-decoration:none}
.city-pin{font-size:20px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:#fef5f5;border-radius:10px;flex-shrink:0}
.city-info{display:flex;flex-direction:column;flex:1;min-width:0}
.city-info strong{font-size:15px}
.city-info small{color:var(--muted);font-size:12px}
.city-arrow{color:var(--muted);font-size:18px;transition:transform .15s,color .15s}
.city-pill-v2:hover .city-arrow{transform:translateX(3px);color:var(--primary)}

/* CTA v2 */
.cta-v2{position:relative;overflow:hidden;background:linear-gradient(135deg,#d11f1f 0%,#e23b3b 35%,#e23b3b 100%);color:#fff;padding:clamp(48px,8vw,80px) 0;isolation:isolate}
.cta-v2::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 0%,rgba(255,255,255,.18),transparent 40%),radial-gradient(circle at 80% 100%,rgba(255,255,255,.12),transparent 40%);z-index:0}
.cta-inner{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
.cta-text{flex:1;min-width:280px}
.cta-text h2{font-size:clamp(24px,4vw,36px);margin:10px 0 12px;line-height:1.15}
.cta-text p{opacity:.92;max-width:520px;font-size:15px;line-height:1.6}
.cta-actions{display:flex;gap:10px;flex-wrap:wrap}
.btn-lg{padding:14px 26px;font-size:16px;border-radius:12px}
.cta-v2 .btn.primary{background:#fff;color:var(--primary);border-color:#fff}
.cta-v2 .btn.primary:hover{background:#fff;filter:brightness(.96)}
.cta-v2 .btn.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.cta-v2 .btn.ghost:hover{background:rgba(255,255,255,.1)}

/* TOPBAR mobile hamburger */
.menu-toggle{display:none;background:transparent;border:0;padding:8px;cursor:pointer;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px}
.menu-toggle:hover{background:#f1f5f9}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--text);position:relative;border-radius:2px;transition:transform .2s,opacity .2s}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;width:100%;height:2px;background:var(--text);border-radius:2px;transition:transform .2s}
.menu-toggle span::before{top:-7px}
.menu-toggle span::after{top:7px}
body.menu-open .menu-toggle span{background:transparent}
body.menu-open .menu-toggle span::before{transform:translateY(7px) rotate(45deg)}
body.menu-open .menu-toggle span::after{transform:translateY(-7px) rotate(-45deg)}

/* Responsive: tablet & phone */
@media (max-width:900px){
  .search-bar-v2{grid-template-columns:1fr;padding:10px;gap:4px}
  .search-field + .search-field{border-left:0;border-top:1px solid var(--border)}
  .search-field{padding:10px 14px}
  .search-go{width:100%;margin-top:4px;min-height:50px}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:10px}
  .cta-inner{flex-direction:column;align-items:flex-start}
}
@media (max-width:520px){
  .hero-v2{padding-top:48px}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .feature-card{padding:22px}
  .step{padding:24px 20px}
  .city-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .city-info strong{font-size:14px}
  .brand{font-size:18px}
  .brand small{display:none}
  .brand-logo{height:32px}
}
@media (prefers-reduced-motion: reduce){
  .hero-v2 .blob{animation:none}
  .hero-title .grad,.hero-badge [data-lucide],.hero-badge svg,.float-card{animation:none}
  .feature-card,.step,.city-pill-v2,.pg-card,.hstat{transition:none}
}

/* =========================================================================
   HOME V3 — quick chips, floating decor, trust strip, testimonials, FAQ
   ========================================================================= */

/* Floating decorative cards in hero (decorative only) */
.hero-floats{position:absolute;inset:0;pointer-events:none;z-index:0;display:none}
@media (min-width:1100px){ .hero-floats{display:block} }
.float-card{position:absolute;display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.95);border-radius:16px;padding:11px 15px;box-shadow:0 20px 40px -14px rgba(209,31,31,.28),inset 0 1px 0 rgba(255,255,255,.7);min-width:200px;animation:floaty 8s ease-in-out infinite}
.float-card strong{display:block;font-size:13px;font-weight:700;color:var(--text);line-height:1.2}
.float-card small{display:block;font-size:11px;color:var(--muted);margin-top:2px}
.float-card .fc-ico{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#fde9e9,#f7d8d8);color:#b81f1f;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.float-card .fc-ico [data-lucide],.float-card .fc-ico svg{width:18px;height:18px}
.float-card .fc-ico-pink{background:linear-gradient(135deg,#fdeaea,#f8d6d6);color:#c21f1f}
.float-card .fc-ico-green{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}
.float-card-1{top:14%;left:3%}
.float-card-2{top:38%;right:3%;animation-delay:-3s}
.float-card-3{bottom:18%;left:5%;animation-delay:-6s}

/* ===================== PRODUCT SHOWCASE ===================== */
.product-showcase{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%,#fdf4f4 55%,#fff 100%)}
.product-showcase .container{position:relative;z-index:1;max-width:1200px}
.ps-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;pointer-events:none;z-index:0}
.ps-blob-1{width:360px;height:360px;background:#f3bcbc;top:-80px;left:-100px}
.ps-blob-2{width:320px;height:320px;background:#f8d6d6;bottom:-120px;right:-80px}

.ps-stage{position:relative;display:flex;align-items:center;justify-content:center;gap:32px;max-width:1140px;margin:0 auto}

/* Browser mockup */
.ps-browser{flex:1;min-width:0;max-width:860px;background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:0 50px 90px -34px rgba(209,31,31,.3),0 14px 34px -14px rgba(15,23,42,.2);overflow:hidden}
.ps-chrome{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f8fafc;border-bottom:1px solid var(--border)}
.ps-dot{width:11px;height:11px;border-radius:50%;background:#e2e8f0}
.ps-dot:nth-child(1){background:#ff5f57}.ps-dot:nth-child(2){background:#febc2e}.ps-dot:nth-child(3){background:#28c840}
.ps-url{margin-left:10px;display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);border-radius:8px;padding:5px 14px;font-size:12px;color:var(--muted);font-weight:500}
.ps-app{display:flex;min-height:400px}

/* Sidebar */
.ps-side{width:194px;flex-shrink:0;background:linear-gradient(180deg,#fff,#fdf7f7);border-right:1px solid var(--border);padding:16px 12px;display:flex;flex-direction:column;gap:18px}
.ps-side-brand{display:flex;align-items:center;gap:8px}
.ps-side-logo-img{height:30px;width:auto;display:block}
.ps-pro{font-size:10px;font-weight:700;background:rgba(209,31,31,.1);color:var(--primary);padding:2px 7px;border-radius:6px}
.ps-nav{display:flex;flex-direction:column;gap:3px}
.ps-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;font-size:13px;font-weight:600;color:var(--muted)}
.ps-nav-item [data-lucide],.ps-nav-item svg{width:16px;height:16px}
.ps-nav-item.active{background:linear-gradient(135deg,rgba(209,31,31,.12),rgba(226,59,59,.06));color:var(--primary);box-shadow:inset 2px 0 0 var(--primary)}
.ps-nav-badge{margin-left:auto;font-size:10px;font-weight:700;background:#eef2f7;color:var(--muted);padding:1px 7px;border-radius:999px}
.ps-nav-dot{margin-left:auto;width:7px;height:7px;border-radius:50%;background:var(--primary)}
.ps-trial{margin-top:auto;display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#fde9e9,#f8d6d6);border-radius:10px;padding:10px 12px;color:#b81f1f}
.ps-trial strong{display:block;font-size:12px;font-weight:700;line-height:1.2}
.ps-trial small{display:block;font-size:10px;color:#a14545}

/* Main panel */
.ps-main{flex:1;min-width:0;padding:14px 20px 18px;background:#fcfcfd}
.ps-topbar{display:flex;align-items:center;gap:12px;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--border)}
.ps-search{flex:1;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:9px;padding:8px 13px;font-size:12px;color:var(--muted)}
.ps-topbar-right{display:flex;align-items:center;gap:10px}
.ps-icon-btn{position:relative;width:34px;height:34px;border-radius:9px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text)}
.ps-icon-btn [data-lucide],.ps-icon-btn svg{width:16px;height:16px}
.ps-icon-badge{position:absolute;top:6px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--primary);border:1.5px solid #fff}
.ps-me{width:34px;height:34px;border-radius:50%;color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center}
.ps-main-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ps-main-head strong{display:block;font-size:16px;font-weight:800}
.ps-main-head small{font-size:12px;color:var(--muted)}
.ps-add-btn{display:inline-flex;align-items:center;gap:5px;background:var(--primary);color:#fff;font-size:12px;font-weight:700;padding:8px 14px;border-radius:9px;box-shadow:0 8px 18px -8px rgba(209,31,31,.6)}
/* KPI mini-tiles (mirrors the real owner dashboard) */
.ps-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.ps-kpi{background:#fff;border:1px solid var(--border);border-radius:11px;padding:11px 12px;display:flex;flex-direction:column;gap:1px;box-shadow:0 2px 8px rgba(15,23,42,.03)}
.ps-kpi [data-lucide],.ps-kpi svg{width:16px;height:16px;color:var(--muted);margin-bottom:5px}
.ps-kpi strong{font-size:17px;font-weight:800;line-height:1;color:var(--text)}
.ps-kpi strong.good{color:var(--good)}.ps-kpi strong.bad{color:var(--bad)}
.ps-kpi span{font-size:10px;font-weight:600;color:var(--muted);letter-spacing:.2px;text-transform:uppercase;line-height:1.2}

.ps-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.ps-stat{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:0 2px 8px rgba(15,23,42,.03)}
.ps-stat-label{display:block;font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.ps-stat-val{display:block;font-size:22px;font-weight:800;line-height:1.1;margin-bottom:8px}
.ps-stat-val.good{color:var(--good)}.ps-stat-val.bad{color:var(--bad)}
.ps-stat-foot{display:flex;align-items:center;gap:8px}
.ps-spark{flex:1;height:28px;min-width:0}
.ps-chip{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;background:#f1f5f9;color:var(--muted);white-space:nowrap}
.ps-chip [data-lucide],.ps-chip svg{width:11px;height:11px}
.ps-chip.good{background:#dcfce7;color:#15803d}.ps-chip.bad{background:#fee2e2;color:#b91c1c}
.ps-occ{margin-top:2px}
.ps-occ-bar{height:7px;border-radius:999px;background:#eef2f7;overflow:hidden;margin-bottom:6px}
.ps-occ-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),#e23b3b)}
.ps-occ-cap{font-size:10px;font-weight:600;color:var(--muted)}

.ps-log{background:#fff;border:1px solid var(--border);border-radius:12px;padding:8px 14px;box-shadow:0 2px 8px rgba(15,23,42,.03)}
.ps-log-head{display:flex;align-items:center;justify-content:space-between;padding:8px 0 10px;border-bottom:1px solid var(--border)}
.ps-log-head strong{font-size:14px;font-weight:800}
.ps-seg{display:inline-flex;background:#f1f5f9;border-radius:8px;padding:2px}
.ps-seg b{font-size:11px;font-weight:700;color:var(--muted);padding:4px 11px;border-radius:6px}
.ps-seg b.active{background:#fff;color:var(--text);box-shadow:0 1px 3px rgba(15,23,42,.12)}
.ps-log-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid #f1f5f9}
.ps-log-row:last-child{border-bottom:0}
.ps-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center}
.ps-log-name{flex:1;min-width:0}
.ps-log-name strong{display:block;font-size:13px;font-weight:700}
.ps-log-name small{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--muted)}
.ps-log-name small [data-lucide],.ps-log-name small svg{width:11px;height:11px}
.ps-log-amt{text-align:right}
.ps-log-amt strong{display:block;font-size:13px;font-weight:800}
.ps-log-amt small{font-size:11px;color:var(--muted)}
.ps-status{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px;width:86px;justify-content:center}
.ps-status.good{background:#dcfce7;color:#15803d}
.ps-status.warn{background:#fef3c7;color:#b45309}

/* Floating notification cards */
.ps-float{position:absolute;z-index:3;display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.9);border-radius:13px;padding:10px 13px;box-shadow:0 20px 42px -14px rgba(15,23,42,.28);animation:floaty 7s ease-in-out infinite}
.ps-float strong{display:block;font-size:12px;font-weight:700;line-height:1.2}
.ps-float small{display:block;font-size:10px;color:var(--muted);margin-top:2px}
.ps-float-ico{width:32px;height:32px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fde9e9,#f7d8d8);color:#b81f1f}
.ps-float-ico [data-lucide],.ps-float-ico svg{width:17px;height:17px}
.ps-float-green{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}
.ps-float-purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#7c3aed}
.ps-float-1{top:-5%;right:2%;animation-delay:-1s}
.ps-float-2{bottom:9%;left:-2%;animation-delay:-4s}
.ps-float-3{top:16%;left:-2%;animation-delay:-6s}

/* Tenant phone mockup — iPhone 17 Pro Max (430×932 viewport ratio) */
.ps-phone{position:relative;flex-shrink:0;width:274px;
  background:linear-gradient(150deg,#d9dde3 0%,#9aa3ad 14%,#71787f 28%,#3f444a 50%,#71787f 72%,#a8b0b8 86%,#d9dde3 100%);
  border-radius:52px;padding:13px;
  box-shadow:0 60px 100px -34px rgba(209,31,31,.3),0 22px 44px -16px rgba(15,23,42,.45),
             inset 0 0 0 1.5px rgba(255,255,255,.35),inset 0 0 0 7px #0b0e13}
/* Titanium side buttons */
.ps-btn{position:absolute;background:linear-gradient(180deg,#aeb6bf,#6c737b);border-radius:3px;box-shadow:inset 0 1px 1px rgba(255,255,255,.4)}
.ps-btn-action{left:-3px;top:108px;width:4px;height:30px}
.ps-btn-vol-up{left:-3px;top:158px;width:4px;height:50px}
.ps-btn-vol-dn{left:-3px;top:220px;width:4px;height:50px}
.ps-btn-power{right:-3px;top:170px;width:4px;height:74px}
/* Screen locked to iPhone 17 Pro Max viewport ratio (430 × 932) */
.ps-phone-screen{position:relative;background:linear-gradient(180deg,#fff,#f6f8fb);border-radius:40px;overflow:hidden;display:flex;flex-direction:column;width:100%;aspect-ratio:430/932}
/* Dynamic Island */
.ps-island{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:88px;height:27px;background:#000;border-radius:999px;z-index:5;display:flex;align-items:center;justify-content:flex-end;padding-right:9px}
.ps-island-cam{width:9px;height:9px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#3b4a63,#0a1020 70%);box-shadow:inset 0 0 0 1px rgba(120,150,200,.35)}
.ps-ph-status{position:relative;display:flex;align-items:center;justify-content:space-between;padding:15px 26px 6px;font-size:12px;font-weight:700;color:var(--text)}
.ps-ph-time{letter-spacing:.3px}
.ps-ph-status-ico{display:inline-flex;gap:4px;align-items:center}
.ps-ph-status-ico [data-lucide],.ps-ph-status-ico svg{width:14px;height:14px}
.ps-ph-home-bar{position:absolute;bottom:7px;left:50%;transform:translateX(-50%);width:108px;height:5px;border-radius:999px;background:#0f172a;opacity:.85}
.ps-ph-body{flex:1;display:flex;flex-direction:column;gap:13px;padding:8px 16px 14px}
.ps-ph-top{display:flex;align-items:center;justify-content:space-between}
.ps-ph-top small{font-size:11px;color:var(--muted)}
.ps-ph-top strong{display:block;font-size:17px;font-weight:800}
.ps-ph-bell{position:relative;width:34px;height:34px;border-radius:10px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text)}
.ps-ph-bell [data-lucide],.ps-ph-bell svg{width:17px;height:17px}
.ps-ph-bell-dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--primary);border:1.5px solid #fff}
.ps-ph-rent{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--primary),#e23b3b);border-radius:18px;padding:16px;color:#fff;display:flex;flex-direction:column;gap:2px;box-shadow:0 14px 28px -12px rgba(209,31,31,.7)}
.ps-ph-rent-glow{position:absolute;top:-40px;right:-30px;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,.18);pointer-events:none}
.ps-ph-rent small{font-size:11px;opacity:.9}
.ps-ph-rent strong{font-size:28px;font-weight:800;line-height:1.1;position:relative}
.ps-ph-due{display:inline-flex;align-items:center;gap:4px;font-size:11px;opacity:.95;margin-bottom:10px}
.ps-ph-due [data-lucide],.ps-ph-due svg{width:12px;height:12px}
.ps-ph-pay{display:inline-flex;align-items:center;justify-content:center;gap:5px;background:#fff;color:var(--primary);font-size:13px;font-weight:800;padding:10px;border-radius:11px}
.ps-ph-rent-foot{display:inline-flex;align-items:center;gap:4px;font-size:10px;opacity:.85;margin-top:8px;justify-content:center}
.ps-ph-rent-foot [data-lucide],.ps-ph-rent-foot svg{width:11px;height:11px}
.ps-ph-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}
.ps-ph-tile{background:#fff;border:1px solid var(--border);border-radius:13px;padding:13px 10px;display:flex;flex-direction:column;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--text);box-shadow:0 2px 6px rgba(15,23,42,.03)}
.ps-ph-tile [data-lucide],.ps-ph-tile svg{width:19px;height:19px;color:var(--primary)}
.ps-ph-notice{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:13px;padding:11px}
.ps-ph-notice-ico{width:32px;height:32px;border-radius:9px;flex-shrink:0;background:rgba(245,158,11,.12);color:#d97706;display:flex;align-items:center;justify-content:center}
.ps-ph-notice-ico [data-lucide],.ps-ph-notice-ico svg{width:16px;height:16px}
.ps-ph-notice strong{display:block;font-size:12px;font-weight:700}
.ps-ph-notice small{font-size:11px;color:var(--muted)}
.ps-ph-nav{display:flex;align-items:center;justify-content:space-around;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-top:1px solid var(--border);padding:11px 0 22px}
.ps-ph-nav-item{width:38px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:9px;color:#94a3b8}
.ps-ph-nav-item [data-lucide],.ps-ph-nav-item svg{width:19px;height:19px}
.ps-ph-nav-item.active{color:var(--primary);background:rgba(209,31,31,.08)}

.ps-cta{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:clamp(36px,6vw,56px)}
.ps-cta .btn-lg [data-lucide],.ps-cta .btn-lg svg{width:18px;height:18px;vertical-align:-4px;margin-right:5px}

@media (max-width:980px){
  .ps-stage{flex-direction:column;gap:22px}
  .ps-browser{max-width:640px;width:100%}
  .ps-float-1{top:-3%;right:2%}
  .ps-float-2{bottom:auto;top:auto;left:auto;display:none}
  .ps-float-3{display:none}
}
@media (max-width:680px){
  /* Hide the decorative sidebar + top bar on phones — show just the dashboard content. */
  .ps-app{flex-direction:column;min-height:0}
  .ps-side{display:none}
  .ps-topbar{display:none}
  .ps-float{display:none}
  .ps-main{padding:16px 14px 18px}
  .ps-main-head strong{font-size:15px}
  .ps-kpis{grid-template-columns:repeat(3,1fr);gap:8px}
  .ps-kpi{padding:10px}
  .ps-kpi strong{font-size:15px}
  .ps-stats{gap:10px}
}
@media (max-width:480px){
  .ps-stats{grid-template-columns:1fr 1fr}
  .ps-stat:last-child{grid-column:span 2}
  .ps-status{width:auto}
  .ps-nav-item{font-size:12px;padding:8px 10px}
  .ps-kpis{grid-template-columns:repeat(2,1fr)}
}

/* Quick city chips under search bar */
.quick-chips{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin:20px auto 0;max-width:880px}
.quick-chips .qc-label{font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.4px;text-transform:uppercase}
.qc-pill{background:rgba(255,255,255,.7);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(209,31,31,.15);color:var(--text);padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;transition:background .15s,color .15s,border-color .15s,transform .15s;text-decoration:none}
.qc-pill:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px);text-decoration:none}

/* Live trust strip */
.trust-strip{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0}
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:center}
.trust-item{display:flex;align-items:center;gap:12px;min-width:0}
.trust-item strong{display:block;font-size:18px;font-weight:800;color:var(--text);line-height:1.1}
.trust-item small{display:block;font-size:12px;color:var(--muted);margin-top:2px}
.trust-ico{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#fde9e9,#fdeaea);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.trust-ico [data-lucide],.trust-ico svg{width:18px;height:18px}
.trust-dot{width:10px;height:10px;border-radius:50%;background:#10b981;flex-shrink:0;position:relative;margin-left:14px;margin-right:14px;box-shadow:0 0 0 4px rgba(16,185,129,.18)}
.trust-dot.live::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid #10b981;opacity:.6;animation:livepulse 1.8s ease-out infinite}
@keyframes livepulse{0%{transform:scale(.6);opacity:.7}100%{transform:scale(1.7);opacity:0}}

/* Testimonials v3 */
.testimonials{background:linear-gradient(180deg,#fef5f5,#fff)}
.t-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px}
/* Testimonials carousel */
.t-carousel{position:relative}
.t-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:10px 4px 16px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.t-track::-webkit-scrollbar{display:none}
.t-track>.t-card-v3{scroll-snap-align:start;flex:0 0 calc((100% - 40px)/3);min-width:0}
.t-nav{position:absolute;top:42%;transform:translateY(-50%);z-index:6;width:44px;height:44px;border-radius:50%;background:#fff;border:1px solid var(--border);box-shadow:0 12px 28px -12px rgba(15,23,42,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);transition:background .2s,color .2s,opacity .2s,transform .2s}
.t-nav:hover{background:var(--primary);color:#fff;border-color:transparent}
.t-nav:active{transform:translateY(-50%) scale(.94)}
.t-nav:disabled{opacity:.3;cursor:default;pointer-events:none}
.t-nav svg,.t-nav [data-lucide]{width:20px;height:20px}
.t-prev{left:-14px}
.t-next{right:-14px}
.t-carousel.is-static .t-nav,.t-carousel.is-static .t-dots{display:none}
.t-dots{display:flex;justify-content:center;gap:8px;margin-top:16px}
.t-dot{width:8px;height:8px;padding:0;border:none;border-radius:999px;background:#d1d5db;cursor:pointer;transition:width .25s ease,background .25s ease}
.t-dot:hover{background:#9ca3af}
.t-dot.is-active{width:26px;background:var(--primary)}
.t-card-v3{position:relative;overflow:hidden;background:#fff;border:1px solid var(--border);border-radius:20px;padding:26px 24px 22px;display:flex;flex-direction:column;gap:14px;transition:transform .2s,box-shadow .2s,border-color .2s}
.t-card-v3::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),#e23b3b);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.t-card-v3:hover{transform:translateY(-4px);box-shadow:0 24px 48px -18px rgba(209,31,31,.2);border-color:transparent}
.t-card-v3:hover::before{transform:scaleX(1)}
.t-quotemark{position:absolute;top:6px;right:18px;font-family:Georgia,serif;font-size:84px;line-height:1;color:var(--primary);opacity:.1;pointer-events:none}
.t-stars{display:flex;gap:2px;color:#f59e0b;position:relative;z-index:1}
.t-stars [data-lucide],.t-stars svg{fill:currentColor;width:15px;height:15px}
.t-card-v3 p{margin:0;font-size:15px;line-height:1.65;color:#334155;flex:1;position:relative;z-index:1}
.t-foot{display:flex;align-items:center;gap:12px;position:relative;z-index:1}
.t-foot-id{flex:1;min-width:0}
.t-avatar{width:46px;height:46px;border-radius:50%;color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px;box-shadow:0 6px 16px -6px rgba(15,23,42,.4)}
.t-foot strong{display:block;font-size:14.5px;font-weight:700;line-height:1.2}
.t-foot small{display:block;font-size:12px;color:var(--muted);margin-top:1px}
.t-verified{color:var(--good);flex-shrink:0}
.t-verified [data-lucide],.t-verified svg{width:18px;height:18px}
/* Featured (highlighted) card */
.t-card-v3.is-featured{background:linear-gradient(140deg,#d11f1f,#e23b3b);border-color:transparent;box-shadow:0 26px 50px -20px rgba(209,31,31,.5)}
.t-card-v3.is-featured::before{display:none}
.t-card-v3.is-featured p{color:#fff}
.t-card-v3.is-featured .t-quotemark{color:#fff;opacity:.22}
.t-card-v3.is-featured .t-stars{color:#fcd34d}
.t-card-v3.is-featured .t-foot strong{color:#fff}
.t-card-v3.is-featured .t-foot small{color:rgba(255,255,255,.85)}
.t-card-v3.is-featured .t-avatar{box-shadow:0 6px 16px -6px rgba(0,0,0,.45);border:2px solid rgba(255,255,255,.5)}
.t-card-v3.is-featured .t-verified{color:#fff}

/* ===================== WHATSAPP REMINDERS ===================== */
.wa-section{background:linear-gradient(180deg,#fff,#fef5f5)}
.wa-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center}
.wa-copy .kicker{display:inline-flex;align-items:center;gap:6px;margin-bottom:14px}
.wa-copy h2{font-size:clamp(24px,4vw,36px);line-height:1.2;margin:0 0 12px;font-weight:800}
.wa-copy > .muted{font-size:clamp(14px,2vw,16px);line-height:1.6;margin:0 0 22px;max-width:48ch}
.wa-list{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-direction:column;gap:16px}
.wa-list li{display:flex;gap:14px;align-items:flex-start}
.wa-li-ico{width:42px;height:42px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fde9e9,#f7d8d8);color:var(--primary)}
.wa-li-ico [data-lucide],.wa-li-ico svg{width:20px;height:20px}
.wa-li-ico-amber{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309}
.wa-li-ico-green{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}
.wa-list strong{display:block;font-size:15.5px;font-weight:700;line-height:1.3}
.wa-list small{display:block;font-size:13.5px;color:var(--muted);line-height:1.5;margin-top:2px}
.wa-list small b{color:var(--text);font-weight:700}
.wa-cta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.wa-note{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--muted)}
.wa-note [data-lucide],.wa-note svg{color:var(--primary)}

/* Chat mockup */
.wa-phone-wrap{display:flex;flex-direction:column;align-items:center;gap:14px}
.wa-chat{width:100%;max-width:390px;background:#0b141a;border-radius:26px;overflow:hidden;box-shadow:0 50px 90px -34px rgba(209,31,31,.34),0 18px 36px -16px rgba(15,23,42,.5);border:1px solid rgba(255,255,255,.08)}
.wa-chat-top{display:flex;align-items:center;gap:11px;background:linear-gradient(180deg,#202c33,#1f2c34);padding:13px 15px;border-bottom:1px solid rgba(0,0,0,.25)}
.wa-chat-avatar{width:40px;height:40px;border-radius:50%;background:#fff;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.wa-chat-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.wa-chat-id{flex:1;min-width:0}
.wa-chat-id strong{display:inline-flex;align-items:center;gap:5px;color:#e9edef;font-size:14.5px;font-weight:600;line-height:1.2}
.wa-verified-tick{width:15px;height:15px;color:#53bdeb}
.wa-chat-id small{display:flex;align-items:center;gap:5px;color:#8696a0;font-size:11px;margin-top:2px}
.wa-online-dot{width:7px;height:7px;border-radius:50%;background:#25d366;display:inline-block;box-shadow:0 0 0 3px rgba(37,211,102,.18)}
.wa-chat-more{color:#8696a0;width:18px;height:18px}
.wa-chat-body{background:#0b141a;background-image:radial-gradient(rgba(255,255,255,.025) 1px,transparent 1px);background-size:18px 18px;padding:16px 12px;display:flex;flex-direction:column;gap:10px;min-height:300px}
.wa-day{align-self:center;background:#182229;color:#8696a0;font-size:10.5px;font-weight:600;letter-spacing:.4px;padding:4px 12px;border-radius:8px;box-shadow:0 1px 1px rgba(0,0,0,.2)}
.wa-enc{align-self:center;display:inline-flex;align-items:center;gap:5px;background:rgba(255,221,102,.08);color:#e7c878;font-size:10px;padding:5px 12px;border-radius:8px;text-align:center;max-width:90%}
.wa-enc [data-lucide],.wa-enc svg{width:11px;height:11px}
.wa-bubble{max-width:85%;padding:8px 11px 18px;border-radius:10px;font-size:13.5px;line-height:1.5;color:#e9edef;position:relative;box-shadow:0 1px 1px rgba(0,0,0,.2)}
.wa-in{align-self:flex-start;background:#202c33;border-top-left-radius:3px}
.wa-out{align-self:flex-end;background:#005c4b;border-top-right-radius:3px}
.wa-link{color:#53bdeb;word-break:break-all}
.wa-time{position:absolute;right:9px;bottom:5px;font-size:10px;color:rgba(233,237,239,.55);display:inline-flex;align-items:center;gap:3px}
.wa-tick{width:13px;height:13px;color:#53bdeb}
.wa-chat-input{display:flex;align-items:center;gap:8px;background:#1f2c34;padding:9px 12px}
.wa-input-pill{flex:1;background:#2a3942;color:#8696a0;border-radius:999px;padding:8px 14px;font-size:12.5px}
.wa-send{width:34px;height:34px;border-radius:50%;background:#25d366;color:#0b141a;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.wa-cap{font-size:13px;color:var(--muted);text-align:center}

@media (max-width:860px){
  .wa-grid{grid-template-columns:1fr;gap:32px}
  .wa-phone-wrap{order:-1}
}

/* FAQ */
.faq-section{background:#fff;border-top:1px solid var(--border)}
.faq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:12px;max-width:980px;margin:0 auto}
.faq-item{background:#fef5f5;border:1px solid var(--border);border-radius:14px;padding:0;overflow:hidden;transition:border-color .15s,background .15s}
.faq-item[open]{border-color:rgba(209,31,31,.3);background:#fff;box-shadow:0 8px 24px -10px rgba(209,31,31,.12)}
.faq-item summary{cursor:pointer;list-style:none;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;gap:12px;font-weight:600;font-size:15px;color:var(--text);user-select:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary [data-lucide],.faq-item summary svg{color:var(--primary);transition:transform .2s;flex-shrink:0}
.faq-item[open] summary [data-lucide],.faq-item[open] summary svg{transform:rotate(45deg)}
.faq-item p{margin:0;padding:0 20px 18px;color:var(--muted);font-size:14px;line-height:1.65}

/* Mobile sticky search CTA */
.home-mobile-cta{display:none;position:fixed;bottom:14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--primary),#e23b3b);color:#fff;padding:13px 26px;border-radius:999px;font-weight:700;font-size:14px;align-items:center;gap:8px;z-index:40;box-shadow:0 14px 30px -8px rgba(209,31,31,.55);text-decoration:none}
.home-mobile-cta:hover{text-decoration:none;color:#fff}

/* ===== Responsive refinements ===== */
@media (max-width:960px){
  .trust-row{grid-template-columns:repeat(2,1fr);gap:18px 14px}
  .t-track>.t-card-v3{flex-basis:calc((100% - 20px)/2)}
}
@media (max-width:720px){
  .hero-v2{padding-top:36px}
  .hero-title{font-size:clamp(28px,8vw,40px);line-height:1.1}
  .hero-lead{font-size:14px;line-height:1.55;margin-bottom:22px}
  .quick-chips{margin-top:14px;gap:6px}
  .quick-chips .qc-label{display:none}
  .qc-pill{padding:5px 11px;font-size:12px}
  .hero-stats{margin-top:24px}
  .hstat{padding:10px 6px}
  .section{padding:clamp(40px,9vw,60px) 0}
  .container{padding:0 20px}
  .features-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .t-grid{grid-template-columns:1fr;gap:12px}
  .t-track>.t-card-v3{flex-basis:100%}
  .t-prev{left:2px}
  .t-next{right:2px}
  .feature-card{padding:16px 14px;border-radius:14px}
  .fc-head{margin-bottom:10px}
  .fc-tag{font-size:10px;padding:3px 8px}
  .feature-card h3{font-size:15px;margin-bottom:6px}
  .feature-card p{font-size:12.5px;line-height:1.45}
  .fc-link{padding-top:10px;font-size:12px}
  .feature-icon{width:40px;height:40px;margin-bottom:10px;border-radius:11px}
  .feature-icon [data-lucide],.feature-icon svg{width:20px;height:20px}
  .t-card-v3{padding:20px;gap:12px}
  .t-card-v3 p{font-size:14px}
  .faq-item summary{padding:14px 16px;font-size:14px}
  .faq-item p{padding:0 16px 14px;font-size:13.5px}
  .trust-strip{padding:14px 0}
  .trust-item strong{font-size:16px}
  .trust-item small{font-size:11px}
  .trust-ico{width:32px;height:32px}
  .trust-dot{margin-left:11px;margin-right:11px}
  .cta-text h2{font-size:24px}
  .home-mobile-cta{display:inline-flex}
  body.public main{padding-bottom:80px}
}
@media (max-width:460px){
  .trust-row{grid-template-columns:1fr 1fr;gap:14px 10px}
  .trust-item{gap:8px}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:8px}
  .steps-grid,.t-grid{gap:10px}
  .step{padding:22px 18px}
  .grid-3{grid-template-columns:1fr;gap:14px}
  .qc-pill{padding:5px 10px;font-size:11.5px}
}

/* =========================================================================
   ABOUT V2 — milestones timeline + press strip
   ========================================================================= */
.milestones{background:linear-gradient(180deg,#fff,#fef5f5)}
.timeline{list-style:none;padding:0;margin:0;position:relative;max-width:760px;margin-inline:auto}
.timeline::before{content:"";position:absolute;left:78px;top:6px;bottom:6px;width:2px;background:linear-gradient(180deg,#f3bcbc,#f8d6d6 60%,transparent);border-radius:2px}
.ms-item{position:relative;display:grid;grid-template-columns:88px 1fr;gap:18px;padding:8px 0 18px;align-items:flex-start}
.ms-item:last-child{padding-bottom:0}
.ms-year{display:inline-flex;align-items:center;justify-content:center;background:#fff;border:2px solid var(--primary);color:var(--primary);font-weight:800;font-size:12px;letter-spacing:.4px;padding:6px 8px;border-radius:999px;min-width:64px;text-align:center;position:relative;z-index:1;box-shadow:0 4px 14px rgba(209,31,31,.16)}
.ms-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px 18px;transition:transform .15s,box-shadow .2s,border-color .15s;flex:1;min-width:0}
.ms-card:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(209,31,31,.18);border-color:transparent}
.ms-card h3{font-size:16px;margin:0 0 4px;font-weight:700}
.ms-card p{font-size:14px;color:var(--muted);line-height:1.6;margin:0}
.ms-card-current{background:linear-gradient(135deg,#d11f1f,#e23b3b);color:#fff;border-color:transparent}
.ms-card-current h3{color:#fff}
.ms-card-current p{color:rgba(255,255,255,.92)}

/* Press strip */
.press-strip-section{padding:clamp(36px,5vw,56px) 0;background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.press-eyebrow{text-align:center;text-transform:uppercase;letter-spacing:1.5px;font-size:11px;font-weight:700;color:var(--muted);margin:0 0 18px}
.press-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(18px,4vw,42px)}
.press-name{font-size:clamp(15px,2vw,18px);font-weight:800;color:#94a3b8;letter-spacing:-.01em;font-family:Georgia,serif;transition:color .15s,filter .15s;filter:grayscale(1) opacity(.7)}
.press-name:hover{color:var(--primary);filter:grayscale(0) opacity(1)}

@media (max-width:600px){
  .timeline::before{left:46px}
  .ms-item{grid-template-columns:62px 1fr;gap:12px}
  .ms-year{min-width:48px;font-size:11px;padding:5px 6px}
  .ms-card{padding:14px 16px}
  .ms-card h3{font-size:15px}
  .ms-card p{font-size:13px}
  .press-strip{gap:14px 22px}
  .press-name{font-size:14px}
}

/* =========================================================================
   CONTACT V2 — channels grid + office map
   ========================================================================= */
.channels-section{background:linear-gradient(180deg,#fff,#fef5f5)}
.channels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.channel-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:22px;display:flex;flex-direction:column;gap:8px;text-decoration:none;color:var(--text);transition:transform .2s,box-shadow .2s,border-color .15s;position:relative;overflow:hidden}
.channel-card:hover{transform:translateY(-3px);box-shadow:0 18px 36px -14px rgba(209,31,31,.18);border-color:transparent;text-decoration:none}
.channel-card .ch-ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:6px;flex-shrink:0}
.channel-card .ch-ico [data-lucide],.channel-card .ch-ico svg{width:22px;height:22px}
.channel-card h3{font-size:16px;margin:0;font-weight:700;color:var(--text)}
.channel-card p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.5;flex:1}
.channel-card .ch-arrow{display:inline-flex;align-items:center;gap:5px;color:var(--primary);font-size:13px;font-weight:600;margin-top:6px;transition:gap .15s}
.channel-card:hover .ch-arrow{gap:8px}

/* Office section */
.office-section{background:#fff;border-top:1px solid var(--border)}
.office-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.4fr);gap:24px;align-items:stretch}
.office-info{background:#fef5f5;border:1px solid var(--border);border-radius:18px;padding:clamp(22px,3vw,32px);display:flex;flex-direction:column;gap:12px}
.office-info h3{font-size:22px;margin:0;font-weight:800}
.office-info > p{color:#334155;line-height:1.65;margin:0}
.office-meta{list-style:none;padding:0;margin:8px 0 14px;display:flex;flex-direction:column;gap:8px}
.office-meta li{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:14px}
.office-meta li [data-lucide],.office-meta li svg{color:var(--primary)}
.office-cta{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;margin-top:auto}
.office-map{border-radius:18px;overflow:hidden;border:1px solid var(--border);min-height:340px;background:#e2e8f0}
.office-map iframe{width:100%;height:100%;min-height:340px;border:0;display:block}

@media (max-width:820px){
  .office-grid{grid-template-columns:1fr;gap:16px}
  .office-map{min-height:260px}
  .office-map iframe{min-height:260px}
}
@media (max-width:520px){
  .channels-grid{grid-template-columns:1fr;gap:10px}
  .channel-card{padding:18px}
  .channel-card .ch-ico{width:40px;height:40px}
  .office-info{padding:20px}
  .office-info h3{font-size:18px}
}

/* =========================================================================
   ABOUT PAGE
   ========================================================================= */
.about-hero{padding:clamp(48px,8vw,90px) 0 clamp(40px,7vw,70px)}
.about-hero .hero-title{margin-bottom:14px}

.about-audience{background:linear-gradient(180deg,#fff,#fef5f5)}
.audience-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}
.audience-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:clamp(22px,3vw,32px);display:flex;flex-direction:column;gap:18px;transition:transform .2s,box-shadow .2s,border-color .2s;position:relative;overflow:hidden}
.audience-card::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(209,31,31,.04));opacity:0;transition:opacity .25s;pointer-events:none;border-radius:20px}
.audience-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -18px rgba(209,31,31,.2);border-color:transparent}
.audience-card:hover::after{opacity:1}
.audience-head{display:flex;align-items:center;gap:14px;position:relative;z-index:1}
.audience-head .feature-icon{margin:0}
.audience-head h3{font-size:20px;margin-top:4px}
.audience-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;position:relative;z-index:1}
.audience-list li{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;line-height:1.55;color:#334155}
.audience-list li [data-lucide],.audience-list li svg{color:var(--primary);background:rgba(209,31,31,.1);border-radius:6px;padding:3px;width:20px;height:20px;flex-shrink:0;margin-top:1px}
.audience-cta{align-self:flex-start;margin-top:6px;display:inline-flex;align-items:center;gap:6px;position:relative;z-index:1}
.audience-cta [data-lucide],.audience-cta svg{transition:transform .15s}
.audience-cta:hover [data-lucide],.audience-cta:hover svg{transform:translateX(3px)}

/* Story section */
.story-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.story-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:26px;transition:transform .2s,box-shadow .2s,border-color .2s}
.story-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent}
.story-card .feature-icon{margin-bottom:14px}
.story-card h3{font-size:18px;margin-bottom:8px}
.story-card p{font-size:14px;color:var(--muted);line-height:1.65}

/* Step icons (used on About "What we stand for") — keep tiles aligned even though they live inside .step */
.step .feature-icon{margin-bottom:14px}

@media (max-width:640px){
  .audience-head h3{font-size:18px}
  .audience-list li{font-size:14px}
}

/* =========================================================================
   CONTACT PAGE
   ========================================================================= */
.contact-hero{padding:clamp(40px,7vw,72px) 0 clamp(28px,5vw,48px)}
.contact-hero .hero-title{margin-bottom:12px}

.contact-layout{display:grid;grid-template-columns:340px 1fr;gap:28px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:14px}
.contact-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:4px;transition:transform .2s,box-shadow .2s,border-color .2s}
.contact-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:transparent}
.contact-card .feature-icon{width:44px;height:44px;font-size:20px;margin-bottom:8px}
.contact-card .feature-icon [data-lucide],.contact-card .feature-icon svg{width:22px;height:22px}
.contact-card h3{font-size:15px;margin:0}
.contact-card .muted.small{font-size:12px;margin:0}
.contact-card .contact-link{margin-top:6px;font-weight:600;color:var(--primary);font-size:15px;word-break:break-word}
.contact-card a.contact-link:hover{text-decoration:underline}
.contact-card address{font-style:normal;margin-top:6px;font-size:14px;line-height:1.5;color:var(--text)}

.contact-form-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:clamp(22px,3vw,36px);box-shadow:0 12px 40px -16px rgba(209,31,31,.12)}
.form-head{margin-bottom:22px}
.form-head h2{font-size:24px;margin-bottom:6px}
.form-head .muted{font-size:14px}

/* Form v2 */
.form-v2{display:flex;flex-direction:column;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.form-field label{font-size:13px;font-weight:600;color:var(--text)}
.form-field .req{color:var(--bad);font-weight:700}
.input-icon{position:relative;display:flex;align-items:stretch;background:#fff;border:1.5px solid var(--border);border-radius:11px;transition:border-color .15s,box-shadow .15s;overflow:hidden}
.input-icon:hover{border-color:#cbd5e1}
.input-icon:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px rgba(209,31,31,.1)}
.input-icon > [data-lucide],.input-icon > svg{align-self:center;margin-left:14px;color:var(--muted);flex-shrink:0;width:18px;height:18px}
.input-icon input,.input-icon select,.input-icon textarea{flex:1;border:0;outline:0;padding:13px 14px;font-size:15px;background:transparent;font-family:inherit;color:var(--text);min-width:0;width:100%}
.input-icon textarea{resize:vertical;line-height:1.55;padding-top:14px}
.input-icon select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.input-icon.textarea-wrap{align-items:flex-start}
.input-icon.textarea-wrap > [data-lucide],.input-icon.textarea-wrap > svg{margin-top:14px;align-self:flex-start}

/* Error state */
.form-field.has-error .input-icon{border-color:var(--bad);background:#fef2f2}
.form-field.has-error .input-icon > [data-lucide],.form-field.has-error .input-icon > svg{color:var(--bad)}
.form-field.has-error .input-icon:focus-within{box-shadow:0 0 0 4px rgba(220,38,38,.12)}
.error-text{color:var(--bad);font-size:12px;min-height:0;font-weight:500}
.form-field:not(.has-error) .error-text:empty{display:none}
.form-meta{display:flex;justify-content:space-between;gap:8px}
.hint-text{color:var(--muted);font-size:12px;margin-left:auto}

.btn-submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:4px}
.form-foot{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;margin:0}
.form-foot [data-lucide],.form-foot svg{color:var(--good);width:14px;height:14px}

/* FAQ band */
.contact-link-card{display:block;text-decoration:none;color:var(--text)}
.contact-link-card:hover{text-decoration:none}
.contact-link-card .feature-icon{margin-bottom:14px}

@media (max-width:900px){
  .contact-layout{grid-template-columns:1fr;gap:18px}
  .contact-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
  .contact-card{padding:16px}
}
@media (max-width:640px){
  .form-row{grid-template-columns:1fr;gap:14px}
  .contact-form-card{padding:20px}
  .form-head h2{font-size:20px}
  .contact-info{grid-template-columns:1fr 1fr}
  .contact-card .feature-icon{width:38px;height:38px}
}
@media (max-width:420px){
  .contact-info{grid-template-columns:1fr}
}

/* =========================================================================
   SEARCH PAGE (v2)
   ========================================================================= */
.search-hero{padding:clamp(40px,7vw,72px) 0 clamp(28px,5vw,48px)}
.search-hero .hero-title{margin-bottom:12px}
.search-bar-inline{margin-top:18px}

.search-layout-v2{display:grid;grid-template-columns:300px 1fr;gap:28px;padding:clamp(24px,4vw,40px) 16px;align-items:start}

/* Filter trigger button (mobile only) */
.filter-trigger{display:none;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px 16px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;width:fit-content;box-shadow:var(--shadow);transition:border-color .15s}
.filter-trigger:hover{border-color:var(--primary)}
.filter-trigger .filter-count{background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:999px;line-height:1.4}

/* Quick-filter bar (Airbnb-style: Filters button + instant chips) */
.filter-bar{grid-column:1/-1;display:flex;align-items:center;gap:12px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px;margin-bottom:6px}
.filter-bar::-webkit-scrollbar{display:none}
.filter-bar .filter-trigger{flex-shrink:0;margin:0}
.filter-bar-sep{display:none;flex-shrink:0;width:1px;height:30px;background:var(--border)}
.quick-filters{display:flex;align-items:center;gap:8px;min-width:0}
.qf-chip{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--text);font-size:13.5px;font-weight:600;white-space:nowrap;cursor:pointer;text-decoration:none;transition:border-color .15s,background .15s,box-shadow .15s,color .15s}
.qf-chip:hover{border-color:#94a3b8;box-shadow:0 2px 10px -4px rgba(15,23,42,.22);text-decoration:none}
.qf-chip [data-lucide],.qf-chip svg{width:15px;height:15px;color:var(--muted)}
.qf-chip.active{border-color:var(--primary);background:rgba(209,31,31,.07);color:var(--primary)}
.qf-chip.active [data-lucide],.qf-chip.active svg{color:var(--primary)}

/* Filter backdrop (mobile only) */
.filter-backdrop{display:none;position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:90;backdrop-filter:blur(2px)}

/* Filter panel (desktop sidebar) */
.filters-panel{background:#fff;border:1px solid var(--border);border-radius:18px;padding:22px;position:sticky;top:80px;max-height:calc(100vh - 100px);overflow-y:auto;box-shadow:0 6px 24px -10px rgba(209,31,31,.1)}
.filters-panel .panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.filters-panel .panel-head h3{display:flex;align-items:center;gap:8px;font-size:18px;margin:0}
.filters-panel .panel-close{display:none;background:transparent;border:0;cursor:pointer;color:var(--muted);padding:6px;border-radius:8px}
.filters-panel .panel-close:hover{background:#f1f5f9;color:var(--text)}

.filter-form{display:flex;flex-direction:column;gap:22px}
.filter-section{display:flex;flex-direction:column;gap:8px}
.filter-label{font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--muted);text-transform:uppercase}

/* Segmented control for gender */
.seg-control{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:#f1f5f9;border-radius:10px;padding:4px}
.seg-control input{position:absolute;opacity:0;pointer-events:none}
.seg-control label{display:flex;align-items:center;justify-content:center;padding:8px 10px;font-size:14px;font-weight:600;color:var(--muted);border-radius:7px;cursor:pointer;transition:background .15s,color .15s}
.seg-control input:checked + label{background:#fff;color:var(--primary);box-shadow:0 2px 6px rgba(15,23,42,.08)}

/* Budget row */
.budget-row{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}
.budget-row .input-icon{flex:1}
.budget-row .input-icon .rupee{display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--muted);margin-left:14px;width:14px}
.budget-sep{font-size:13px;color:var(--muted)}

/* Amenity chips */
.amen-chips{display:flex;flex-wrap:wrap;gap:8px}
.amen-chip{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1.5px solid var(--border);border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;color:var(--text)}
.amen-chip input{position:absolute;opacity:0;pointer-events:none}
.amen-chip:hover{border-color:#cbd5e1;background:#fef5f5}
.amen-chip:has(input:checked){background:rgba(209,31,31,.08);border-color:var(--primary);color:var(--primary);font-weight:600}
.amen-chip [data-lucide],.amen-chip svg{color:currentColor}

.filter-actions{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.filter-actions .btn{display:inline-flex;align-items:center;justify-content:center;gap:6px}

/* Results pane */
.results-pane{min-width:0}
.results-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.results-head h2{font-size:clamp(20px,3vw,26px);margin:0;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.results-head h2 strong{color:var(--primary)}
.results-head h2 .muted{font-size:.7em;font-weight:500}
.btn-sm{padding:8px 12px;font-size:13px;display:inline-flex;align-items:center;gap:6px}

/* PG cards grid */
.pg-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}

/* PG card v2 */
.pg-card-v2{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .25s,border-color .15s;color:var(--text);text-decoration:none}
.pg-card-v2:hover{transform:translateY(-4px);box-shadow:0 22px 50px -18px rgba(209,31,31,.22);border-color:transparent;text-decoration:none}
.pg-card-v2 .cover{height:200px;background:linear-gradient(135deg,#ee8f8f,#e23b3b);background-size:cover;background-position:center;position:relative}
.pg-card-v2 .cover-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7)}
.pg-card-v2 .cover-fallback [data-lucide],.pg-card-v2 .cover-fallback svg{width:48px;height:48px;stroke-width:1.5}
.pg-card-v2 .badge{position:absolute;top:12px;left:12px;background:#fff;color:var(--primary);padding:5px 10px;border-radius:8px;font-size:11px;font-weight:700;display:inline-flex;align-items:center;gap:4px;box-shadow:0 2px 8px rgba(15,23,42,.12)}
.pg-card-v2 .badge.badge-verified{left:auto;right:12px;background:#dcfce7;color:#166534}
.pg-card-v2 .meta{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1}
.pg-card-v2 .meta-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.pg-card-v2 .meta-head h3{font-size:17px;margin:0;line-height:1.3}
.pg-card-v2 .gender-pill{font-size:11px;font-weight:600;background:#fef5f5;color:var(--primary);padding:3px 8px;border-radius:6px;white-space:nowrap;text-transform:capitalize}
.pg-card-v2 .loc,.pg-card-v2 .rating{font-size:13px;color:var(--muted);margin:0;display:flex;align-items:center;gap:5px}
.pg-card-v2 .rating strong{color:var(--text);font-weight:700}
.pg-card-v2 .amen{display:flex;flex-wrap:wrap;gap:6px}
.pg-card-v2 .amen span{display:inline-flex;align-items:center;gap:4px;background:#f1f5f9;padding:4px 8px;border-radius:6px;font-size:11px;color:#475569}
.pg-card-v2 .price-row{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:auto;padding-top:8px;border-top:1px solid var(--border)}
.pg-card-v2 .price{font-weight:700;color:var(--primary);margin:0;font-size:15px}
.pg-card-v2 .price small{color:var(--muted);font-size:11px;font-weight:500}
.pg-card-v2 .view-link{font-size:13px;font-weight:600;color:var(--primary);display:inline-flex;align-items:center;gap:4px;transition:transform .15s}
.pg-card-v2:hover .view-link [data-lucide],.pg-card-v2:hover .view-link svg{transform:translateX(3px);transition:transform .15s}

/* Empty state */
.empty-state{padding:60px 24px;text-align:center;background:#fff;border:1px dashed var(--border);border-radius:18px;display:flex;flex-direction:column;align-items:center;gap:10px}
.empty-state .empty-icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#fde9e9,#fdeaea);display:flex;align-items:center;justify-content:center;color:var(--primary);margin-bottom:6px}
.empty-state .empty-icon [data-lucide],.empty-state .empty-icon svg{width:32px;height:32px}
.empty-state h3{font-size:18px;margin:0}
.empty-state p{color:var(--muted);font-size:14px;margin:0;max-width:380px}
.empty-state .btn{margin-top:10px;display:inline-flex;align-items:center;gap:6px}

/* Responsive — below 1100px the filter sidebar becomes a slide-in drawer
   (so the search-map layout can stack map-over-list on mobile & tablet).
   The drawer + backdrop sit ABOVE the Leaflet map: Leaflet's controls/panes
   reach z-index ~1000, so the drawer uses 1200 to never be covered. */
@media (max-width:1099px){
  .search-layout-v2{grid-template-columns:1fr}
  .filter-trigger{display:inline-flex}
  .filter-bar-sep{display:block}

  .filter-backdrop{z-index:1190;background:rgba(15,23,42,.5)}
  body.filters-open .filter-backdrop{display:block}

  .filters-panel{
    position:fixed;top:0;right:0;bottom:0;width:min(380px,92vw);max-height:100%;
    display:flex;flex-direction:column;padding:0;border:0;
    border-radius:22px 0 0 22px;overflow:hidden;
    transform:translateX(105%);transition:transform .3s cubic-bezier(.4,0,.2,1);
    z-index:1200;box-shadow:-24px 0 60px -18px rgba(15,23,42,.4);
  }
  body.filters-open .filters-panel{transform:translateX(0)}

  /* Sticky header */
  .filters-panel .panel-head{
    position:sticky;top:0;z-index:2;margin:0;flex-shrink:0;
    padding:18px 20px;background:#fff;border-bottom:1px solid var(--border);
  }
  .filters-panel .panel-head h3{font-size:17px}
  .filters-panel .panel-close{
    display:inline-flex;align-items:center;justify-content:center;
    width:36px;height:36px;border-radius:10px;background:#f1f5f9;color:var(--text);
  }
  .filters-panel .panel-close:hover{background:#e2e8f0;color:var(--primary)}

  /* Scrollable body */
  .filters-panel .filter-form{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px;gap:22px}

  /* Pinned footer actions — always reachable */
  .filters-panel .filter-actions{
    position:sticky;bottom:0;margin:6px -20px 0;
    padding:14px 20px calc(14px + env(safe-area-inset-bottom));
    background:#fff;border-top:1px solid var(--border);
    box-shadow:0 -8px 20px -12px rgba(15,23,42,.2);
  }
  .filters-panel .filter-actions .btn{padding:13px 18px;font-size:15px}

  body.filters-open{overflow:hidden}
}
@media (max-width:640px){
  .pg-cards-grid{grid-template-columns:1fr;gap:14px}
  .pg-card-v2 .cover{height:180px}
  .search-bar-inline{margin-top:14px}
  .results-head h2{font-size:18px}
  .filters-panel{width:100vw;border-radius:0}
}

/* =========================================================================
   SEARCH MAP — Airbnb-style split
   Desktop (>=1100): filters | PG list | sticky map.
   Mobile/tablet (<1100): map banner on top, listings in a sheet over it.
   ========================================================================= */
.results-map{display:block}
/* z-index:0 establishes a stacking context so Leaflet's internal panes/controls
   (z-index 200–1000) stay trapped below the filter drawer (z-index 100) and the
   sticky topbar — otherwise the map bleeds over the open mobile filter drawer. */
.results-map-inner{position:relative;z-index:0;overflow:hidden;background:#e8edf2}
#searchMap{width:100%;height:100%;background:#e8edf2}

@media (min-width:1100px){
  /* Airbnb-style desktop: scrollable 2-up card list on the LEFT, a big sticky
     full-height map on the RIGHT (~45%). Filters move into a slide-in drawer
     opened by the "Filters" button at the top of the list. */
  .search-layout-v2.has-map{grid-template-columns:minmax(0,1.22fr) minmax(0,1fr);gap:24px;padding-top:18px;align-items:start}
  .search-layout-v2.has-map .pg-cards-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px}

  /* Filters button + chip bar across the top (like Airbnb's filter bar) */
  .search-layout-v2.has-map .filter-trigger{display:inline-flex}
  .search-layout-v2.has-map .filter-bar-sep{display:block}

  /* Filters open as a CENTERED MODAL on desktop (Airbnb-style dialog) */
  .search-layout-v2.has-map .filter-backdrop{z-index:1190;background:rgba(15,23,42,.5)}
  body.filters-open .search-layout-v2.has-map .filter-backdrop{display:block}
  .search-layout-v2.has-map .filters-panel{
    position:fixed;top:50%;left:50%;transform:translate(-50%,-46%) scale(.98);
    width:min(780px,92vw);max-height:86vh;height:auto;
    display:flex;flex-direction:column;padding:0;border:0;border-radius:22px;
    overflow:hidden;opacity:0;visibility:hidden;pointer-events:none;
    transition:opacity .22s ease,transform .24s cubic-bezier(.4,0,.2,1),visibility .24s;
    z-index:1200;box-shadow:0 40px 120px -30px rgba(15,23,42,.5);
  }
  body.filters-open .search-layout-v2.has-map .filters-panel{
    opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,-50%) scale(1);
  }
  /* Centered header with the close button on the right */
  .search-layout-v2.has-map .filters-panel .panel-head{position:relative;z-index:2;margin:0;flex-shrink:0;padding:18px 22px;background:#fff;border-bottom:1px solid var(--border);justify-content:center}
  .search-layout-v2.has-map .filters-panel .panel-head h3{font-size:16px;justify-content:center}
  .search-layout-v2.has-map .filters-panel .panel-close{position:absolute;right:16px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#f1f5f9;color:var(--text)}
  .search-layout-v2.has-map .filters-panel .panel-close:hover{background:#e2e8f0;color:var(--primary)}
  .search-layout-v2.has-map .filters-panel .filter-form{flex:1;min-height:0;overflow-y:auto;padding:22px;gap:24px}
  /* Footer: Clear all (left, link) + Apply (right) like Airbnb */
  .search-layout-v2.has-map .filters-panel .filter-actions{flex-direction:row;justify-content:space-between;align-items:center;margin:0;flex-shrink:0;padding:14px 22px;background:#fff;border-top:1px solid var(--border)}
  .search-layout-v2.has-map .filters-panel .filter-actions .btn{width:auto}
  .search-layout-v2.has-map .filters-panel .filter-actions .btn.ghost{order:-1;border:0;background:transparent;box-shadow:none;text-decoration:underline;padding:8px 4px;font-weight:600}
  .search-layout-v2.has-map .filters-panel .filter-actions .btn.ghost:hover{color:var(--primary);transform:none;box-shadow:none}
  .search-layout-v2.has-map .filters-panel .filter-actions .btn.primary{padding:12px 22px}
  body.filters-open{overflow:hidden}

  /* Sticky full-height map on the right */
  .results-map{align-self:start}
  .results-map-inner{position:sticky;top:84px;height:calc(100vh - 104px);border-radius:16px;box-shadow:0 1px 2px rgba(15,23,42,.06),0 12px 32px -16px rgba(15,23,42,.28)}
}

/* Mobile & tablet: full-bleed map banner + listings sheet (Airbnb app style) */
@media (max-width:1099px){
  .search-layout-v2.has-map{gap:0;padding-top:14px}
  .search-layout-v2.has-map .filter-bar{order:1;margin-bottom:14px}
  .search-layout-v2.has-map .results-map{order:2;margin:0 -16px}
  .search-layout-v2.has-map .results-map-inner{height:clamp(300px,46vh,440px)}
  .search-layout-v2.has-map .results-pane{order:3;position:relative;z-index:1;margin:-22px -16px 0;padding:22px 16px 24px;background:#fff;border-radius:22px 22px 0 0;box-shadow:0 -8px 24px -12px rgba(15,23,42,.12)}
  /* Drag-handle pill at the top of the sheet */
  .search-layout-v2.has-map .results-pane::before{content:"";display:block;width:42px;height:5px;border-radius:999px;background:#cbd5e1;margin:-8px auto 16px}
}

/* Shortlist heart on the card photo (Airbnb-style) */
.card-heart{position:absolute;top:12px;right:12px;z-index:2;width:34px;height:34px;padding:0;border:0;border-radius:50%;background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:transform .12s ease}
.card-heart:hover{transform:scale(1.12)}
.card-heart:active{transform:scale(.92)}
.card-heart:disabled{opacity:.6;cursor:default}
.card-heart [data-lucide],.card-heart svg{width:25px;height:25px;color:#fff;fill:rgba(15,23,42,.45);stroke-width:2;filter:drop-shadow(0 1px 3px rgba(15,23,42,.5));transition:fill .15s,color .15s,transform .12s}
.card-heart.active [data-lucide],.card-heart.active svg{fill:var(--primary);color:#fff}
.card-heart.active{animation:heart-pop .28s ease}
@keyframes heart-pop{0%{transform:scale(1)}45%{transform:scale(1.28)}100%{transform:scale(1)}}
/* Keep the verified badge clear of the heart (move it to the bottom-left) */
.pg-card-v2 .badge.badge-verified{top:auto;bottom:12px;left:12px;right:auto}

/* Price marker pills (Airbnb-style: white default, dark when active) */
.pg-price-marker{background:transparent;border:0}
.pg-price-marker span{display:inline-block;background:#fff;color:var(--text);font-weight:600;font-size:13px;line-height:1;padding:7px 11px;border-radius:999px;box-shadow:0 1px 2px rgba(15,23,42,.18),0 2px 8px rgba(15,23,42,.22);border:1px solid rgba(15,23,42,.06);white-space:nowrap;transform:translate(-50%,-50%);transition:transform .14s ease,background .14s,color .14s,box-shadow .14s;cursor:pointer}
.pg-price-marker:hover span{transform:translate(-50%,-50%) scale(1.06)}
.pg-price-marker.is-active span{background:#1f2937;color:#fff;border-color:#1f2937;transform:translate(-50%,-50%) scale(1.08);box-shadow:0 4px 14px rgba(15,23,42,.4)}

/* List card highlight when its marker is hovered/open */
.pg-card-v2.map-hover{border-color:#94a3b8;box-shadow:0 14px 32px -14px rgba(15,23,42,.28)}

/* Map popup mini-card */
.map-pop{display:block;text-decoration:none;color:var(--text);width:240px}
.map-pop:hover{text-decoration:none}
.map-pop-img{width:100%;height:132px;border-radius:12px;background-size:cover;background-position:center;background-color:#f1f5f9;margin-bottom:9px}
.map-pop-img--empty{background:linear-gradient(135deg,#ee8f8f,#e23b3b)}
.map-pop-body{display:flex;flex-direction:column;gap:3px;min-width:0}
.map-pop-body strong{font-size:14.5px;line-height:1.25}
.map-pop-loc{font-size:12.5px;color:var(--muted)}
.map-pop-price{font-size:13.5px;font-weight:700;color:var(--text);margin-top:2px}
.map-pop-price small{color:var(--muted);font-weight:500}
.leaflet-popup-content{margin:0;padding:0}
.leaflet-popup-content-wrapper{border-radius:16px;padding:8px;box-shadow:0 6px 26px -6px rgba(15,23,42,.34)}
.leaflet-popup-close-button{width:26px !important;height:26px !important;background:#fff !important;border-radius:50% !important;top:14px !important;right:14px !important;color:#0f172a !important;box-shadow:0 1px 4px rgba(15,23,42,.3);font-size:18px !important;line-height:24px !important;display:flex !important;align-items:center;justify-content:center}

/* =========================================================================
   AUTH v2  (split-screen login/register)
   ========================================================================= */
/* Hide the global topbar on auth pages (Lucide :has selector trick) */
body:has(.auth-v2) .topbar{display:none}
body:has(.auth-v2){background:#fff}
body:has(.auth-v2) main{min-height:100vh}

.auth-v2{display:grid;grid-template-columns:minmax(420px, 1fr) 1fr;min-height:100vh;background:#fff}

/* LEFT side panel */
.auth-side{position:relative;overflow:hidden;background:linear-gradient(135deg,#d11f1f 0%,#e23b3b 40%,#e23b3b 100%);color:#fff;padding:clamp(28px,4vw,48px);display:flex;flex-direction:column;justify-content:space-between;isolation:isolate}
.auth-side::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 25% 0%,rgba(255,255,255,.16),transparent 40%),radial-gradient(circle at 75% 100%,rgba(255,255,255,.10),transparent 40%);z-index:0}
.auth-side .blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;pointer-events:none;z-index:0}
.auth-side .blob-1{width:380px;height:380px;background:#f8d6d6;top:-100px;right:-120px}
.auth-side .blob-2{width:300px;height:300px;background:#eeacac;bottom:-100px;left:-80px}
.auth-side-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:clamp(20px,4vw,32px);height:100%}
.auth-brand{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:22px;color:#fff;text-decoration:none}
.auth-brand .logo-dot{background:#fff}
.auth-brand-tag{font-weight:500;font-size:12px;background:rgba(255,255,255,.18);color:#fff;padding:3px 8px;border-radius:6px}
.auth-side-content{flex:1;display:flex;flex-direction:column;gap:18px;justify-content:center;max-width:480px}
.auth-side-title{font-size:clamp(28px,4vw,40px);line-height:1.15;font-weight:800;margin:0;letter-spacing:-.01em}
.auth-side-lead{opacity:.92;font-size:15px;line-height:1.6;margin:0}
.auth-side-features{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-direction:column;gap:14px}
.auth-side-features li{display:flex;gap:14px;align-items:flex-start}
.auth-feature-ico{width:38px;height:38px;background:rgba(255,255,255,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.auth-feature-ico [data-lucide],.auth-feature-ico svg{width:18px;height:18px;color:#fff}
.auth-side-features strong{display:block;font-size:14.5px;font-weight:600;margin-bottom:2px}
.auth-side-features span{font-size:13px;opacity:.85}
.auth-side-foot{opacity:.7;position:relative;z-index:1;font-size:12px}
.auth-side-foot a{color:#fff;text-decoration:underline;opacity:.95}

/* RIGHT main panel */
.auth-main{display:flex;align-items:center;justify-content:center;padding:clamp(24px,4vw,48px);background:linear-gradient(180deg,#fff,#fef5f5)}
.auth-card-v2{width:100%;max-width:440px;display:flex;flex-direction:column;gap:20px}
.auth-brand-mobile{display:none;color:var(--primary);font-size:20px;align-items:center;gap:10px;margin-bottom:8px}
.auth-brand-mobile .logo-dot{background:var(--primary)}
.auth-brand-mobile .auth-brand-tag{color:#fff;background:var(--primary)}

.auth-head .kicker{margin-bottom:10px}
.auth-head h1{font-size:clamp(24px,3.5vw,30px);margin:6px 0 6px;line-height:1.2}
.auth-head .muted{font-size:14.5px;margin:0}

.auth-form{gap:14px}
.auth-form .label-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:6px}
.auth-form .label-row label{margin-bottom:0}
.label-link{font-size:12.5px;font-weight:600;color:var(--primary)}
.label-link:hover{text-decoration:underline}

/* Password show/hide toggle */
.pw-toggle{background:transparent;border:0;cursor:pointer;color:var(--muted);padding:8px 14px;display:inline-flex;align-items:center;justify-content:center;align-self:stretch;border-left:1px solid transparent;transition:color .15s}
.pw-toggle:hover{color:var(--primary)}

.remember-row{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--muted);cursor:pointer;margin:-2px 0 2px}
.remember-row input{accent-color:var(--primary)}

.btn-submit{margin-top:6px}
.btn-submit [data-lucide],.btn-submit svg{transition:transform .15s}
.btn-submit:hover [data-lucide],.btn-submit:hover svg{transform:translateX(2px)}

.fb-status{margin:6px 0 0;text-align:center;font-size:13.5px;min-height:0}
.fb-status:empty{display:none}
.fb-status.good{color:var(--good)}
.fb-status.error{color:var(--bad)}

/* "or" divider */
.auth-divider{position:relative;text-align:center;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px;margin:6px 0}
.auth-divider::before,.auth-divider::after{content:"";position:absolute;top:50%;width:calc(50% - 24px);height:1px;background:var(--border)}
.auth-divider::before{left:0}
.auth-divider::after{right:0}
.auth-divider span{background:transparent;padding:0 6px;position:relative;z-index:1}

.auth-alt-actions{display:flex;flex-direction:column;gap:10px}
.auth-alt-actions .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px}

.auth-foot{text-align:center;font-size:14px;color:var(--muted);margin:6px 0 0}
.auth-foot a{font-weight:600;color:var(--primary)}

/* Demo accounts (collapsed by default) */
.auth-demo{border:1px solid var(--border);border-radius:12px;padding:0;background:#fff;margin-top:6px;overflow:hidden}
.auth-demo summary{list-style:none;cursor:pointer;padding:14px 16px;font-size:13.5px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px;user-select:none}
.auth-demo summary::-webkit-details-marker{display:none}
.auth-demo summary .demo-chev{margin-left:auto;transition:transform .2s;color:var(--muted)}
.auth-demo[open] summary .demo-chev{transform:rotate(180deg)}
.demo-list{display:flex;flex-direction:column;gap:6px;padding:0 12px 12px;border-top:1px solid var(--border)}
.demo-item{display:grid;grid-template-columns:1fr auto;column-gap:10px;align-items:baseline;text-align:left;padding:10px 12px;background:#fef5f5;border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:background .15s,border-color .15s;font-family:inherit;margin-top:8px}
.demo-item:hover{background:#fde9e9;border-color:var(--primary)}
.demo-role{font-weight:700;color:var(--primary);font-size:13px}
.demo-email{font-size:12.5px;color:var(--muted);grid-column:1/-1;font-family:ui-monospace,Menlo,Consolas,monospace;margin-top:2px}
.demo-hint{font-size:11px;color:var(--muted);font-weight:500}
.demo-foot{margin:8px 12px 0;font-size:12px}

/* Mobile */
@media (max-width:900px){
  .auth-v2{grid-template-columns:1fr}
  .auth-side{display:none}
  .auth-brand-mobile{display:inline-flex}
  .auth-main{padding:clamp(20px,5vw,32px);align-items:flex-start;padding-top:32px}
}
@media (max-width:520px){
  .auth-card-v2{gap:16px}
  .auth-head h1{font-size:22px}
  .demo-item{padding:8px 10px}
}

/* Register-specific: role cards + password strength */
.role-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.role-cards input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.role-card{display:flex;align-items:center;gap:10px;padding:14px;border:1.5px solid var(--border);border-radius:12px;cursor:pointer;background:#fff;transition:border-color .15s,background .15s,box-shadow .15s;position:relative}
.role-card:hover{border-color:#cbd5e1;background:#fef5f5}
.role-ico{width:40px;height:40px;border-radius:10px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--muted);transition:background .15s,color .15s}
.role-ico [data-lucide],.role-ico svg{width:20px;height:20px}
.role-text{display:flex;flex-direction:column;line-height:1.25;min-width:0;flex:1}
.role-text strong{font-size:14.5px;font-weight:700;color:var(--text)}
.role-text small{font-size:12px;color:var(--muted)}
.role-tick{width:22px;height:22px;border-radius:50%;background:#fff;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,border-color .15s,color .15s;color:transparent}
.role-tick [data-lucide],.role-tick svg{width:14px;height:14px}
.role-cards input[type="radio"]:checked + .role-card{border-color:var(--primary);background:linear-gradient(135deg,#fef5f5,#fef5f5);box-shadow:0 0 0 4px rgba(209,31,31,.08)}
.role-cards input[type="radio"]:checked + .role-card .role-ico{background:linear-gradient(135deg,var(--primary),#e23b3b);color:#fff}
.role-cards input[type="radio"]:checked + .role-card .role-tick{background:var(--primary);border-color:var(--primary);color:#fff}
.role-cards input[type="radio"]:focus-visible + .role-card{outline:2px solid var(--primary);outline-offset:2px}

/* Password strength meter */
.pw-strength{display:flex;align-items:center;gap:10px;margin-top:6px}
.pw-strength-track{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}
.pw-strength-fill{height:100%;width:0;background:var(--bad);border-radius:3px;transition:width .25s,background .25s}
.pw-strength-fill.weak  {background:#dc2626}
.pw-strength-fill.fair  {background:#f59e0b}
.pw-strength-fill.good  {background:#10b981}
.pw-strength-fill.strong{background:#059669}
.pw-strength-label{font-size:12px;font-weight:600;color:var(--muted);min-width:60px;text-align:right}

/* Terms row error state */
.terms-row.has-error{color:var(--bad)}
.terms-row.has-error input[type="checkbox"]{outline:2px solid var(--bad);outline-offset:2px;border-radius:3px}

@media (max-width:520px){
  .role-cards{grid-template-columns:1fr}
  .role-card{padding:12px}
}

/* =========================================================================
   PG DETAIL v3  (NoBroker-style: top strip + gallery tabs + meta cards)
   ========================================================================= */
.pg-v3{padding:clamp(14px,2vw,24px) 16px clamp(80px,10vw,60px)}

/* TOP HEADER STRIP */
.pg-strip{display:grid;grid-template-columns:1fr auto auto;gap:18px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px 20px;margin-bottom:14px;box-shadow:0 4px 18px -8px rgba(15,23,42,.08)}
.pg-strip-id{display:flex;align-items:center;gap:14px;min-width:0}
.pg-strip-icon{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,#fde9e9,#fdeaea);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}
.pg-strip-icon [data-lucide],.pg-strip-icon svg{width:24px;height:24px}
.pg-strip-meta{min-width:0;display:flex;flex-direction:column;gap:4px}
.pg-strip-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pg-strip-title-row h1{font-size:clamp(18px,2.5vw,24px);margin:0;font-weight:800;line-height:1.2;letter-spacing:-.01em}
.pg-verified{display:inline-flex;align-items:center;gap:3px;background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534;padding:3px 8px;border-radius:7px;font-size:11.5px;font-weight:700}
.pg-strip-addr{margin:0;font-size:13.5px;color:var(--muted);display:inline-flex;align-items:center;gap:5px;flex-wrap:wrap}
.pg-strip-addr strong{color:var(--text);font-weight:700}
.pg-meta-sep{opacity:.4;padding:0 2px}
.rating-star{color:#f59e0b;fill:#f59e0b}

.pg-strip-stats{display:flex;gap:8px}
.pg-strip-stat{background:#f8fafc;border:1px solid var(--border);border-radius:11px;padding:8px 16px;text-align:center;min-width:110px}
.pg-strip-stat span{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:2px}
.pg-strip-stat strong{display:block;font-size:16px;font-weight:800;color:var(--text)}
.pg-strip-cta{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}

/* BREADCRUMB */
.pg-crumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);margin-bottom:18px;flex-wrap:wrap}
.pg-crumb a{color:var(--muted);text-decoration:none}
.pg-crumb a:hover{color:var(--primary)}
.pg-crumb span{opacity:.5}
.pg-crumb .crumb-current{color:var(--text);font-weight:600;opacity:1}

/* MAIN GRID: gallery + meta */
.pg-main-grid{display:grid;grid-template-columns:minmax(0, 1.6fr) minmax(280px, 380px);gap:20px;align-items:stretch;margin-bottom:32px}

/* GALLERY PANE */
.gallery-pane{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.gallery-tabs{display:flex;gap:0;background:#fff;border-bottom:1px solid var(--border);padding:0;overflow-x:auto}
.gallery-tab{background:transparent;border:0;padding:14px 20px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;gap:8px;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap;flex-shrink:0;font-family:inherit}
.gallery-tab small{font-size:11px;background:#f1f5f9;padding:2px 7px;border-radius:6px;font-weight:600;color:var(--muted)}
.gallery-tab:hover{color:var(--text)}
.gallery-tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.gallery-tab.active small{background:rgba(209,31,31,.1);color:var(--primary)}
.gallery-panel{flex:1;min-height:380px;display:flex;flex-direction:column}
.gallery-panel[hidden]{display:none}

/* Photo collage */
.gallery-collage{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:6px;padding:6px;height:100%;min-height:380px}
.gallery-collage[data-count="1"]{grid-template-columns:1fr;grid-template-rows:1fr}
.gallery-collage[data-count="2"]{grid-template-rows:1fr}
.gallery-collage[data-count="3"] .g-main{grid-row:1 / 3}
.g-cell{position:relative;display:block;background-size:cover;background-position:center;background-color:#e2e8f0;border-radius:8px;overflow:hidden;transition:filter .15s}
.g-cell:hover{filter:brightness(.92)}
.g-main{grid-row:1 / 3;grid-column:1}
.gallery-collage[data-count="1"] .g-main{grid-row:auto;grid-column:auto}
.g-overlay-btn{position:absolute;top:12px;left:12px;background:rgba(15,23,42,.7);color:#fff;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:5px;backdrop-filter:blur(4px)}
.g-more{position:absolute;inset:0;background:rgba(15,23,42,.6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:24px;backdrop-filter:blur(2px)}
.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);min-height:380px;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}
.gallery-empty [data-lucide],.gallery-empty svg{width:48px;height:48px;stroke-width:1.5}

/* 360° tour panel */
.tour-room-tabs{display:flex;gap:8px;padding:14px 16px 0;flex-wrap:wrap;overflow-x:auto}
.tour-room-tab{background:#f1f5f9;color:var(--text);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s;font-family:inherit;white-space:nowrap}
.tour-room-tab:hover{background:#e2e8f0}
.tour-room-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.tour-stage{position:relative;flex:1;min-height:360px;background:#000;margin:14px 6px 6px;border-radius:8px;overflow:hidden}
.pg-360-pano,.pg-360-iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:#000}
.tour-fs-btn{position:absolute;top:12px;right:12px;display:inline-flex;align-items:center;gap:5px;background:rgba(15,23,42,.7);color:#fff;border:1px solid rgba(255,255,255,.15);padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;backdrop-filter:blur(6px);z-index:2}
.tour-fs-btn:hover{background:rgba(15,23,42,.9)}
.tour-hint{margin:6px 14px 12px;display:inline-flex;align-items:center;gap:5px}

/* Location panel */
.map-stage{flex:1;min-height:380px;width:100%;background:#e2e8f0;position:relative}
.map-stage .leaflet-container{height:100%;width:100%}
.map-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid var(--border);background:#fafbfc;flex-wrap:wrap}
.map-addr-line{margin:0;font-size:13px;color:var(--muted);display:inline-flex;align-items:center;gap:5px;min-width:0}
.map-fallback{flex:1;min-height:380px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:linear-gradient(135deg,#fde9e9,#fdeaea);color:var(--text);text-align:center;padding:24px}
.map-fallback [data-lucide],.map-fallback svg{width:36px;height:36px;color:var(--primary)}

/* META PANE (right side) */
.meta-pane{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:16px}
.meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.meta-card{display:flex;gap:10px;align-items:center;padding:10px 4px;border-bottom:1px solid var(--border);min-width:0}
.meta-card:nth-last-child(-n+2){border-bottom:0}
.meta-ico{color:var(--muted);flex-shrink:0;width:20px;height:20px}
.meta-card > div{display:flex;flex-direction:column;min-width:0;line-height:1.25}
.meta-card strong{font-size:14px;font-weight:700;color:var(--text);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}
.meta-card small{font-size:11.5px;color:var(--muted)}

.meta-cta-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;padding-top:8px;border-top:1px solid var(--border)}
.meta-cta-main{display:inline-flex;align-items:center;justify-content:center;gap:6px}
.meta-icon-btn{width:48px;height:48px;border-radius:11px;background:#fff;border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;color:var(--primary);transition:background .15s,border-color .15s}
.meta-icon-btn:hover{background:#fef5f5;border-color:var(--primary);text-decoration:none}

.meta-trust{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--muted)}
.meta-trust span{display:inline-flex;align-items:center;gap:4px;background:#f8fafc;padding:5px 10px;border-radius:7px}
.meta-trust [data-lucide],.meta-trust svg{color:var(--good)}

/* SECONDARY GRID (below main): content + activity */
.pg-secondary-grid{display:grid;grid-template-columns:minmax(0, 1fr) 320px;gap:28px;align-items:start}
.pg-content{min-width:0}
.pg-section{padding-top:24px;margin-top:24px;border-top:1px solid var(--border)}
.pg-section:first-of-type{border-top:0;margin-top:0;padding-top:0}
.pg-section h2{font-size:clamp(18px,2.5vw,22px);margin-bottom:14px;font-weight:700}
.pg-description{color:#334155;line-height:1.75;font-size:15px}

/* Activity pane */
.activity-pane{position:sticky;top:80px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:14px}
.activity-title{font-size:16px;margin:0;padding-bottom:12px;border-bottom:1px solid var(--border);font-weight:700}
.activity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.activity-stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:10px 4px;gap:4px;background:#f8fafc;border-radius:10px}
.activity-stat [data-lucide],.activity-stat svg{color:var(--primary)}
.activity-stat strong{font-size:18px;font-weight:800;color:var(--text);line-height:1}
.activity-stat small{font-size:11px;color:var(--muted);line-height:1.2}
.activity-tour{padding:12px;background:linear-gradient(135deg,#fef5f5,#fef5f5);border-radius:10px;border:1px solid #fde9e9}
.activity-tour-head{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-weight:600;color:var(--primary)}
.activity-tour p{margin:0;line-height:1.5}

/* Amenities v2 */
.amenities-v2{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;padding:0;margin:0}
.amenities-v2 li{display:flex;gap:12px;align-items:center;background:#fff;padding:12px 14px;border-radius:12px;border:1px solid var(--border);font-size:14px;font-weight:500;transition:border-color .15s,transform .15s}
.amenities-v2 li:hover{border-color:transparent;transform:translateY(-1px);box-shadow:var(--shadow)}
.amenities-v2 .ami-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.amenities-v2 .ami-icon [data-lucide],.amenities-v2 .ami-icon svg{width:18px;height:18px}
.ami-icon-1{background:linear-gradient(135deg,#fde9e9,#f7d8d8);color:#b81f1f}
.ami-icon-2{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}
.ami-icon-3{background:linear-gradient(135deg,#fdeaea,#f8d6d6);color:#c21f1f}
.ami-icon-4{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}
.ami-icon-5{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309}
.ami-icon-6{background:linear-gradient(135deg,#fdeaea,#f7d8d8);color:#8f1717}

/* Rooms v2 */
.rooms-grid-v2{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-top:14px}
.room-card-v2{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:12px;transition:transform .15s,box-shadow .2s,border-color .15s}
.room-card-v2:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:transparent}
.room-card-v2 .room-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.room-id{display:flex;flex-direction:column;gap:2px}
.room-num{font-size:15px;font-weight:700}
.room-card-v2 .room-tags{display:flex;flex-wrap:wrap;gap:6px;min-height:22px}
.room-card-v2 .room-tags span{display:inline-flex;align-items:center;gap:4px;background:#f1f5f9;padding:4px 10px;border-radius:7px;font-size:11.5px;color:#475569;font-weight:500}
.room-card-v2 .room-tags .tag-360{background:linear-gradient(135deg,#fde9e9,#fdeaea);color:var(--primary);font-weight:600}
.room-card-v2 .room-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:auto;padding-top:10px;border-top:1px dashed var(--border)}
.room-card-v2 .room-price{font-weight:800;font-size:18px;color:var(--primary)}
.room-card-v2 .room-price small{font-size:11px;color:var(--muted);font-weight:500;margin-left:2px}
.room-card-v2 .room-360-btn{padding:6px 10px;font-size:12.5px;font-weight:600;border-radius:8px;display:inline-flex;align-items:center;gap:4px}

/* Reviews v2 */
.reviews-v2{display:flex;flex-direction:column;gap:10px}
.review-card-v2{background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px}
.review-card-v2 .review-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px;flex-wrap:wrap}
.review-stars{display:inline-flex;align-items:center;gap:2px}
.review-stars .star-fill{color:#f59e0b;fill:#f59e0b}
.review-stars .star-empty{color:#e2e8f0}
.review-stars .rating-num{margin-left:8px;font-weight:700;font-size:13px;color:var(--text)}
.review-stars .review-name{margin-right:8px;font-size:13.5px;font-weight:700;color:var(--text)}
.review-card-v2 p{font-size:14.5px;color:#334155;line-height:1.65;margin:0}

/* Tenant review submission */
.rf-wrap{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.rf-trigger{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:#fff;border:1px solid var(--border);border-radius:13px;padding:12px 14px;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s}
.rf-trigger:hover{border-color:var(--primary);box-shadow:0 4px 14px rgba(209,31,31,.09)}
.rf-trigger.open{background:#fff7f7;border-color:var(--primary)}
.rf-trigger-ic{flex:none;width:42px;height:42px;border-radius:11px;background:rgba(209,31,31,.1);color:var(--primary);display:flex;align-items:center;justify-content:center}
.rf-trigger-ic svg{width:21px;height:21px}
.rf-trigger-text{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}
.rf-trigger-text strong{font-size:14.5px;color:var(--text)}
.rf-trigger-text small{font-size:12.5px;color:var(--muted)}
.rf-trigger-chev{flex:none;color:var(--muted);transition:transform .22s}
.rf-trigger.open .rf-trigger-chev{transform:rotate(180deg)}
.review-form{margin-top:12px;padding:16px;border:1px solid var(--border);border-radius:13px;background:#fafafa;animation:rfReveal .2s ease}
@keyframes rfReveal{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.review-form .rf-label{display:block;font-size:12.5px;font-weight:700;color:var(--text);margin:0 0 7px}
.review-form .rf-label:not(:first-child){margin-top:14px}
.rf-stars{display:inline-flex;flex-direction:row-reverse;justify-content:flex-end;gap:2px}
.rf-stars input{position:absolute;opacity:0;width:0;height:0}
.rf-stars label{cursor:pointer;color:#d1d5db;line-height:0;padding:2px;transition:color .12s}
.rf-stars label svg{width:30px;height:30px;stroke:currentColor;fill:currentColor}
.rf-stars label:hover,.rf-stars label:hover ~ label,.rf-stars input:checked ~ label{color:#f59e0b}
.review-form textarea{display:block;width:100%;box-sizing:border-box;padding:11px 13px;border:1px solid var(--border);border-radius:11px;font-family:inherit;font-size:14px;line-height:1.55;resize:vertical;min-height:78px}
.review-form textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(209,31,31,.12)}
.rf-submit{margin-top:10px;display:inline-flex;align-items:center;gap:7px;background:var(--primary);color:#fff;border:0;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer}
.rf-submit:hover{filter:brightness(.95)}
.review-login-cta{margin-top:16px;padding:12px 14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:9px;font-size:13.5px;color:#475569}
.review-login-cta a{color:var(--primary);font-weight:600}

/* Empty state in PG detail */
.pg-content .empty-state{margin-top:14px}

/* Leaflet attribution polish (inside .map-stage) */
.map-stage .leaflet-control-attribution{background:rgba(255,255,255,.7);font-size:9px;padding:1px 4px;color:#94a3b8;line-height:1.2}
.map-stage .leaflet-control-attribution a{color:#94a3b8;text-decoration:none}

/* Empty inline (legacy fallback) */
.empty-inline{padding:20px;background:#f8fafc;border-radius:10px;color:var(--muted);text-align:center;font-size:14px}

/* Per-room 360° modal viewer */
.room360-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center}
.room360-modal.open{display:flex}
.room360-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.78);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.room360-dialog{position:relative;background:#0f172a;color:#fff;width:min(1100px,95vw);max-height:92vh;border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.5);overflow:hidden;display:flex;flex-direction:column}
.room360-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.1)}
.room360-head h3{margin:0;font-size:16px;font-weight:600;color:#fff}
.room360-close{background:transparent;border:0;color:#fff;cursor:pointer;padding:6px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.room360-close [data-lucide],.room360-close svg{width:22px;height:22px}
.room360-close:hover{background:rgba(255,255,255,.1)}
.room360-body{position:relative;background:#000;height:min(70vh,640px)}
.room360-pano,.room360-iframe{width:100%;height:100%;display:none;border:0;background:#000}
.room360-hint{margin:0;padding:8px 18px;text-align:center;color:#94a3b8;background:#0b1220}
@media (max-width:640px){
  .room360-body{height:min(60vh,480px)}
  .room360-dialog{width:96vw}
}

/* Mobile sticky booking bar */
.pg-mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);padding:10px 16px;justify-content:space-between;align-items:center;gap:12px;z-index:80;box-shadow:0 -8px 24px -10px rgba(15,23,42,.12);padding-bottom:max(10px,env(safe-area-inset-bottom))}
.pg-mobile-price{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.pg-mobile-price strong{font-size:18px;font-weight:800;color:var(--text)}
.pg-mobile-price strong small{font-size:12px;color:var(--muted);font-weight:500}
.pg-mobile-bar .btn{display:inline-flex;align-items:center;gap:6px;padding:11px 18px;font-size:14px}

/* Responsive */
@media (max-width:1024px){
  .pg-strip{grid-template-columns:1fr;gap:14px}
  .pg-strip-stats{justify-content:flex-start}
  .pg-strip-cta{justify-self:start}
  .pg-main-grid{grid-template-columns:1fr}
  .pg-secondary-grid{grid-template-columns:1fr}
  .activity-pane{position:static}
}
@media (max-width:640px){
  .gallery-collage{grid-template-rows:180px 80px 80px;grid-template-columns:1fr 1fr;min-height:340px}
  .gallery-collage .g-main{grid-row:1;grid-column:1 / -1}
  .gallery-collage[data-count="1"]{grid-template-rows:220px;min-height:220px}
  .gallery-panel,.tour-stage,.map-stage,.gallery-empty,.map-fallback{min-height:320px}
  .pg-strip{padding:14px;border-radius:12px}
  .pg-strip-icon{width:42px;height:42px}
  .pg-strip-stats{flex-wrap:wrap}
  .pg-strip-stat{padding:6px 12px;min-width:auto;flex:1}
  .pg-mobile-bar{display:flex}
  .gallery-tab{padding:12px 14px;font-size:13px}
  .meta-grid{grid-template-columns:1fr 1fr}
  .activity-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:420px){
  .gallery-collage{grid-template-rows:160px 70px}
  .gallery-collage .g-cell:nth-child(n+4){display:none}
  .room-card-v2 .room-foot{flex-direction:column;align-items:stretch;gap:6px}
  .room-card-v2 .room-360-btn{width:100%;justify-content:center}
  .meta-grid{grid-template-columns:1fr}
  .pg-strip-title-row h1{font-size:16px}
}

/* =========================================================================
   PG DETAIL — NoBroker-style layout (.pg-nb)
   ========================================================================= */
.pg-nb{padding:clamp(14px,2vw,24px) 16px clamp(80px,10vw,60px)}

/* TOP HEADER STRIP */
.nb-strip{display:grid;grid-template-columns:1fr auto auto auto;gap:14px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 18px;margin-bottom:12px;box-shadow:0 4px 18px -8px rgba(15,23,42,.08)}
.nb-strip-id{display:flex;align-items:center;gap:14px;min-width:0}
.nb-strip-icon{width:50px;height:50px;border-radius:12px;background:linear-gradient(135deg,#fde9e9,#fdeaea);display:flex;align-items:center;justify-content:center;color:var(--primary);font-weight:800;font-size:14px;flex-shrink:0;letter-spacing:.5px}
.nb-strip-meta{min-width:0;display:flex;flex-direction:column;gap:2px}
.nb-strip-meta h1{font-size:clamp(16px,2vw,20px);margin:0;font-weight:800;line-height:1.2;letter-spacing:-.01em;color:var(--text)}
.nb-strip-addr{margin:0;font-size:12.5px;color:var(--muted);line-height:1.3}
.nb-strip-stat{text-align:center;min-width:110px;border-left:1px solid var(--border);padding:6px 16px 6px}
.nb-strip-stat:first-of-type{border-left:0}
.nb-strip-stat strong{display:block;font-size:18px;font-weight:800;color:var(--text);line-height:1.1}
.nb-strip-stat span{display:block;font-size:11px;color:var(--muted);font-weight:500;margin-top:2px}
.nb-cta-red{display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#fff !important;font-weight:700;font-size:14px;padding:12px 22px;border-radius:8px;text-decoration:none;border:0;cursor:pointer;transition:background .15s,transform .15s;white-space:nowrap;line-height:1.2}
.nb-cta-red:hover{background:var(--primary-dark);transform:translateY(-1px);text-decoration:none}

/* BREADCRUMB */
.nb-crumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);margin:0 4px 14px;flex-wrap:wrap}
.nb-crumb a{color:var(--muted);text-decoration:none}
.nb-crumb a:hover{color:var(--primary);text-decoration:underline}
.nb-crumb span{opacity:.5}
.nb-crumb .nb-crumb-current{color:var(--text);font-weight:600;opacity:1}

/* MAIN GRID: gallery + meta */
.nb-main-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(280px,400px);gap:16px;align-items:start;margin-bottom:18px}

/* GALLERY */
.nb-gallery{position:relative;display:flex;flex-direction:column;min-height:480px}
.nb-collage{position:relative;display:grid;grid-template-columns:1.6fr 1fr;grid-template-rows:1fr 1fr;gap:8px;flex:1;min-height:480px}
.nb-panel{display:contents}
.nb-panel[hidden]{display:none !important}

/* Overlay tabs on top of gallery (Photos / Location) — z-index above Leaflet (panes use 200–700) */
.nb-overlay-tabs{position:absolute;top:14px;left:14px;display:flex;gap:8px;z-index:1000}
.nb-overlay-tab{background:rgba(15,23,42,.72);color:#fff;border:0;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:background .15s}
.nb-overlay-tab:hover{background:rgba(15,23,42,.9)}
.nb-overlay-tab.active{background:#0f172a}

/* Shortlist top-right */
.nb-shortlist{position:absolute;top:14px;right:14px;background:rgba(15,23,42,.72);color:#fff;border:0;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:1000;transition:background .15s}
.nb-shortlist:hover{background:rgba(15,23,42,.9)}
.nb-shortlist.active{background:var(--primary);color:#fff}
.nb-shortlist.active [data-lucide],.nb-shortlist.active svg{fill:#fff}

/* 360° overlay button on main image */
.nb-360-overlay{position:absolute;bottom:14px;left:14px;background:rgba(255,255,255,.95);color:#0f172a;border:0;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;box-shadow:0 4px 16px -4px rgba(15,23,42,.3);transition:transform .15s,box-shadow .2s;z-index:1000}
.nb-360-overlay:hover{transform:translateY(-1px);box-shadow:0 6px 20px -4px rgba(15,23,42,.4)}
.nb-360-overlay small{background:var(--primary);color:#fff;padding:1px 7px;border-radius:8px;font-size:11px;font-weight:700;margin-left:2px}

/* Photo cells */
.ng-cell{position:relative;display:block;background-size:cover;background-position:center;background-color:#e2e8f0;border-radius:12px;overflow:hidden;transition:filter .15s}
.ng-cell:hover{filter:brightness(.92)}
.ng-main{grid-row:1/3;grid-column:1}
.ng-top{grid-row:1;grid-column:2}
.ng-bot{grid-row:2;grid-column:2}
.ng-more{position:absolute;inset:0;background:rgba(15,23,42,.6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:28px;backdrop-filter:blur(2px)}

/* Location panel (full area) */
.nb-panel-location.active{display:block !important;grid-column:1/-1;grid-row:1/-1}
.nb-panel-location.active .nb-map-stage,.nb-panel-location.active .nb-map-fallback{height:100%;min-height:480px;border-radius:12px;overflow:hidden}
.nb-map-stage{width:100%;background:#e2e8f0;position:relative}
.nb-map-stage .leaflet-container{height:100%;width:100%}
.nb-map-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:linear-gradient(135deg,#fde9e9,#fdeaea);color:var(--text);text-align:center;padding:24px}
.nb-map-fallback [data-lucide],.nb-map-fallback svg{width:36px;height:36px;color:var(--primary)}

.nb-collage-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);min-height:480px;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:12px}
.nb-collage-empty [data-lucide],.nb-collage-empty svg{width:48px;height:48px;stroke-width:1.5}

/* META PANE (right side) */
.nb-meta{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:14px}
.nb-meta-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.nb-meta-card{display:flex;gap:10px;align-items:center;padding:14px 12px;background:#fff;border-right:1px solid var(--border);border-bottom:1px solid var(--border);min-width:0}
.nb-meta-card:nth-child(2n){border-right:0}
.nb-meta-card:nth-last-child(-n+2){border-bottom:0}
.nb-meta-card [data-lucide],.nb-meta-card svg{color:#64748b;flex-shrink:0;width:22px;height:22px}
.nb-meta-card > div{display:flex;flex-direction:column;min-width:0;line-height:1.25;gap:1px}
.nb-meta-card strong{font-size:13.5px;font-weight:700;color:var(--text);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}
.nb-meta-card small{font-size:11.5px;color:var(--muted)}

.nb-cta-block{width:100%}
.nb-cta-icons{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.nb-icon-btn{width:100%;height:44px;border-radius:8px;background:#ecfdf5;border:1px solid #d1fae5;display:inline-flex;align-items:center;justify-content:center;color:#059669;transition:background .15s}
.nb-icon-btn:hover{background:#d1fae5;text-decoration:none}

.nb-report{padding-top:12px;border-top:1px solid var(--border)}
.nb-report-head{display:flex;align-items:center;gap:6px;font-size:13px;color:#475569;margin-bottom:10px}
.nb-report-head [data-lucide],.nb-report-head svg{color:#10b981}
.nb-report-actions{display:flex;gap:8px;flex-wrap:wrap}
.nb-report-btn{flex:1;min-width:0;background:#fff;border:1px solid var(--border);color:#334155;font-size:12.5px;font-weight:600;padding:8px 6px;border-radius:6px;cursor:pointer;transition:border-color .15s,background .15s;white-space:nowrap;font-family:inherit}
.nb-report-btn:hover{border-color:var(--primary);background:#fef5f5;color:var(--primary)}
.nb-report-btn.reported{background:#dcfce7;border-color:#86efac;color:#166534;cursor:default}
.nb-report-btn.reported:hover{background:#dcfce7;color:#166534}
.nb-report-msg{margin:10px 0 0;font-size:12.5px;color:#166534}
.nb-report-msg.error{color:#b91c1c}

/* Live activity */
.nb-side-title{display:flex;align-items:center;justify-content:space-between;gap:8px}
.nb-activity-live{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#16a34a;background:#dcfce7;padding:3px 8px;border-radius:6px}
.nb-activity-dot{width:6px;height:6px;background:#16a34a;border-radius:50%;animation:nb-pulse 1.6s infinite}
@keyframes nb-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.75)}}
.nb-stat-bump{animation:nb-bump .4s ease}
@keyframes nb-bump{0%{transform:scale(1);color:var(--primary)}40%{transform:scale(1.18);color:var(--primary)}100%{transform:scale(1);color:var(--text)}}

/* SECONDARY GRID */
.nb-secondary-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:18px;align-items:start;margin-top:18px}
.nb-content{min-width:0;display:flex;flex-direction:column;gap:14px}
.nb-side{display:flex;flex-direction:column;gap:14px;position:sticky;top:80px}
.nb-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:20px}
.nb-card-title{font-size:18px;margin:0 0 14px;font-weight:700;color:var(--text);border-bottom:2px solid var(--primary);display:inline-block;padding-bottom:6px;padding-right:18px}
.nb-description{color:#334155;line-height:1.7;font-size:14.5px;margin:0}

/* Single room details */
.nb-room-row{display:flex;gap:42px;flex-wrap:wrap;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.nb-room-info{display:flex;flex-direction:column;gap:2px}
.nb-room-price{font-size:20px;font-weight:800;color:var(--text)}
.nb-room-price small{font-size:13px;font-weight:500;color:var(--muted);margin-left:1px}
.nb-room-sub{font-size:14px;margin:0 0 10px;font-weight:600;color:#334155}
.nb-amenities-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}
.nb-amenity-tile{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;font-size:12.5px;font-weight:600;color:#475569;line-height:1.3}
.nb-amenity-tile [data-lucide],.nb-amenity-tile svg{width:26px;height:26px;color:#f59e0b}

/* Side cards */
.nb-side-title{font-size:16px;margin:0 0 14px;font-weight:700;color:var(--text)}
.nb-activity-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px}
.nb-activity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.nb-activity-stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 6px;background:#f8fafc;border-radius:10px;text-align:center}
.nb-activity-stat [data-lucide],.nb-activity-stat svg{color:#64748b;margin-bottom:2px}
.nb-activity-stat strong{font-size:18px;font-weight:800;color:var(--text);line-height:1}
.nb-activity-stat small{font-size:11px;color:var(--muted);line-height:1.2}
.nb-activity-foot{margin:10px 0 0;text-align:right;font-size:11px}
.nb-activity-foot strong{color:var(--primary);font-weight:700}

.nb-society-title{font-size:14px;margin:0 0 14px;font-weight:700;color:var(--text);border-bottom:2px solid var(--primary);display:inline-block;padding-bottom:5px;padding-right:14px}

/* 360 modal extras */
.room360-tabs{display:flex;gap:8px;padding:10px 18px;background:#0b1220;border-bottom:1px solid rgba(255,255,255,.08);flex-wrap:wrap}
.room360-tab{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:6px 12px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}
.room360-tab:hover{background:rgba(255,255,255,.15)}
.room360-tab.active{background:var(--primary);border-color:var(--primary)}

/* Responsive */
@media (max-width:1024px){
  .nb-main-grid{grid-template-columns:1fr}
  .nb-gallery,.nb-collage,.nb-collage-empty{min-height:380px}
  .nb-collage{min-height:380px}
  .nb-secondary-grid{grid-template-columns:1fr}
  .nb-side{position:static}
}
@media (max-width:760px){
  .nb-strip{grid-template-columns:1fr;gap:10px}
  .nb-strip-stat{border-left:0;border-top:1px solid var(--border);padding:8px 0;min-width:0;text-align:left;display:flex;justify-content:space-between;align-items:center}
  .nb-strip-stat strong{font-size:16px}
  .nb-cta-red{width:100%}
  .nb-collage{grid-template-columns:1fr;grid-template-rows:240px 100px 100px;gap:6px;min-height:auto}
  .ng-main{grid-row:1;grid-column:1}
  .ng-top{grid-row:2;grid-column:1}
  .ng-bot{grid-row:3;grid-column:1}
  .nb-meta-grid{grid-template-columns:1fr}
  .nb-meta-card{border-right:0}
  .nb-meta-card:nth-last-child(2){border-bottom:1px solid var(--border)}
  .nb-overlay-tabs,.nb-shortlist{top:10px}
  .nb-overlay-tabs{left:10px}
  .nb-shortlist{right:10px;padding:6px 12px;font-size:12px}
  .nb-overlay-tab{padding:6px 12px;font-size:12px}
  .nb-360-overlay{bottom:10px;left:10px;padding:7px 12px;font-size:12px}
}
@media (max-width:420px){
  .nb-amenities-tiles{grid-template-columns:repeat(2,1fr)}
  .nb-room-row{gap:20px}
  .nb-card{padding:14px}
  .nb-activity-grid{gap:6px}
  .nb-activity-stat{padding:10px 4px}
}

/* Make image cells (buttons) reset native styling */
.ng-cell{border:0;padding:0;font:inherit;color:inherit;text-align:left;cursor:pointer;width:100%;height:100%}

/* =========================================================================
   EXPLORE NEIGHBOURHOOD (.nb-neighbourhood)
   ========================================================================= */
.nb-neighbourhood .nb-nh-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:6px}
.nb-nh-tab{flex:1;background:transparent;border:0;padding:14px 12px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;font-family:inherit}
.nb-nh-tab:hover{color:var(--text)}
.nb-nh-tab.active{color:var(--primary);border-bottom-color:var(--primary)}

.nb-nh-panels{padding-top:8px}
.nb-nh-panel[hidden]{display:none}
.nb-nh-loading{padding:24px;text-align:center;color:var(--muted);font-size:13.5px}
.nb-nh-error{padding:14px;background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:8px}

.nb-nh-group{border:1px solid var(--border);border-radius:10px;background:#fff;margin-top:10px;overflow:hidden}
.nb-nh-group:first-child{margin-top:0}
.nb-nh-group > summary{display:flex;align-items:center;gap:12px;padding:14px 16px;font-size:14.5px;font-weight:700;color:var(--text);cursor:pointer;list-style:none;user-select:none}
.nb-nh-group > summary::-webkit-details-marker{display:none}
.nb-nh-group > summary > [data-lucide]:first-child,.nb-nh-group > summary > svg:first-child{color:var(--primary);width:20px;height:20px;flex-shrink:0}
.nb-nh-group > summary > span{flex:1;color:var(--primary)}
.nb-nh-group > summary .nb-nh-empty{flex:0 0 auto;font-weight:500;color:var(--muted)}
.nb-nh-group > summary .nb-nh-chev{width:18px;height:18px;color:var(--muted);transition:transform .2s;flex-shrink:0}
.nb-nh-group[open] > summary .nb-nh-chev{transform:rotate(180deg)}
.nb-nh-group[open] > summary > span{color:var(--text)}
.nb-nh-group[open] > summary > [data-lucide]:first-child,.nb-nh-group[open] > summary > svg:first-child{color:var(--text)}

.nb-nh-list{list-style:none;margin:0;padding:0 16px 12px}
.nb-nh-list li{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:10px 0;border-top:1px solid var(--border);font-size:14px}
.nb-nh-list li:first-child{border-top:1px solid var(--border)}
.nb-nh-name{color:var(--text);line-height:1.3;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nb-nh-dist{color:var(--muted);font-size:13px;white-space:nowrap}

@media (max-width:520px){
  .nb-nh-tab{padding:12px 6px;font-size:13px}
  .nb-nh-list li{font-size:13px;gap:8px}
  .nb-nh-dist{font-size:12px}
}

/* =========================================================================
   PHOTO LIGHTBOX (.nb-lb)
   ========================================================================= */
.nb-lb{position:fixed;inset:0;z-index:10000;background:#0b0b0d;display:none;flex-direction:column;color:#fff}
.nb-lb.open{display:flex}

/* Top bar */
.nb-lb-top{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;gap:16px;flex-wrap:wrap}
.nb-lb-title h2{margin:0;font-size:17px;font-weight:600;color:#fff;line-height:1.2}
.nb-lb-actions{display:flex;align-items:center;gap:14px}
.nb-lb-price{font-size:15px;font-weight:600;color:#fff}
.nb-lb-cta{padding:9px 18px;font-size:13px}
.nb-lb-close{background:transparent;border:0;color:#fff;cursor:pointer;padding:6px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;line-height:1;transition:background .15s}
.nb-lb-close:hover{background:rgba(255,255,255,.08)}
.nb-lb-close [data-lucide],.nb-lb-close svg{width:22px;height:22px}

/* Sub-bar (share + shortlist) */
.nb-lb-subbar{display:flex;justify-content:space-between;align-items:center;padding:0 24px 12px;gap:12px;flex-wrap:wrap}
.nb-lb-share{display:inline-flex;align-items:center;gap:8px}
.nb-lb-share-label{font-size:13px;color:#cbd5e1;margin-right:4px}
.nb-lb-share-btn{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:#fff;background:#1e293b;transition:transform .12s,background .15s}
.nb-lb-share-btn:hover{transform:translateY(-1px);text-decoration:none}
.nb-lb-share-btn [data-lucide],.nb-lb-share-btn svg{width:16px;height:16px}
.nb-lb-fb{background:#1877f2}
.nb-lb-wa{background:#25d366}
.nb-lb-tw{background:#1da1f2}
.nb-lb-em{background:#64748b}
.nb-lb-shortlist{background:transparent;border:0;color:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;padding:6px 10px;border-radius:6px;font-family:inherit;transition:background .15s}
.nb-lb-shortlist:hover{background:rgba(255,255,255,.06)}
.nb-lb-shortlist [data-lucide],.nb-lb-shortlist svg{width:18px;height:18px;color:#fff}
.nb-lb-shortlist.active [data-lucide],.nb-lb-shortlist.active svg{color:var(--primary);fill:var(--primary)}

/* Progress / tab bar */
.nb-lb-progress{padding:0 24px 10px;display:flex;align-items:center;justify-content:space-between;gap:14px}
.nb-lb-progress-bar{flex:1;height:2px;background:rgba(255,255,255,.12);border-radius:2px;overflow:hidden}
.nb-lb-progress-fill{height:100%;background:var(--primary);width:0%;transition:width .25s ease}
.nb-lb-counter{font-size:13px;color:#cbd5e1;font-weight:500;white-space:nowrap}

/* Stage */
.nb-lb-stage{position:relative;flex:1;display:flex;align-items:center;justify-content:center;min-height:0;padding:0 16px}
.nb-lb-track{position:relative;width:100%;height:100%;max-width:1400px;display:flex;align-items:center;justify-content:center}
.nb-lb-slide{display:none;width:100%;height:100%;align-items:center;justify-content:center}
.nb-lb-slide.active{display:flex}
.nb-lb-slide img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}

.nb-lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.92);border:0;color:#0f172a;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;z-index:3;transition:background .15s,transform .12s;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.nb-lb-nav:hover{background:#fff;transform:translateY(-50%) scale(1.06)}
.nb-lb-nav [data-lucide],.nb-lb-nav svg{width:22px;height:22px}
.nb-lb-prev{left:24px}
.nb-lb-next{right:24px}

/* Thumbs */
.nb-lb-thumbs{display:flex;gap:8px;padding:14px 24px;overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}
.nb-lb-thumbs::-webkit-scrollbar{height:6px}
.nb-lb-thumbs::-webkit-scrollbar-track{background:transparent}
.nb-lb-thumbs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}
.nb-lb-thumb{flex:0 0 96px;height:64px;border-radius:6px;border:2px solid transparent;background:#1e293b center/cover no-repeat;cursor:pointer;padding:0;transition:border-color .15s,opacity .15s;opacity:.6}
.nb-lb-thumb:hover{opacity:.85}
.nb-lb-thumb.active{border-color:var(--primary);opacity:1}

/* Responsive lightbox */
@media (max-width:640px){
  .nb-lb-top{padding:12px 14px}
  .nb-lb-title h2{font-size:14px}
  .nb-lb-price{font-size:13px}
  .nb-lb-cta{padding:7px 12px;font-size:12px}
  .nb-lb-subbar,.nb-lb-progress{padding-left:14px;padding-right:14px}
  .nb-lb-nav{width:36px;height:36px}
  .nb-lb-prev{left:8px}
  .nb-lb-next{right:8px}
  .nb-lb-thumbs{padding:10px 14px}
  .nb-lb-thumb{flex-basis:72px;height:48px}
}

/* =========================================================================
   SHORTLIST PAGE (.sl-*)
   ========================================================================= */
.sl-page{padding:clamp(20px,3vw,40px) 16px 60px}
.sl-head{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--border)}
.sl-head h1{margin:0 0 4px;font-size:clamp(20px,2.4vw,26px);display:inline-flex;align-items:center;gap:8px}
.sl-head h1 [data-lucide],.sl-head h1 svg{color:var(--primary)}
.sl-head p{margin:0}

.sl-empty{padding:48px 24px;text-align:center;background:#fff;border:1px dashed var(--border);border-radius:18px;display:flex;flex-direction:column;align-items:center;gap:12px}
.sl-empty-ico{width:78px;height:78px;border-radius:20px;background:linear-gradient(135deg,#fde9e9,#fdeaea);display:flex;align-items:center;justify-content:center;color:var(--primary);margin-bottom:4px}
.sl-empty-ico [data-lucide],.sl-empty-ico svg{width:38px;height:38px}
.sl-empty h2{margin:0;font-size:20px;font-weight:700}
.sl-empty p{color:var(--muted);max-width:420px;margin:0 0 6px;line-height:1.5}

.sl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.sl-card{position:relative;background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .2s,opacity .2s}
.sl-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px -16px rgba(15,23,42,.18)}
.sl-card.sl-removing{opacity:0;transform:scale(.96)}
.sl-cover{position:relative;display:block;height:170px;background:#e2e8f0 center/cover no-repeat;text-decoration:none}
.sl-cover-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted);background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}
.sl-cover-fallback [data-lucide],.sl-cover-fallback svg{width:36px;height:36px}
.sl-badge{position:absolute;top:10px;left:10px;background:rgba(15,23,42,.78);color:#fff;padding:4px 10px;border-radius:6px;font-size:11.5px;font-weight:700;backdrop-filter:blur(6px)}
.sl-remove{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:#fff;color:var(--primary);border:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px -4px rgba(15,23,42,.3);transition:transform .12s,background .15s}
.sl-remove:hover{transform:scale(1.06)}
.sl-remove [data-lucide],.sl-remove svg{width:18px;height:18px}
.sl-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px}
.sl-body h3{margin:0;font-size:15.5px;font-weight:700;line-height:1.3}
.sl-body h3 a{color:var(--text);text-decoration:none}
.sl-body h3 a:hover{color:var(--primary)}
.sl-addr{margin:0;font-size:13px;color:var(--muted);display:inline-flex;align-items:center;gap:4px;line-height:1.3}
.sl-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:8px;padding-top:10px;border-top:1px dashed var(--border)}
.sl-price{font-weight:800;color:var(--primary);font-size:17px}
.sl-price small{font-weight:500;font-size:12px;color:var(--muted);margin-left:1px}

/* Nav heart link */
/* Icon-only action button (e.g. Shortlist heart in the header) */
.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:12px;
  background:rgba(255,255,255,.6);border:1px solid var(--border);
  color:var(--text);flex-shrink:0;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,color .18s ease;
}
.icon-btn:hover{
  color:var(--primary);border-color:var(--primary);background:#fff;
  box-shadow:0 4px 14px rgba(209,31,31,.18);transform:translateY(-1px);text-decoration:none;
}
.icon-btn [data-lucide],.icon-btn svg{width:18px;height:18px}
.nav-shortlist{display:inline-flex;align-items:center;justify-content:center}

/* Shortlisted state styling (PG detail + lightbox heart icons) */
.nb-shortlist.active [data-lucide],.nb-shortlist.active svg{fill:#fff}
.nb-lb-shortlist.active [data-lucide],.nb-lb-shortlist.active svg{color:var(--primary);fill:var(--primary)}

@media (max-width:480px){
  .sl-grid{grid-template-columns:1fr;gap:14px}
  .sl-cover{height:200px}
}

/* =========================================================================
   PGTribes Services, PG Rules, Similar Properties
   ========================================================================= */
.nb-services{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px}
.nb-service{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:18px 12px;border-radius:12px;color:var(--text);text-decoration:none;font-weight:600;font-size:13px;line-height:1.35;transition:background .15s,transform .12s}
.nb-service:hover{background:#fef5f5;transform:translateY(-2px);text-decoration:none}
.nb-service-ico{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,#fde9e9,#fdeaea);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.nb-service-ico [data-lucide],.nb-service-ico svg{width:22px;height:22px}
.nb-service-tag{position:absolute;top:6px;right:12px;background:#dc2626;color:#fff;font-size:9.5px;font-weight:700;padding:2px 6px;border-radius:5px;letter-spacing:.4px}

.nb-rules-tiles .nb-rule-tile [data-lucide],.nb-rules-tiles .nb-rule-tile svg{color:#dc2626}

.nb-similar-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px}
.nb-similar-list{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.nb-similar{display:grid;grid-template-columns:88px 1fr;gap:10px;align-items:stretch;padding:8px;border-radius:10px;text-decoration:none;color:inherit;border:1px solid transparent;transition:border-color .15s,background .15s}
.nb-similar:hover{border-color:var(--border);background:#fef5f5;text-decoration:none}
.nb-similar-img{height:88px;border-radius:8px;background:#1f2937 center/cover no-repeat;background-image:linear-gradient(135deg,#1e293b,#0f172a)}
.nb-similar-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.nb-similar-info strong{font-size:13.5px;font-weight:700;line-height:1.25;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nb-similar-info p{margin:0;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nb-similar-tag{display:inline-block;font-size:10.5px;font-weight:700;color:var(--primary);background:#fde9e9;padding:2px 7px;border-radius:5px;margin-top:3px;align-self:flex-start}
.nb-similar-row{display:flex;gap:14px;margin-top:6px;justify-content:space-between}
.nb-similar-row > div{display:flex;flex-direction:column;line-height:1.15}
.nb-similar-row small{font-size:10.5px;color:var(--muted)}
.nb-similar-row strong{font-size:13px;color:var(--text);font-weight:700}
.nb-similar-deposit{text-align:right}
.nb-similar-more{display:block;text-align:center;padding:10px;margin-top:12px;background:var(--primary);color:#fff !important;font-size:13px;font-weight:700;border-radius:8px;text-decoration:none}
.nb-similar-more:hover{background:var(--primary-dark);text-decoration:none}

@media (max-width:520px){
  .nb-services{grid-template-columns:repeat(3,1fr);gap:10px}
  .nb-service{padding:12px 6px;font-size:12px}
  .nb-service-ico{width:38px;height:38px}
}

/* =========================================================================
   GET DIRECTIONS BAR (.nb-dir-bar)
   ========================================================================= */
.nb-dir-bar{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px 14px 10px 18px;margin:0 0 18px;flex-wrap:nowrap;box-shadow:0 4px 14px -10px rgba(15,23,42,.08)}
.nb-dir-pin{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:#fde9e9;color:var(--primary);display:inline-flex;align-items:center;justify-content:center}
.nb-dir-pin [data-lucide],.nb-dir-pin svg{width:18px;height:18px;fill:var(--primary)}
.nb-dir-label{flex-shrink:0;font-weight:700;font-size:14.5px;color:var(--text);white-space:nowrap}
.nb-dir-input-wrap{flex:1;min-width:0;position:relative}
.nb-dir-input{width:100%;border:1px solid var(--border);border-radius:8px;padding:10px 38px 10px 14px;font:inherit;font-size:14px;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s;outline:none;font-family:inherit}
.nb-dir-input::placeholder{color:#94a3b8}
.nb-dir-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(209,31,31,.12)}
.nb-dir-btn{flex-shrink:0;background:#fff;color:var(--primary);border:1.5px solid var(--primary);border-radius:8px;padding:10px 22px;font-weight:700;font-size:14px;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}
.nb-dir-btn:hover{background:var(--primary);color:#fff}

.nb-dir-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:50%;background:transparent;color:#94a3b8;border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s}
.nb-dir-clear:hover{background:#f1f5f9;color:#475569}
.nb-dir-clear [data-lucide],.nb-dir-clear svg{width:16px;height:16px}

.nb-dir-sugg{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 18px 40px -16px rgba(15,23,42,.25);max-height:340px;overflow-y:auto;z-index:50;list-style:none;margin:0;padding:6px}
.nb-dir-sugg[hidden]{display:none}
.nb-dir-sugg-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:13.5px;color:var(--text);line-height:1.35}
.nb-dir-sugg-item:hover,.nb-dir-sugg-item.active{background:#f8fafc}
.nb-dir-sugg-ico{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:#f1f5f9;color:#64748b;display:inline-flex;align-items:center;justify-content:center}
.nb-dir-sugg-ico [data-lucide],.nb-dir-sugg-ico svg{width:14px;height:14px}
.nb-dir-sugg-text{flex:1;min-width:0;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nb-dir-sugg-text strong{font-weight:700;color:var(--text)}
.nb-dir-sugg-rest{color:#475569;font-weight:400}
.nb-dir-sugg-tag{flex-shrink:0;font-size:11.5px;font-weight:600;color:#059669;background:#fff;border:1px solid #a7f3d0;padding:3px 10px;border-radius:999px}
.nb-dir-empty{padding:12px 14px;color:var(--muted);font-size:13px}

/* =========================================================================
   OWNER REVEAL CARD
   ========================================================================= */
.nb-owner-card{background:#fef5f5;border:1px solid #f7d8d8;border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:12px}
.nb-owner-card[hidden]{display:none}
.nb-owner-head{display:flex;align-items:center;gap:10px}
.nb-owner-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#e34a4a);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;flex-shrink:0}
.nb-owner-id{display:flex;flex-direction:column;line-height:1.2}
.nb-owner-id strong{font-size:14.5px;font-weight:700;color:var(--text)}
.nb-owner-id small{font-size:11.5px;color:var(--muted)}
.nb-owner-actions{display:flex;flex-direction:column;gap:6px}
.nb-owner-action{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid var(--border);border-radius:8px;color:var(--text);text-decoration:none;font-size:13.5px;font-weight:600;transition:border-color .15s,background .15s}
.nb-owner-action:hover{border-color:var(--primary);background:#fff;color:var(--primary);text-decoration:none}
.nb-owner-action [data-lucide],.nb-owner-action svg{color:var(--primary)}

/* =========================================================================
   GENERIC MODAL (.nb-modal)
   ========================================================================= */
.nb-modal{position:fixed;inset:0;z-index:9000;display:none;align-items:center;justify-content:center;padding:14px}
.nb-modal.open{display:flex}
.nb-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.nb-modal-dialog{position:relative;background:#fff;width:min(520px,100%);max-height:92vh;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 60px -20px rgba(15,23,42,.4)}
.nb-modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border)}
.nb-modal-head h3{margin:0;font-size:16px;font-weight:700;display:inline-flex;align-items:center;gap:8px}
.nb-modal-close{background:transparent;border:0;color:#475569;cursor:pointer;padding:6px;border-radius:6px;display:inline-flex;align-items:center;line-height:1;transition:background .15s}
.nb-modal-close:hover{background:#f1f5f9}
.nb-modal-close [data-lucide],.nb-modal-close svg{width:20px;height:20px}
.nb-modal-body{padding:16px 18px;overflow-y:auto}
.nb-modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px;border-top:1px solid var(--border);background:#fafbfc}

/* Visit picker */
.nb-visit-block{margin-top:10px}
.nb-visit-block:first-child{margin-top:0}
.nb-visit-block h4{margin:0 0 8px;font-size:13px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.4px}
.nb-visit-dates{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}
.nb-visit-date{flex-shrink:0;background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:10px 14px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:64px;font-family:inherit;transition:border-color .15s,background .15s,transform .12s}
.nb-visit-date:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}
.nb-visit-date.active{background:var(--primary);border-color:var(--primary);color:#fff}
.nb-visit-date .dow{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;opacity:.85}
.nb-visit-date .dnum{font-size:20px;font-weight:800;line-height:1}
.nb-visit-date .mon{font-size:11px;font-weight:500;opacity:.7}

.nb-visit-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}
.nb-visit-slot{background:#fff;border:1.5px solid var(--border);border-radius:8px;padding:9px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;font-family:inherit;transition:border-color .15s,color .15s,background .15s}
.nb-visit-slot:hover{border-color:var(--primary);color:var(--primary)}
.nb-visit-slot.active{background:var(--primary);border-color:var(--primary);color:#fff}
.nb-visit-input{width:100%;border:1px solid var(--border);border-radius:8px;padding:10px 12px;font:inherit;font-size:14px;color:var(--text);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}
.nb-visit-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(209,31,31,.12)}
textarea.nb-visit-input{resize:vertical;min-height:80px;line-height:1.5}

.nb-visit-msg{margin:12px 0 0;padding:10px;background:#dcfce7;border:1px solid #86efac;border-radius:8px;color:#166534;font-size:13px}
.nb-visit-msg.error{background:#fee2e2;border-color:#fecaca;color:#b91c1c}

/* =========================================================================
   CHAT MODAL (.nb-chat)
   ========================================================================= */
.nb-chat{position:fixed;inset:0;z-index:9100;display:none;align-items:flex-end;justify-content:flex-end;padding:14px}
.nb-chat.open{display:flex}
.nb-chat-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.nb-chat-dialog{position:relative;background:#fff;width:min(400px,100%);height:min(620px,92vh);border-radius:14px;display:flex;flex-direction:column;box-shadow:0 24px 60px -20px rgba(15,23,42,.4);overflow:hidden}
.nb-chat-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#fef5f5,#fef5f5)}
.nb-chat-id{display:flex;align-items:center;gap:10px}
.nb-chat-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#e34a4a);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;flex-shrink:0}
.nb-chat-id strong{display:block;font-size:14px;font-weight:700;line-height:1.2;color:var(--text)}
.nb-chat-id small{display:block;font-size:11.5px;line-height:1.2}
.nb-chat-body{flex:1;overflow-y:auto;padding:14px;background:#f8fafc;display:flex;flex-direction:column;gap:8px}
.nb-chat-loading{text-align:center;padding:14px}
.nb-chat-empty{text-align:center;padding:32px 16px}
.nb-chat-msg{display:flex;flex-direction:column;max-width:80%;gap:2px}
.nb-chat-msg.mine{align-self:flex-end;align-items:flex-end}
.nb-chat-msg.theirs{align-self:flex-start;align-items:flex-start}
.nb-chat-bubble{padding:9px 13px;border-radius:14px;font-size:13.5px;line-height:1.4;word-wrap:break-word}
.nb-chat-msg.mine .nb-chat-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}
.nb-chat-msg.theirs .nb-chat-bubble{background:#fff;color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}
.nb-chat-msg.pending .nb-chat-bubble{opacity:.7}
.nb-chat-msg.failed .nb-chat-bubble{background:#fee2e2;color:#991b1b}
.nb-chat-time{font-size:10.5px;color:var(--muted);margin:0 4px}
.nb-chat-form{display:flex;align-items:center;gap:8px;padding:10px;border-top:1px solid var(--border);background:#fff}
.nb-chat-form input{flex:1;min-width:0;border:1px solid var(--border);border-radius:999px;padding:9px 16px;font:inherit;font-size:13.5px;background:#f8fafc;outline:none;transition:border-color .15s,background .15s}
.nb-chat-form input:focus{border-color:var(--primary);background:#fff}
.nb-chat-send{width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,transform .12s}
.nb-chat-send:hover{background:var(--primary-dark);transform:translateY(-1px)}
.nb-chat-send [data-lucide],.nb-chat-send svg{width:18px;height:18px}

@media (max-width:520px){
  .nb-chat{padding:0}
  .nb-chat-dialog{width:100%;height:100%;border-radius:0}
  .nb-modal-dialog{width:100%}
}

@media (max-width:640px){
  .nb-dir-bar{flex-wrap:wrap;gap:10px;padding:12px}
  .nb-dir-label{order:1;flex-basis:auto}
  .nb-dir-input-wrap{order:3;flex-basis:100%}
  .nb-dir-btn{order:4;width:100%}
  .nb-dir-pin{order:0}
}

/* ============================================================
   Real-time engine (firebase-realtime.js) — notification bell + toast
   ============================================================ */
[data-notif-bell]{position:relative;display:inline-block;margin-right:10px}
.zb-bell-btn{background:transparent;border:none;cursor:pointer;font-size:20px;padding:4px 8px;border-radius:6px;position:relative;line-height:1}
.zb-bell-btn:hover{background:rgba(0,0,0,.06)}
.zb-bell-badge{position:absolute;top:-2px;right:-2px;background:#dc2626;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;padding:0 4px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center}
.zb-bell-panel{position:absolute;right:0;top:calc(100% + 8px);width:320px;max-height:420px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.15);overflow:hidden;display:none;z-index:9999}
.zb-bell-panel.open{display:flex;flex-direction:column}
.zb-bell-head{padding:10px 14px;font-weight:600;border-bottom:1px solid #f1f5f9;background:#f8fafc;color:#0f172a}
.zb-bell-list{overflow-y:auto;flex:1}
.zb-bell-empty{padding:24px 14px;text-align:center;color:#64748b;font-size:13px}
.zb-bell-item{padding:10px 14px;border-bottom:1px solid #f1f5f9;font-size:13px;color:#334155}
.zb-bell-item.unread{background:#fef9c3}
.zb-bell-title{font-weight:600;color:#0f172a;margin-bottom:2px}
.zb-bell-msg{color:#475569;line-height:1.4}
.zb-bell-time{font-size:11px;color:#94a3b8;margin-top:4px}

.zb-toast{position:fixed;right:20px;bottom:20px;background:#0f172a;color:#fff;padding:12px 16px;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.25);max-width:320px;font-size:13px;line-height:1.4;opacity:0;transform:translateY(20px);transition:opacity .3s,transform .3s;z-index:10000;pointer-events:none}
.zb-toast.show{opacity:1;transform:translateY(0)}
.zb-toast strong{display:block;margin-bottom:2px;font-size:14px}

/* Tighten layout when bell is dropped into the tenant/staff small header */
.t-header [data-notif-bell]{margin-right:6px}
.t-header [data-notif-bell] .zb-bell-panel{right:-40px;width:min(320px,calc(100vw - 24px))}

/* In-flight submit button spinner */
.zb-spinner{display:inline-block;width:12px;height:12px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:zb-spin .65s linear infinite;vertical-align:-2px;margin-right:6px}
@keyframes zb-spin{to{transform:rotate(360deg)}}
[data-zb-busy]{opacity:.7;cursor:wait}


/* =================================================================
   SUPPORT PAGE
   ================================================================= */

/* Hero with live chat side-panel */
.support-hero{
  position:relative;overflow:hidden;
  background:radial-gradient(900px 500px at 0% 0%, rgba(232,90,90,.18), transparent 60%),
             radial-gradient(700px 400px at 100% 20%, rgba(226,59,59,.14), transparent 60%),
             linear-gradient(180deg, #fffafa 0%, #fef3f3 100%);
  padding:64px 0 56px;
}
.support-hero-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start;
}
.support-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(34,197,94,.1);color:#15803d;
  border:1px solid rgba(34,197,94,.25);
  padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;
}
.pulse-dot{
  width:8px;height:8px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,.7);
  animation:pulseDot 2s infinite;
}
@keyframes pulseDot{
  0%{box-shadow:0 0 0 0 rgba(34,197,94,.6)}
  70%{box-shadow:0 0 0 10px rgba(34,197,94,0)}
  100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}
}
.support-hero-text h1{
  font-size:44px;line-height:1.1;margin:16px 0 10px;
  color:#0f172a;font-weight:800;letter-spacing:-.02em;
}
.support-hero-text .lead{font-size:17px;color:#475569;max-width:46ch;margin-bottom:24px}

.support-search{
  position:relative;display:flex;align-items:center;gap:0;
  background:#fff;border:1px solid #e2e8f0;border-radius:14px;
  box-shadow:0 4px 20px -8px rgba(15,23,42,.1);
  padding:6px 6px 6px 44px;max-width:520px;
}
.support-search-icon{position:absolute;left:16px;color:#94a3b8}
.support-search input{
  flex:1;border:none;outline:none;background:transparent;
  padding:12px 8px;font-size:15px;color:#0f172a;
}
.support-search input::placeholder{color:#94a3b8}
.support-search button{
  background:linear-gradient(135deg,#e85a5a,#e23b3b);
  color:#fff;border:none;padding:10px 22px;border-radius:10px;
  font-weight:600;font-size:14px;cursor:pointer;
  transition:transform .15s, box-shadow .2s;
}
.support-search button:hover{transform:translateY(-1px);box-shadow:0 8px 20px -8px rgba(226,59,59,.5)}

.support-meta{display:flex;flex-wrap:wrap;gap:6px 22px;margin-top:18px}
.support-meta span{display:inline-flex;align-items:center;gap:6px;color:#475569;font-size:13px}
.support-meta strong{color:#0f172a}

/* ---------- Chat widget ---------- */
.support-chat{
  display:flex;flex-direction:column;
  background:#fff;border:1px solid #e2e8f0;border-radius:20px;
  box-shadow:0 30px 80px -30px rgba(209,31,31,.35), 0 8px 24px -12px rgba(15,23,42,.1);
  overflow:hidden;min-height:520px;max-height:620px;
}
.sc-head{
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(135deg,#d11f1f 0%,#e23b3b 60%,#e23b3b 130%);
  color:#fff;padding:16px 18px;
}
.sc-agent{display:flex;align-items:center;gap:12px}
.sc-avatar{
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.18);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:13px;letter-spacing:.05em;
  border:1px solid rgba(255,255,255,.25);
}
.sc-agent-name{font-weight:700;font-size:15px;display:flex;align-items:center;gap:8px}
.sc-online{color:#86efac;font-size:10px;line-height:1;text-shadow:0 0 8px #4ade80}
.sc-agent-sub{font-size:12px;opacity:.85;margin-top:2px}
.sc-min{
  background:rgba(255,255,255,.12);border:none;color:#fff;
  width:32px;height:32px;border-radius:8px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.sc-min:hover{background:rgba(255,255,255,.22)}

.sc-body{
  flex:1;overflow-y:auto;padding:20px 16px;
  background:linear-gradient(180deg,#fffafa 0%, #fdf4f4 100%);
  display:flex;flex-direction:column;gap:12px;
  scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent;
}
.sc-body::-webkit-scrollbar{width:6px}
.sc-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}

.sc-msg{display:flex;flex-direction:column;max-width:78%}
.sc-msg.bot{align-self:flex-start}
.sc-msg.me{align-self:flex-end;align-items:flex-end}
.sc-bubble{
  padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5;
  word-wrap:break-word;white-space:pre-wrap;
}
.sc-msg.bot .sc-bubble{
  background:#fff;color:#0f172a;border:1px solid #e2e8f0;
  border-bottom-left-radius:4px;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.sc-msg.me .sc-bubble{
  background:linear-gradient(135deg,#e23b3b,#d11f1f);color:#fff;
  border-bottom-right-radius:4px;
}
.sc-ts{font-size:11px;color:#94a3b8;margin-top:4px;padding:0 6px}

.sc-typing .sc-bubble{display:inline-flex;gap:4px;padding:14px 14px}
.sc-typing .sc-bubble span{
  width:6px;height:6px;background:#94a3b8;border-radius:50%;
  animation:scDot 1.2s infinite ease-in-out;
}
.sc-typing .sc-bubble span:nth-child(2){animation-delay:.2s}
.sc-typing .sc-bubble span:nth-child(3){animation-delay:.4s}
@keyframes scDot{
  0%,60%,100%{transform:translateY(0);opacity:.4}
  30%{transform:translateY(-4px);opacity:1}
}

.sc-quick{display:flex;flex-wrap:wrap;gap:6px;padding:4px 0 4px}
.sc-quick button{
  background:#fff;border:1px solid #e2e8f0;color:#d11f1f;
  padding:7px 12px;border-radius:999px;font-size:13px;cursor:pointer;
  transition:all .15s;
}
.sc-quick button:hover{background:#fef4f4;border-color:#f3bcbc;transform:translateY(-1px)}

.sc-input{
  display:flex;align-items:center;gap:8px;padding:12px;
  background:#fff;border-top:1px solid #e2e8f0;
}
.sc-input input{
  flex:1;border:1px solid #e2e8f0;border-radius:12px;
  padding:10px 14px;font-size:14px;outline:none;
  transition:border-color .15s;
}
.sc-input input:focus{border-color:#ee8f8f;box-shadow:0 0 0 3px rgba(238,143,143,.15)}
.sc-attach,.sc-send{
  width:40px;height:40px;border-radius:10px;border:none;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.sc-attach{background:#f1f5f9;color:#64748b}
.sc-attach:hover{background:#e2e8f0;color:#0f172a}
.sc-send{background:linear-gradient(135deg,#e23b3b,#d11f1f);color:#fff}
.sc-send:hover{transform:translateY(-1px);box-shadow:0 8px 18px -8px rgba(226,59,59,.55)}

.sc-foot{
  display:flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 12px;background:#fffafa;border-top:1px solid #f1f5f9;
  color:#94a3b8;font-size:11px;
}

.sc-collapsed .sc-body,
.sc-collapsed .sc-input,
.sc-collapsed .sc-foot{display:none}

/* ---------- Channels grid ---------- */
.support-channels{padding:80px 16px 24px}
.sec-title{font-size:32px;font-weight:800;letter-spacing:-.02em;color:#0f172a;margin:0 0 8px}
.sec-sub{color:#64748b;font-size:16px;margin:0 0 32px;max-width:60ch}
.ch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.ch-card{
  display:block;background:#fff;border:1px solid #e2e8f0;border-radius:16px;
  padding:24px;text-decoration:none;color:inherit;
  transition:transform .2s, box-shadow .2s, border-color .2s;
}
.ch-card:hover{
  transform:translateY(-4px);border-color:#f3bcbc;
  box-shadow:0 20px 40px -20px rgba(209,31,31,.25);
}
.ch-card h3{font-size:18px;font-weight:700;color:#0f172a;margin:14px 0 6px}
.ch-card p{color:#64748b;font-size:14px;line-height:1.5;margin:0 0 14px}
.ch-icon{
  width:48px;height:48px;border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;
}
.ch-icon svg{width:22px;height:22px}
.ch-wa{background:linear-gradient(135deg,#25d366,#128c7e)}
.ch-call{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}
.ch-mail{background:linear-gradient(135deg,#e85a5a,#d11f1f)}
.ch-ticket{background:linear-gradient(135deg,#e23b3b,#b81f1f)}
.ch-cta{display:inline-flex;align-items:center;gap:6px;color:#d11f1f;font-weight:600;font-size:14px}

/* ---------- Topics grid ---------- */
.support-topics{padding:64px 16px}
.topic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.topic{
  display:flex;align-items:center;gap:14px;
  background:#fff;border:1px solid #e2e8f0;border-radius:14px;
  padding:18px 20px;text-decoration:none;
  transition:all .15s;
}
.topic:hover{border-color:#f3bcbc;background:#fffafa;transform:translateX(2px)}
.topic > svg, .topic > i{color:#d11f1f;flex-shrink:0}
.topic strong{display:block;color:#0f172a;font-size:15px;font-weight:600;margin-bottom:2px}
.topic small{color:#64748b;font-size:13px}

/* ---------- FAQ ---------- */
.support-faq{padding:48px 16px 64px}
.faq-list{display:flex;flex-direction:column;gap:10px;max-width:880px}
.faq-list details{
  background:#fff;border:1px solid #e2e8f0;border-radius:12px;
  padding:0;overflow:hidden;transition:border-color .15s;
}
.faq-list details[open]{border-color:#f3bcbc}
.faq-list summary{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:16px 20px;cursor:pointer;font-weight:600;color:#0f172a;
  font-size:15px;list-style:none;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-chev{color:#94a3b8;transition:transform .2s}
.faq-list details[open] .faq-chev{transform:rotate(180deg);color:#d11f1f}
.faq-list p{padding:0 20px 18px;margin:0;color:#475569;line-height:1.6;font-size:14px}
.faq-list a{color:#d11f1f;text-decoration:underline}

/* ---------- Ticket card ---------- */
.support-ticket{padding:24px 0 80px;background:#fffafa}
.ticket-card{
  display:grid;grid-template-columns:1fr 1.2fr;gap:48px;
  background:#fff;border:1px solid #e2e8f0;border-radius:24px;
  padding:48px;margin-top:32px;
  box-shadow:0 30px 80px -40px rgba(209,31,31,.2);
}
.ticket-left h2{font-size:28px;font-weight:800;color:#0f172a;margin:0 0 10px;letter-spacing:-.01em}
.ticket-left p{color:#64748b;line-height:1.6;margin:0 0 24px}
.ticket-perks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.ticket-perks li{display:flex;align-items:center;gap:10px;color:#0f172a;font-size:14px}
.ticket-perks li svg{color:#22c55e;background:rgba(34,197,94,.12);padding:4px;border-radius:50%;box-sizing:content-box}

.ticket-form{display:flex;flex-direction:column;gap:16px}
.ticket-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ticket-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#0f172a;font-size:13px}
.ticket-form input,
.ticket-form select,
.ticket-form textarea{
  width:100%;padding:11px 14px;border:1px solid #e2e8f0;border-radius:10px;
  font-size:14px;color:#0f172a;background:#fff;font-family:inherit;
  outline:none;transition:border-color .15s, box-shadow .15s;
}
.ticket-form input:focus,
.ticket-form select:focus,
.ticket-form textarea:focus{border-color:#ee8f8f;box-shadow:0 0 0 3px rgba(238,143,143,.15)}
.ticket-form textarea{resize:vertical;min-height:120px}
.form-err{color:#dc2626;font-weight:500;font-size:12px;margin-top:2px}
.ticket-submit{
  align-self:flex-start;display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,#e23b3b,#d11f1f);color:#fff;
  padding:12px 24px;border-radius:12px;border:none;cursor:pointer;
  font-weight:600;font-size:15px;
  box-shadow:0 8px 20px -8px rgba(226,59,59,.5);
  transition:transform .15s, box-shadow .2s;
}
.ticket-submit:hover{transform:translateY(-1px);box-shadow:0 12px 24px -10px rgba(226,59,59,.6)}

/* Responsive */
@media (max-width: 960px){
  .support-hero-grid{grid-template-columns:1fr;gap:32px}
  .support-chat{min-height:480px}
  .ticket-card{grid-template-columns:1fr;padding:32px;gap:32px}
}
@media (max-width: 640px){
  .support-hero{padding:48px 0 40px}
  .support-hero-text h1{font-size:32px}
  .support-search{flex-wrap:wrap}
  .support-search input{min-width:60%}
  .ticket-form .form-row{grid-template-columns:1fr}
  .ticket-card{padding:24px;border-radius:18px}
  .sec-title{font-size:24px}
}

/* Support chat — error & failed message states */
.sc-msg-error .sc-bubble{
  background:#fef2f2 !important;border-color:#fecaca !important;color:#991b1b !important;
}
.sc-msg-failed .sc-bubble{
  background:linear-gradient(135deg,#dc2626,#991b1b) !important;
  position:relative;
}
.sc-msg-failed .sc-bubble::after{
  content:"⚠ not delivered";position:absolute;bottom:-16px;right:6px;
  font-size:10px;color:#dc2626;font-weight:600;white-space:nowrap;
}

/* =========================================================================
   PGNAV — modern public header + mobile drawer (replaces .topbar/.primary)
   The drawer is a body-level sibling (see public.php), so its position:fixed
   resolves against the viewport, not a backdrop-filtered ancestor.
   ========================================================================= */
.pgnav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.8);-webkit-backdrop-filter:saturate(180%) blur(16px);backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid rgba(226,232,240,.7);transition:box-shadow .25s ease,background .25s ease,border-color .25s ease}
.pgnav.is-scrolled{background:rgba(255,255,255,.92);border-bottom-color:rgba(226,232,240,.95);box-shadow:0 6px 24px rgba(15,23,42,.07)}
.pgnav__bar{display:flex;align-items:center;justify-content:space-between;height:68px;gap:16px}
.pgnav__brand{display:flex;align-items:center;flex-shrink:0;transition:transform .2s ease}
.pgnav__brand:hover{transform:scale(1.03)}
.pgnav__brand img{height:40px;width:auto;display:block}

.pgnav__links{display:flex;align-items:center;gap:2px}
.pgnav__links a{position:relative;color:var(--text);font-weight:500;font-size:15px;padding:8px 14px;border-radius:10px;line-height:1;display:inline-flex;align-items:center;gap:6px;transition:color .18s ease,background .18s ease}
.pgnav__links a:hover{color:var(--primary);background:rgba(209,31,31,.06);text-decoration:none}
.pgnav__links a::after{content:"";position:absolute;left:14px;right:14px;bottom:5px;height:2px;background:var(--primary);border-radius:2px;transform:scaleX(0);transform-origin:center;transition:transform .2s ease}
.pgnav__links a:hover::after{transform:scaleX(1)}

.pgnav__actions{display:flex;align-items:center;gap:10px}
.pgnav__icon{width:42px;height:42px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.6);border:1px solid var(--border);color:var(--text);flex-shrink:0;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,color .18s ease}
.pgnav__icon:hover{color:var(--primary);border-color:var(--primary);background:#fff;box-shadow:0 4px 14px rgba(209,31,31,.18);transform:translateY(-1px);text-decoration:none}
.pgnav__icon [data-lucide],.pgnav__icon svg{width:18px;height:18px}

.pgnav__btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:12px;padding:9px 16px;font-size:14px;font-weight:600;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,color .18s ease}
.pgnav__btn [data-lucide],.pgnav__btn svg{width:16px;height:16px}
.pgnav__btn--ghost{background:rgba(255,255,255,.6);border-color:var(--border);color:var(--text)}
.pgnav__btn--ghost:hover{border-color:var(--primary);color:var(--primary);background:#fff;box-shadow:0 4px 14px rgba(15,23,42,.06);text-decoration:none}
.pgnav__btn--solid{background:linear-gradient(135deg,var(--secondary),var(--primary));color:#fff;box-shadow:0 6px 16px rgba(209,31,31,.28)}
.pgnav__btn--solid:hover{background:linear-gradient(135deg,var(--primary),var(--primary-dark));box-shadow:0 10px 24px rgba(209,31,31,.36);transform:translateY(-1px);text-decoration:none}

.pgnav__burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;border:1px solid var(--border);background:rgba(255,255,255,.6);border-radius:12px;cursor:pointer;padding:0 11px;flex-shrink:0;transition:border-color .18s ease,background .18s ease}
.pgnav__burger:hover{border-color:var(--primary);background:#fff}
.pgnav__burger span{display:block;height:2px;width:100%;background:var(--text);border-radius:2px;transition:transform .25s ease,opacity .2s ease}

/* Mobile drawer */
.pgnav-drawer{position:fixed;inset:0;z-index:1000}
.pgnav-drawer[hidden]{display:none}
.pgnav-drawer__scrim{position:absolute;inset:0;background:rgba(15,23,42,.5);opacity:0;transition:opacity .28s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.pgnav-drawer__panel{position:absolute;top:0;right:0;bottom:0;width:min(86vw,360px);background:#fff;display:flex;flex-direction:column;padding:18px 18px calc(20px + env(safe-area-inset-bottom));box-shadow:-16px 0 44px rgba(15,23,42,.22);transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;-webkit-overflow-scrolling:touch}
.pgnav-drawer.is-open .pgnav-drawer__scrim{opacity:1}
.pgnav-drawer.is-open .pgnav-drawer__panel{transform:translateX(0)}
.pgnav-drawer__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.pgnav-drawer__title{font-size:12px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted)}
.pgnav-drawer__close{width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.pgnav-drawer__close:hover{background:#fef5f5;color:var(--primary);border-color:var(--primary)}
.pgnav-drawer__close [data-lucide],.pgnav-drawer__close svg{width:20px;height:20px}
.pgnav-drawer__links{display:flex;flex-direction:column;gap:2px}
.pgnav-drawer__links a{display:flex;align-items:center;gap:12px;padding:14px 14px;border-radius:12px;color:var(--text);font-size:16px;font-weight:600;transition:background .15s,color .15s}
.pgnav-drawer__links a:hover{background:#fef5f5;color:var(--primary);text-decoration:none}
.pgnav-drawer__links a [data-lucide],.pgnav-drawer__links a svg{width:20px;height:20px;color:var(--primary);flex-shrink:0}
.pgnav-drawer__cta{display:flex;flex-direction:column;gap:10px;margin-top:auto;padding-top:18px;border-top:1px solid var(--border)}
.pgnav-drawer__cta .pgnav__btn{width:100%;padding:13px 16px;font-size:15px}

/* Switch to mobile layout */
@media (max-width:900px){
  .pgnav__links{display:none}
  .pgnav__desk{display:none}
  .pgnav__burger{display:flex}
}
@media (max-width:520px){
  .pgnav__brand img{height:32px}
}
@media (prefers-reduced-motion:reduce){
  .pgnav-drawer__panel{transition:none}
  .pgnav-drawer__scrim{transition:none}
}
