/* =====================================================================
   cp-marketing.css — Phase 7 marketing layer.
   Light-only design layer for the public marketing pages.
   Sits on top of cp-design.css; provides public chrome (nav, footer)
   and page-content components (hero, section, contact-card, CTA, FAQ,
   step-card, eyebrow).

   Class names match the existing components/nav.html and
   components/footer.html markup so the components.js injector keeps
   working without any v2 partial.

   Sole stylesheet for all public pages (paired with cp-design.css).
   ===================================================================== */

/* ── Tokens (light marketing palette) ─────────────────────────────── */
:root {
  --m-brand: #006aff;
  --m-brand-dark: #0054cc;
  --m-brand-pale: #eaf2ff;
  /* Gold — single brand value. Mirrored as --gold in cp-design.css; keep in sync. */
  --m-gold: #d4a017;
  --m-gold-pale: #faf3dd;
  --m-ink: #0a1729;
  --m-ink-2: #1a2540;
  --m-text: #1f2937;
  --m-muted: #4b5563;
  --m-muted-2: #6b7280;
  --m-soft: #8892a2;
  --m-bg: #ffffff;
  --m-surface: #f7f9fc;
  --m-surface-2: #eff2f7;
  --m-border: #e4e8ef;
  --m-border-strong: #d4dae3;
  --m-white: #ffffff;
  --m-shadow-sm: 0 1px 2px rgba(15,23,42,0.06), 0 1px 3px rgba(15,23,42,0.04);
  --m-shadow-md: 0 6px 16px rgba(15,23,42,0.08), 0 2px 6px rgba(15,23,42,0.04);
  --m-shadow-lg: 0 18px 40px rgba(15,23,42,0.12), 0 6px 14px rgba(15,23,42,0.06);
  --m-shadow-blue: 0 6px 16px rgba(0,106,255,0.18), 0 2px 6px rgba(0,106,255,0.10);
  --m-shadow-blue-lg: 0 12px 28px rgba(0,106,255,0.26), 0 4px 10px rgba(0,106,255,0.14);
  --m-r: 8px;
  --m-r-lg: 12px;
  --m-r-xl: 16px;
  --m-r-2xl: 22px;
  --m-r-full: 999px;
  --m-font-display: 'Fraunces', 'Georgia', 'Times New Roman', serif;
  --m-s-1: 4px;
  --m-s-2: 8px;
  --m-s-3: 12px;
  --m-s-4: 16px;
  --m-s-5: 20px;
  --m-s-6: 24px;
  --m-s-8: 32px;
  --m-s-10: 40px;
  --m-s-12: 48px;
  --m-s-16: 64px;
  --m-s-20: 80px;
  --m-s-24: 96px;
  --m-max-w: 1180px;
  --m-nav-h: 64px;
  --m-font-base: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --m-dur: 200ms;
  --m-dur-slow: 320ms;
  --m-ease: cubic-bezier(.4,0,.2,1);
  --m-ease-out: cubic-bezier(.2,.8,.2,1);
  --m-z-nav: 50;
}

/* ── Marketing scope reset ─────────────────────────────────────────
   Scoped to body[data-portal="public"] so admin/landlord/tenant
   pages that also load cp-design.css stay untouched.            */
body[data-portal="public"] {
  margin: 0;
  background: var(--m-bg);
  color: var(--m-text);
  font-family: var(--m-font-base);
  font-size: 15.5px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body[data-portal="public"] *,
body[data-portal="public"] *::before,
body[data-portal="public"] *::after {
  box-sizing: border-box;
}
body[data-portal="public"] a { color: var(--m-brand); text-decoration: none; }
body[data-portal="public"] a:hover { color: var(--m-brand-dark); }
body[data-portal="public"] img { max-width: 100%; height: auto; display: block; }
body[data-portal="public"] h1,
body[data-portal="public"] h2,
body[data-portal="public"] h3,
body[data-portal="public"] h4 { font-family: var(--m-font-base); color: var(--m-ink); margin: 0; }
body[data-portal="public"] p { margin: 0; }
body[data-portal="public"] ul { margin: 0; }

/* ── Container ─────────────────────────────────────────────────── */
body[data-portal="public"] .container {
  max-width: var(--m-max-w);
  margin: 0 auto;
  padding: 0 var(--m-s-6);
}
@media (max-width: 600px) {
  body[data-portal="public"] .container { padding: 0 var(--m-s-5); }
}

/* ── Buttons ──────────────────────────────────────────────────── */
body[data-portal="public"] .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--m-s-2);
  padding: 10px 18px;
  border-radius: var(--m-r);
  font-size: 14.5px;
  font-weight: 600;
  letter-spacing: -0.01em;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: all var(--m-dur) var(--m-ease);
  min-height: 40px;
}
body[data-portal="public"] .btn-primary {
  background: var(--m-brand);
  color: var(--m-white);
  box-shadow: var(--m-shadow-blue);
}
body[data-portal="public"] .btn-primary:hover {
  background: var(--m-brand-dark);
  color: var(--m-white);
  transform: translateY(-1px);
  box-shadow: var(--m-shadow-blue-lg);
}
body[data-portal="public"] .btn-ghost {
  background: var(--m-surface);
  color: var(--m-ink);
  border-color: var(--m-border);
}
body[data-portal="public"] .btn-ghost:hover {
  background: var(--m-surface-2);
  border-color: var(--m-border-strong);
  color: var(--m-ink);
}
body[data-portal="public"] .btn-lg {
  padding: 13px 24px;
  font-size: 15.5px;
  border-radius: var(--m-r-lg);
  min-height: 48px;
}
body[data-portal="public"] .btn-full { width: 100%; }

/* ── Top nav ─────────────────────────────────────────────────── */
body[data-portal="public"] .nav {
  position: sticky;
  top: 0;
  z-index: var(--m-z-nav);
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--m-border);
}
body[data-portal="public"] .nav-inner {
  max-width: var(--m-max-w);
  margin: 0 auto;
  padding: 0 var(--m-s-6);
  height: var(--m-nav-h);
  display: flex;
  align-items: center;
  gap: var(--m-s-4);
}
body[data-portal="public"] .nav-logo {
  display: flex;
  align-items: center;
  gap: var(--m-s-3);
  text-decoration: none;
  flex-shrink: 0;
}
body[data-portal="public"] .nav-logo-emblem {
  width: 34px;
  height: 34px;
  border-radius: var(--m-r-lg);
  background: linear-gradient(135deg, var(--m-brand) 0%, var(--m-brand-dark) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--m-shadow-sm);
}
body[data-portal="public"] .nav-logo-emblem svg { width: 20px; height: 20px; }
body[data-portal="public"] .nav-logo-text-wrap { display: flex; flex-direction: column; line-height: 1.1; }
body[data-portal="public"] .nav-logo-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--m-ink);
  letter-spacing: -0.02em;
}
body[data-portal="public"] .nav-logo-tagline {
  font-size: 9.5px;
  font-weight: 500;
  color: var(--m-muted-2);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-top: 2px;
}
body[data-portal="public"] .nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-left: auto;
}
body[data-portal="public"] .nav-link {
  padding: 8px 14px;
  border-radius: var(--m-r);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--m-muted);
  transition: all var(--m-dur) var(--m-ease);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
body[data-portal="public"] .nav-link:hover {
  color: var(--m-ink);
  background: var(--m-surface);
}
body[data-portal="public"] .nav-link.active {
  color: var(--m-ink);
  font-weight: 600;
  background: var(--m-brand-pale);
}
body[data-portal="public"] .nav-link--track {
  color: var(--m-muted);
  font-weight: 500;
}
body[data-portal="public"] .nav-link--landlord,
body[data-portal="public"] .nav-link--admin {
  color: var(--m-muted);
}
body[data-portal="public"] .nav-mobile-toggle {
  display: none;
  background: var(--m-surface);
  border: 1px solid var(--m-border);
  width: 44px;
  height: 44px;
  font-size: 18px;
  color: var(--m-ink);
  cursor: pointer;
  border-radius: var(--m-r);
  margin-left: auto;
  align-items: center;
  justify-content: center;
}
@media (max-width: 900px) {
  body[data-portal="public"] .nav-links { display: none; }
  body[data-portal="public"] .nav-mobile-toggle { display: inline-flex; }
}

/* ── Mobile drawer ───────────────────────────────────────────── */
body[data-portal="public"] .nav-drawer-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(10,23,41,0.4);
  z-index: calc(var(--m-z-nav) - 1);
  backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity 0.32s ease;
}
body[data-portal="public"] .nav-drawer-overlay.visible { display: block; }
body[data-portal="public"] .nav-drawer-overlay.open { opacity: 1; }
body[data-portal="public"] .nav-drawer {
  position: fixed;
  top: 0;
  right: -100%;
  bottom: 0;
  width: min(320px, 88vw);
  background: var(--m-white);
  z-index: var(--m-z-nav);
  display: flex;
  flex-direction: column;
  transition: right var(--m-dur-slow) var(--m-ease-out);
  box-shadow: var(--m-shadow-lg);
}
body[data-portal="public"] .nav-drawer.open { right: 0; }
body[data-portal="public"] .nav-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--m-s-5) var(--m-s-6);
  border-bottom: 1px solid var(--m-border);
}
body[data-portal="public"] .nav-drawer-close {
  background: var(--m-surface);
  border: none;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  color: var(--m-muted);
  cursor: pointer;
}
body[data-portal="public"] .nav-drawer-close:hover { background: var(--m-surface-2); color: var(--m-ink); }
body[data-portal="public"] .nav-drawer-body {
  padding: var(--m-s-4) var(--m-s-3);
  flex: 1;
  overflow-y: auto;
}
body[data-portal="public"] .nav-drawer-link {
  display: flex;
  align-items: center;
  gap: var(--m-s-3);
  padding: 12px var(--m-s-3);
  border-radius: var(--m-r-lg);
  font-size: 14.5px;
  font-weight: 500;
  color: var(--m-text);
  text-decoration: none;
  transition: all var(--m-dur) var(--m-ease);
  min-height: 44px;
}
body[data-portal="public"] .nav-drawer-link:hover { background: var(--m-surface); color: var(--m-ink); }
body[data-portal="public"] .nav-drawer-link.active { background: var(--m-brand-pale); color: var(--m-brand); font-weight: 600; }
body[data-portal="public"] .nav-drawer-link i {
  width: 22px;
  text-align: center;
  font-size: 14px;
  color: var(--m-muted-2);
}
body[data-portal="public"] .nav-drawer-link.active i { color: var(--m-brand); }
body[data-portal="public"] .nav-drawer-divider {
  height: 1px;
  background: var(--m-border);
  margin: var(--m-s-3) var(--m-s-2);
}
body[data-portal="public"] .nav-drawer-cta {
  padding: var(--m-s-4) var(--m-s-6);
  border-top: 1px solid var(--m-border);
}
body[data-portal="public"] .nav-drawer-footer {
  padding: var(--m-s-4) var(--m-s-6);
  font-size: 12px;
  color: var(--m-muted-2);
}

/* ── Section eyebrow ────────────────────────────────────────── */
body[data-portal="public"] .section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--m-s-2);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--m-brand);
  background: var(--m-brand-pale);
  border-radius: var(--m-r-full);
  padding: 5px 12px;
}

/* ── Marketing hero ─────────────────────────────────────────── */
body[data-portal="public"] .info-hero {
  background: linear-gradient(135deg, var(--m-ink) 0%, var(--m-ink-2) 100%);
  padding: var(--m-s-16) 0 var(--m-s-12);
  margin-bottom: var(--m-s-12);
  position: relative;
  overflow: hidden;
}
body[data-portal="public"] .info-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 70% 50%, rgba(212,160,23,0.10) 0%, transparent 60%);
  pointer-events: none;
}
body[data-portal="public"] .info-hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(to right, transparent 5%, rgba(212,160,23,0.3) 30%, rgba(212,160,23,0.3) 70%, transparent 95%);
}
body[data-portal="public"] .info-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 720px;
}
body[data-portal="public"] .info-hero .section-eyebrow {
  background: rgba(212,160,23,0.14);
  color: #f1c64a;
  margin-bottom: var(--m-s-4);
}
body[data-portal="public"] .info-hero-title {
  font-size: clamp(32px, 5vw, 52px);
  font-weight: 700;
  color: var(--m-white);
  line-height: 1.1;
  margin: 0 0 var(--m-s-3);
  letter-spacing: -0.02em;
}
body[data-portal="public"] .info-hero-sub {
  font-size: 17px;
  color: rgba(255,255,255,0.62);
  line-height: 1.65;
}

/* ── Marketing page sections ────────────────────────────────── */
body[data-portal="public"] .info-page {
  padding: 0 0 var(--m-s-24);
}
body[data-portal="public"] .info-content { max-width: 760px; }
body[data-portal="public"] .info-section { margin-bottom: var(--m-s-10); }
body[data-portal="public"] .info-section h2 {
  font-size: 26px;
  font-weight: 700;
  color: var(--m-ink);
  margin: 0 0 var(--m-s-4);
  padding-bottom: var(--m-s-3);
  border-bottom: 1.5px solid var(--m-border);
  letter-spacing: -0.01em;
}
body[data-portal="public"] .info-section p {
  font-size: 15.5px;
  color: var(--m-text);
  line-height: 1.8;
  margin: 0 0 var(--m-s-4);
}
body[data-portal="public"] .info-section ul {
  padding-left: var(--m-s-5);
  display: flex;
  flex-direction: column;
  gap: var(--m-s-2);
}
body[data-portal="public"] .info-section ul li {
  font-size: 15.5px;
  color: var(--m-text);
  line-height: 1.7;
}

/* ── Legal / policy doc layout (terms, privacy, fair-housing, policy pages) ── */
body[data-portal="public"] .info-body {
  padding: var(--m-s-4) 0 var(--m-s-20);
}
body[data-portal="public"] .info-doc {
  max-width: 780px;
  margin: 0 auto;
}
body[data-portal="public"] .info-section h3 {
  font-size: 17px;
  font-weight: 700;
  color: var(--m-ink);
  margin: var(--m-s-6) 0 var(--m-s-3);
  letter-spacing: -0.005em;
}
body[data-portal="public"] .info-section h4 {
  font-size: 15px;
  font-weight: 700;
  color: var(--m-ink);
  margin: var(--m-s-5) 0 var(--m-s-2);
}
body[data-portal="public"] .info-section ol {
  padding-left: var(--m-s-5);
  display: flex;
  flex-direction: column;
  gap: var(--m-s-2);
  margin: 0 0 var(--m-s-4);
}
body[data-portal="public"] .info-section ol li {
  font-size: 15.5px;
  color: var(--m-text);
  line-height: 1.7;
}
body[data-portal="public"] .info-section a {
  color: var(--m-brand);
  text-decoration: underline;
  text-underline-offset: 2px;
}
body[data-portal="public"] .info-section a:hover { color: var(--m-brand-strong, var(--m-brand)); }
body[data-portal="public"] .effective-date {
  font-size: 13px;
  color: rgba(255,255,255,0.7);
  margin: var(--m-s-3) 0 0;
}
body[data-portal="public"] .policy-nav {
  background: var(--m-white);
  border: 1px solid var(--m-border);
  border-radius: var(--m-r-2xl);
  padding: var(--m-s-6);
  margin-bottom: var(--m-s-8);
  box-shadow: var(--m-shadow-sm);
}
body[data-portal="public"] .policy-nav h3 {
  font-size: 12px;
  font-weight: 700;
  color: var(--m-ink);
  margin: 0 0 var(--m-s-3);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
body[data-portal="public"] .policy-nav a {
  display: block;
  color: var(--m-brand);
  font-size: 14.5px;
  padding: 4px 0;
  text-decoration: none;
}
body[data-portal="public"] .policy-nav a:hover { text-decoration: underline; }

/* ── Contact card ───────────────────────────────────────────── */
body[data-portal="public"] .contact-card {
  background: var(--m-white);
  border: 1px solid var(--m-border);
  border-radius: var(--m-r-2xl);
  padding: var(--m-s-8);
  box-shadow: var(--m-shadow-sm);
}
body[data-portal="public"] .contact-card h3 {
  font-size: 22px;
  font-weight: 700;
  color: var(--m-ink);
  margin: 0 0 var(--m-s-5);
}
body[data-portal="public"] .contact-row {
  display: flex;
  align-items: center;
  gap: var(--m-s-3);
  padding: var(--m-s-3) 0;
  border-bottom: 1px solid var(--m-border);
  font-size: 15px;
  color: var(--m-text);
}
body[data-portal="public"] .contact-row:last-child { border-bottom: none; }
body[data-portal="public"] .contact-row-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--m-r-lg);
  background: var(--m-brand-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: var(--m-brand);
  flex-shrink: 0;
}
body[data-portal="public"] .contact-row a {
  color: var(--m-ink);
  font-weight: 600;
}
body[data-portal="public"] .contact-row a:hover { color: var(--m-brand); }

/* ── Inline CTA card ───────────────────────────────────────── */
body[data-portal="public"] .info-cta {
  background: linear-gradient(135deg, var(--m-ink) 0%, var(--m-ink-2) 100%);
  border-radius: var(--m-r-2xl);
  padding: var(--m-s-10);
  margin-top: var(--m-s-12);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--m-s-6);
  flex-wrap: wrap;
  position: relative;
  overflow: hidden;
}
body[data-portal="public"] .info-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 80% at 90% 50%, rgba(212,160,23,0.14) 0%, transparent 60%);
  pointer-events: none;
}
body[data-portal="public"] .info-cta-text { position: relative; z-index: 1; }
body[data-portal="public"] .info-cta-text h3 {
  font-size: 26px;
  font-weight: 700;
  color: var(--m-white);
  margin: 0 0 var(--m-s-2);
}
body[data-portal="public"] .info-cta-text p {
  font-size: 15px;
  color: rgba(255,255,255,0.62);
}
body[data-portal="public"] .info-cta .btn { position: relative; z-index: 1; }

/* ── FAQ accordion ─────────────────────────────────────────── */
body[data-portal="public"] .faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--m-s-3);
}
body[data-portal="public"] .faq-item {
  border: 1px solid var(--m-border);
  border-radius: var(--m-r-xl);
  overflow: hidden;
  background: var(--m-white);
  transition: box-shadow var(--m-dur) var(--m-ease);
}
body[data-portal="public"] .faq-item:hover { box-shadow: var(--m-shadow-sm); }
body[data-portal="public"] .faq-summary {
  padding: var(--m-s-5);
  font-weight: 600;
  font-size: 15.5px;
  color: var(--m-ink);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--m-s-4);
  list-style: none;
  background: var(--m-white);
  transition: background var(--m-dur) var(--m-ease);
}
body[data-portal="public"] .faq-summary:hover { background: var(--m-surface); }
body[data-portal="public"] .faq-summary::-webkit-details-marker { display: none; }
body[data-portal="public"] .faq-summary::after {
  content: '+';
  font-size: 22px;
  font-weight: 300;
  color: var(--m-brand);
  flex-shrink: 0;
  transition: transform var(--m-dur) var(--m-ease);
}
body[data-portal="public"] details[open] .faq-summary::after { transform: rotate(45deg); }
body[data-portal="public"] details[open] .faq-summary {
  color: var(--m-brand);
  background: var(--m-brand-pale);
}
body[data-portal="public"] .faq-body {
  padding: var(--m-s-5);
  background: var(--m-white);
  font-size: 15px;
  color: var(--m-text);
  line-height: 1.75;
}

/* ── Step cards ────────────────────────────────────────────── */
body[data-portal="public"] .steps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--m-s-5);
  margin-top: var(--m-s-6);
}
body[data-portal="public"] .step-card {
  background: var(--m-white);
  border: 1px solid var(--m-border);
  border-radius: var(--m-r-xl);
  padding: var(--m-s-6);
  transition: box-shadow var(--m-dur-slow) var(--m-ease), transform var(--m-dur-slow) var(--m-ease);
}
body[data-portal="public"] .step-card:hover {
  box-shadow: var(--m-shadow-md);
  transform: translateY(-3px);
}
body[data-portal="public"] .step-number {
  font-size: 48px;
  font-weight: 900;
  color: var(--m-brand-pale);
  line-height: 1;
  margin-bottom: var(--m-s-3);
}
body[data-portal="public"] .step-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--m-r-lg);
  background: var(--m-brand-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: var(--m-brand);
  margin-bottom: var(--m-s-4);
}
body[data-portal="public"] .step-title {
  font-weight: 700;
  font-size: 16px;
  color: var(--m-ink);
  margin-bottom: var(--m-s-2);
}
body[data-portal="public"] .step-desc {
  font-size: 13.5px;
  color: var(--m-muted);
  line-height: 1.65;
}

/* ── Footer ────────────────────────────────────────────────── */
body[data-portal="public"] .footer {
  background: var(--m-ink);
  color: rgba(255,255,255,0.72);
  padding: var(--m-s-16) 0 var(--m-s-8);
  margin-top: var(--m-s-20);
}
body[data-portal="public"] .footer .container { max-width: var(--m-max-w); }
body[data-portal="public"] .footer-grid {
  display: grid;
  grid-template-columns: 2.2fr 1fr 1fr 1fr 1fr;
  gap: var(--m-s-10);
  margin-bottom: var(--m-s-12);
}
body[data-portal="public"] .footer-logo {
  display: flex;
  align-items: center;
  gap: var(--m-s-3);
  margin-bottom: var(--m-s-5);
}
body[data-portal="public"] .footer-logo-mark {
  width: 34px;
  height: 34px;
  border-radius: var(--m-r-lg);
  background: var(--m-brand);
  display: flex;
  align-items: center;
  justify-content: center;
}
body[data-portal="public"] .footer-logo-text {
  font-size: 16px;
  font-weight: 700;
  color: var(--m-white);
}
body[data-portal="public"] .footer-desc {
  font-size: 14px;
  color: rgba(255,255,255,0.55);
  line-height: 1.7;
  max-width: 280px;
  margin-bottom: var(--m-s-4);
}
body[data-portal="public"] .footer-col-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--m-white);
  margin-bottom: var(--m-s-4);
}
body[data-portal="public"] .footer-link {
  display: block;
  padding: 6px 0;
  font-size: 14px;
  color: rgba(255,255,255,0.62);
  text-decoration: none;
  transition: color var(--m-dur) var(--m-ease);
}
body[data-portal="public"] .footer-link:hover { color: var(--m-white); }
body[data-portal="public"] .footer-bottom {
  padding-top: var(--m-s-6);
  border-top: 1px solid rgba(255,255,255,0.10);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--m-s-4);
  font-size: 13px;
  color: rgba(255,255,255,0.55);
}
body[data-portal="public"] .footer-eq {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: rgba(255,255,255,0.62);
}
body[data-portal="public"] .footer-bottom-links { display: flex; gap: var(--m-s-5); }
body[data-portal="public"] .footer-bottom-links a {
  color: rgba(255,255,255,0.55);
  text-decoration: none;
}
body[data-portal="public"] .footer-bottom-links a:hover { color: var(--m-white); }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 960px) {
  body[data-portal="public"] .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--m-s-8);
  }
}
@media (max-width: 768px) {
  body[data-portal="public"] .info-hero { padding: var(--m-s-12) 0 var(--m-s-10); margin-bottom: var(--m-s-10); }
  body[data-portal="public"] .info-hero-title { font-size: clamp(26px, 7vw, 36px); }
  body[data-portal="public"] .info-hero-sub { font-size: 15px; }
  body[data-portal="public"] .info-page { padding: 0 0 var(--m-s-16); }
  body[data-portal="public"] .info-cta { padding: var(--m-s-6); flex-direction: column; align-items: flex-start; }
  body[data-portal="public"] .info-cta-text h3 { font-size: 20px; }
  body[data-portal="public"] .footer { padding: var(--m-s-12) 0 var(--m-s-6); }
  body[data-portal="public"] .footer-bottom { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 600px) {
  body[data-portal="public"] .footer-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  body[data-portal="public"] .info-hero { padding: var(--m-s-10) 0 var(--m-s-8); }
  body[data-portal="public"] .info-section h2 { font-size: 20px; }
  body[data-portal="public"] .info-section p,
  body[data-portal="public"] .info-section ul li { font-size: 14.5px; }
}

/* ── Reduced motion ────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"] .btn,
  body[data-portal="public"] .nav-drawer,
  body[data-portal="public"] .nav-drawer-overlay,
  body[data-portal="public"] .step-card,
  body[data-portal="public"] .faq-item,
  body[data-portal="public"] .faq-summary {
    transition: none !important;
  }
  body[data-portal="public"] .btn-primary:hover,
  body[data-portal="public"] .step-card:hover { transform: none !important; }
}


/* =====================================================================
   HOMEPAGE COMPONENTS — sub-phase 7.3.1 (April 22 2026).
   All selectors scoped under body[data-portal="public"].
   See BATCH_3_MIGRATION.md for migration history.
   ===================================================================== */

/* ── Hero ──────────────────────────────────────────────────── */
body[data-portal="public"] .hero {
  position: relative;
  background:
    linear-gradient(150deg, rgba(4,17,31,0.82) 0%, rgba(11,29,56,0.68) 45%, rgba(14,35,71,0.66) 75%, rgba(7,22,39,0.82) 100%),
    url('https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=2000&q=80') center/cover no-repeat;
  background-color: #04111F;
  min-height: 500px;
  padding: clamp(60px, 10vw, 110px) 0 clamp(60px, 8vw, 90px);
  display: flex; align-items: center; overflow: hidden;
}
body[data-portal="public"] .hero-atmosphere {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 55% at 88% 12%, rgba(0,106,255,0.22) 0%, transparent 55%),
    radial-gradient(ellipse 50% 65% at 5%  85%, rgba(0,80,200,0.14) 0%, transparent 50%),
    radial-gradient(ellipse 90% 40% at 50% 110%, rgba(0,57,180,0.12) 0%, transparent 60%);
}
body[data-portal="public"] .hero-grain {
  position: absolute; inset: 0; opacity: 0.030; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  background-repeat: repeat; background-size: 160px 160px;
}
body[data-portal="public"] .hero-rule,
body[data-portal="public"] .hero-line {
  position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.08) 30%, rgba(255,255,255,0.08) 70%, transparent 100%);
}
body[data-portal="public"] .hero-inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr; gap: var(--m-s-16); align-items: center;
  max-width: var(--m-max-w); margin: 0 auto; padding: 0 var(--m-s-6);
}
body[data-portal="public"] .hero-content { position: relative; z-index: 1; max-width: 760px; }
body[data-portal="public"] .hero-eyebrow {
  display: inline-flex; align-items: center; gap: var(--m-s-2);
  background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.30);
  border-radius: var(--m-r-full); padding: 5px 14px;
  font-size: 11px; font-weight: 700; color: rgba(255,255,255,0.95);
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--m-s-6);
}
body[data-portal="public"] .hero-eyebrow-pulse,
body[data-portal="public"] .hero-eyebrow-dot {
  width: 5px; height: 5px; border-radius: 50%; background: rgba(255,255,255,0.90);
  flex-shrink: 0; animation: heroPulse 2s infinite;
}
@keyframes heroPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.45; transform: scale(0.7); }
}
body[data-portal="public"] .hero-headline,
body[data-portal="public"] .hero-title {
  font-family: var(--m-font-base);
  font-size: clamp(38px, 6vw, 78px);
  font-weight: 700; color: #fff;
  line-height: 1.04; letter-spacing: -0.025em; margin-bottom: var(--m-s-6);
}
body[data-portal="public"] .hero-headline em,
body[data-portal="public"] .hero-title em {
  font-family: var(--m-font-display);
  font-style: normal; font-weight: 700;
  color: #f4d27a;
  letter-spacing: -0.015em;
  text-decoration: underline;
  text-decoration-color: rgba(244, 210, 122, 0.45);
  text-underline-offset: 5px;
  text-decoration-thickness: 2px;
}
body[data-portal="public"] .hero-title .line-indent { display: block; padding-left: clamp(16px, 3vw, 60px); }
body[data-portal="public"] .hero-sub,
body[data-portal="public"] .hero-subtitle {
  font-size: clamp(15px, 1.8vw, 17px); color: rgba(255,255,255,0.80);
  line-height: 1.7; max-width: 540px;
  margin-bottom: var(--m-s-10); font-weight: 400;
}
body[data-portal="public"] .hero-stats {
  display: flex; gap: clamp(24px, 4vw, 56px); margin-top: var(--m-s-10); flex-wrap: wrap;
}
body[data-portal="public"] .hero-stat { position: relative; padding-left: var(--m-s-4); }
body[data-portal="public"] .hero-stat::before {
  content: ''; position: absolute; left: 0; top: 4px; bottom: 4px;
  width: 2px; background: linear-gradient(to bottom, #4d9aff, transparent); border-radius: 2px;
}
body[data-portal="public"] .hero-stat-num {
  font-family: var(--m-font-base); font-size: clamp(24px, 3vw, 36px);
  font-weight: 700; color: #fff; line-height: 1; letter-spacing: -0.01em;
}
body[data-portal="public"] .hero-stat-label {
  font-size: 11px; font-weight: 500; color: rgba(255,255,255,0.48);
  letter-spacing: 0.08em; text-transform: uppercase; margin-top: 4px;
}
body[data-portal="public"] .hero-stat-divider { width: 1px; background: rgba(255,255,255,0.08); align-self: stretch; }

/* ── Search bar (mobile-first column → row at 769px) ─────── */
body[data-portal="public"] .search-bar,
body[data-portal="public"] .search-box {
  background: var(--m-white); border-radius: var(--m-r-2xl);
  overflow: hidden; box-shadow: 0 28px 80px rgba(0,0,0,0.40), 0 0 0 1px rgba(255,255,255,0.04);
  max-width: 700px;
  flex-direction: column; gap: 0;
}
body[data-portal="public"] .search-bar-top { display: flex; align-items: stretch; flex-direction: column; }
body[data-portal="public"] .search-box { padding: 0; display: flex; align-items: center; flex-wrap: wrap; }
body[data-portal="public"] .search-field {
  flex: 1; min-width: 100%; display: flex; align-items: center; gap: var(--m-s-3);
  padding: 14px 18px; border-right: none; border-bottom: 1px solid var(--m-border);
  border-radius: 0; width: 100%;
  transition: background var(--m-dur) var(--m-ease);
}
body[data-portal="public"] .search-field:hover { background: var(--m-surface); }
body[data-portal="public"] .search-field:first-child { border-radius: var(--m-r-2xl) var(--m-r-2xl) 0 0; }
body[data-portal="public"] .search-field:last-of-type { border-bottom: none; }
body[data-portal="public"] .search-field i,
body[data-portal="public"] .search-field-icon { color: var(--m-brand); font-size: 13px; flex-shrink: 0; }
body[data-portal="public"] .search-field-wrap { display: flex; flex-direction: column; gap: 1px; flex: 1; }
body[data-portal="public"] .search-field-label {
  font-size: 11px; font-weight: 700; color: var(--m-muted-2);
  text-transform: uppercase; letter-spacing: 0.05em;
}
body[data-portal="public"] .search-field input,
body[data-portal="public"] .search-field select {
  border: none; outline: none; font-size: 13.5px; font-weight: 600;
  color: var(--m-text); background: transparent; width: 100%;
  font-family: var(--m-font-base); appearance: none;
}
body[data-portal="public"] .search-btn,
body[data-portal="public"] .search-submit {
  width: 100%; justify-content: center;
  border-radius: 0 0 var(--m-r-2xl) var(--m-r-2xl);
  min-height: 52px;
  background: var(--m-brand); color: #fff; border: none;
  font-family: var(--m-font-base); font-size: 14px; font-weight: 700;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 22px; cursor: pointer;
  transition: background var(--m-dur) var(--m-ease);
}
body[data-portal="public"] .search-btn:hover,
body[data-portal="public"] .search-submit:hover { background: var(--m-brand-dark); }

@media (min-width: 769px) {
  body[data-portal="public"] .search-bar-top,
  body[data-portal="public"] .search-box { flex-direction: row; }
  body[data-portal="public"] .search-field {
    min-width: unset; border-right: 1px solid var(--m-border); border-bottom: none;
    border-radius: 0; width: auto;
  }
  body[data-portal="public"] .search-field:first-child {
    border-radius: var(--m-r-full) 0 0 var(--m-r-full);
  }
  body[data-portal="public"] .search-btn,
  body[data-portal="public"] .search-submit {
    width: auto; justify-content: flex-start;
    border-radius: 0 var(--m-r-full) var(--m-r-full) 0; min-height: unset;
  }
}

/* Hero stats responsive (mobile: wrap, hide divider; ≥640: show divider) */
@media (max-width: 639px) {
  body[data-portal="public"] .hero-stats {
    flex-wrap: wrap; gap: var(--m-s-4) var(--m-s-5); justify-content: center;
  }
  body[data-portal="public"] .hero-stat-divider { display: none; }
  body[data-portal="public"] .hero { padding-top: var(--m-s-12); padding-bottom: var(--m-s-12); min-height: auto; }
}

/* ── Trust strip ───────────────────────────────────────────── */
body[data-portal="public"] .trust-strip {
  background: var(--m-white); border-bottom: 1px solid var(--m-border); padding: 14px 0;
}
body[data-portal="public"] .trust-strip-inner {
  max-width: var(--m-max-w); margin: 0 auto; padding: 0 var(--m-s-6);
  display: flex; align-items: center; justify-content: center; flex-wrap: wrap;
}
body[data-portal="public"] .trust-strip-item {
  display: flex; align-items: center; gap: 7px; padding: 5px 22px;
  font-size: 13px; font-weight: 600; color: var(--m-muted);
  border-right: 1px solid var(--m-border); white-space: nowrap;
}
body[data-portal="public"] .trust-strip-item:last-child { border-right: none; }
body[data-portal="public"] .trust-strip-item i { font-size: 13px; color: var(--m-brand); }
@media (max-width: 820px) {
  body[data-portal="public"] .trust-strip-item { padding: 4px 12px; font-size: 12px; border-right: none; }
}
@media (max-width: 480px) {
  body[data-portal="public"] .trust-strip { display: none; }
}

/* ── Section eyebrow / title (light variant) ──────────────── */
body[data-portal="public"] .section-eyebrow {
  display: inline-flex; align-items: center; gap: var(--m-s-2);
  font-size: 11px; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--m-brand);
  background: var(--m-brand-pale); border-radius: var(--m-r-full);
  padding: 5px 12px; margin-bottom: var(--m-s-4);
}
body[data-portal="public"] .section-eyebrow i { font-size: 9px; }
body[data-portal="public"] .section-title {
  font-family: var(--m-font-base); font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 800; color: var(--m-ink); line-height: 1.15; letter-spacing: -0.025em;
}
body[data-portal="public"] .section-subtitle {
  font-size: 16px; color: var(--m-muted); line-height: 1.7; max-width: 520px; margin-top: var(--m-s-3);
}

/* ── Container helper used by homepage sections ───────────── */
body[data-portal="public"] .container {
  max-width: var(--m-max-w); margin: 0 auto; padding: 0 var(--m-s-6);
}

/* ── Featured listings section ────────────────────────────── */
body[data-portal="public"] .featured-section {
  padding: var(--m-s-20) 0 var(--m-s-24); background: var(--m-bg); position: relative;
}
body[data-portal="public"] .featured-section::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(to right, transparent 5%, var(--m-border) 30%, var(--m-border) 70%, transparent 95%);
}
body[data-portal="public"] .featured-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-bottom: var(--m-s-10); gap: var(--m-s-4); flex-wrap: wrap;
}
body[data-portal="public"] .featured-title {
  font-family: var(--m-font-base); font-size: clamp(26px, 3vw, 40px);
  font-weight: 800; color: var(--m-ink);
  line-height: 1.1; letter-spacing: -0.01em;
  margin: var(--m-s-2) 0 var(--m-s-1);
}
body[data-portal="public"] .featured-subtitle { font-size: 14.5px; color: var(--m-muted-2); margin: 0; }
body[data-portal="public"] .featured-view-all {
  flex-shrink: 0; white-space: nowrap;
  font-size: 13.5px; font-weight: 600;
  padding: 10px 20px; border-radius: var(--m-r-full);
  border: 1.5px solid var(--m-border); color: var(--m-muted);
  text-decoration: none; display: inline-flex; align-items: center; gap: 6px;
  transition: all var(--m-dur) var(--m-ease); background: transparent;
}
body[data-portal="public"] .featured-view-all:hover {
  border-color: var(--m-brand); color: var(--m-brand); background: var(--m-brand-pale);
}
body[data-portal="public"] .featured-view-all i { font-size: 10px; }
body[data-portal="public"] .featured-cta { text-align: center; margin-top: var(--m-s-12); }
@media (min-width: 1320px) {
  body[data-portal="public"] .featured-section .property-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 540px) {
  body[data-portal="public"] .featured-header { align-items: flex-start; }
  body[data-portal="public"] .featured-view-all { display: none; }
}

/* ── Property grid + property card (shared with listings/property) ─ */
body[data-portal="public"] .property-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--m-s-4);
}
@media (min-width: 540px) {
  body[data-portal="public"] .property-grid { grid-template-columns: repeat(2, 1fr); gap: var(--m-s-4); }
}
@media (min-width: 900px) {
  body[data-portal="public"] .property-grid { grid-template-columns: repeat(3, 1fr); gap: var(--m-s-5); }
}

body[data-portal="public"] .property-card {
  background: var(--m-white); border-radius: var(--m-r-2xl);
  border: 1px solid var(--m-border); overflow: hidden;
  display: flex; flex-direction: column; cursor: pointer;
  transition: transform var(--m-dur) var(--m-ease), box-shadow var(--m-dur) var(--m-ease), border-color var(--m-dur) var(--m-ease);
  opacity: 0; transform: translateY(8px);
  transition-property: opacity, transform, box-shadow, border-color;
  transition-duration: 320ms; transition-timing-function: var(--m-ease-out);
  transition-delay: var(--cp-delay, 0ms);
}
body[data-portal="public"] .property-card.cp-card-visible { opacity: 1; transform: none; }
body[data-portal="public"] .property-card:hover {
  transform: translateY(-4px); box-shadow: var(--m-shadow-lg); border-color: var(--m-border-strong);
}

body[data-portal="public"] .property-card-img {
  position: relative; aspect-ratio: 4 / 3; overflow: hidden;
  background: var(--m-surface); border-radius: var(--m-r-2xl) var(--m-r-2xl) 0 0;
}
body[data-portal="public"] .property-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 400ms var(--m-ease); }
body[data-portal="public"] .property-card:hover .property-card-img img { transform: scale(1.04); }
body[data-portal="public"] .property-card-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 350ms var(--m-ease); }
body[data-portal="public"] .property-card-slide.active { opacity: 1; }

body[data-portal="public"] .property-card-actions {
  position: absolute; top: 10px; right: 10px; display: flex; gap: 6px; z-index: 2;
}
body[data-portal="public"] .property-card-save,
body[data-portal="public"] .property-card-share {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,0.92); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.4); color: var(--m-ink);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 13px; transition: all var(--m-dur) var(--m-ease);
}
body[data-portal="public"] .property-card-save:hover,
body[data-portal="public"] .property-card-share:hover { background: #fff; transform: scale(1.06); }
body[data-portal="public"] .property-card-save.saved { color: #e11d48; }

body[data-portal="public"] .property-card-badges {
  position: absolute; top: 10px; left: 10px; display: flex; flex-direction: column; gap: 5px; z-index: 2;
}
body[data-portal="public"] .property-card-badges .badge,
body[data-portal="public"] [class^="badge-"] {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: var(--m-r-full);
  font-size: 11px; font-weight: 700; letter-spacing: 0.02em;
}
body[data-portal="public"] .badge-new   { background: var(--m-ink); color: #4d9aff; }
body[data-portal="public"] .badge-green { background: rgba(5,150,105,0.88); color: #fff; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
body[data-portal="public"] .badge-amber { background: rgba(20,20,20,0.72); color: rgba(255,255,255,0.92); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,0.10); }
body[data-portal="public"] .badge-slate { background: rgba(20,20,20,0.52); color: rgba(255,255,255,0.82); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }

body[data-portal="public"] .property-card-body {
  padding: 14px 16px 16px; display: flex; flex-direction: column;
  transition: background var(--m-dur) var(--m-ease);
}
body[data-portal="public"] .property-card-price {
  font-family: var(--m-font-base); font-size: 20px; font-weight: 800;
  color: var(--m-ink); line-height: 1; letter-spacing: -0.01em; margin-bottom: 5px;
}
body[data-portal="public"] .property-card-price span { font-size: 12.5px; font-weight: 500; color: var(--m-muted-2); margin-left: 4px; }
body[data-portal="public"] .property-card-meta {
  display: flex; gap: 10px; font-size: 12px; color: var(--m-muted-2); margin-bottom: 8px; flex-wrap: wrap;
}
body[data-portal="public"] .property-card-meta span { display: inline-flex; align-items: center; gap: 4px; }
body[data-portal="public"] .property-card-meta i { color: var(--m-brand); font-size: 11px; }
body[data-portal="public"] .property-card-title {
  font-weight: 700; font-size: 15px; color: var(--m-text);
  margin-bottom: 5px; line-height: 1.32;
  display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden;
  transition: color 220ms var(--m-ease);
}
body[data-portal="public"] .property-card:hover .property-card-title { color: var(--m-brand); }
body[data-portal="public"] .property-card-addr {
  font-size: 12.5px; color: var(--m-muted-2); margin-bottom: 12px;
  display: flex; align-items: center; gap: 4px; line-height: 1.3;
}
body[data-portal="public"] .property-card-addr i { font-size: 9px; color: var(--m-brand); flex-shrink: 0; }
body[data-portal="public"] .property-card-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 12px; }
body[data-portal="public"] .property-card-tag {
  display: inline-flex; align-items: center; gap: 4px;
  border-radius: 100px; padding: 4px 11px; font-size: 11px; font-weight: 600;
  letter-spacing: 0.01em; border: 1px solid transparent;
}
body[data-portal="public"] .property-card-tag.tag-pet      { background: rgba(251,191,36,0.12); color: #92400e; border-color: rgba(251,191,36,0.30); }
body[data-portal="public"] .property-card-tag.tag-parking  { background: rgba(0,106,255,0.08);  color: #1d4ed8; border-color: rgba(0,106,255,0.22); }
body[data-portal="public"] .property-card-tag.tag-utilities { background: rgba(5,150,105,0.09); color: #065f46; border-color: rgba(5,150,105,0.24); }

/* Skeleton loaders for property cards */
body[data-portal="public"] .property-card-skeleton { pointer-events: none; border-radius: var(--m-r-2xl); overflow: hidden; }
body[data-portal="public"] .skeleton-img { aspect-ratio: 4 / 3; width: 100%; }
body[data-portal="public"] .skeleton-line { height: 15px; margin-bottom: 8px; border-radius: var(--m-r); }
body[data-portal="public"] .skeleton-line.w-40 { width: 40%; }
body[data-portal="public"] .skeleton-line.w-60 { width: 60%; }
body[data-portal="public"] .skeleton-line.w-80 { width: 80%; }
@keyframes shimmer {
  0%   { background-position: -600px 0; }
  100% { background-position:  600px 0; }
}
body[data-portal="public"] .skeleton-img,
body[data-portal="public"] .skeleton-line {
  background: linear-gradient(90deg, var(--m-surface) 25%, var(--m-surface-2) 50%, var(--m-surface) 75%);
  background-size: 1200px 100%; animation: shimmer 1.4s infinite linear;
}

/* ── How it works section (dark strip in light page) ─────── */
body[data-portal="public"] .hiw-section {
  background: var(--m-ink); padding: var(--m-s-16) 0 var(--m-s-12);
  position: relative; overflow: hidden;
}
body[data-portal="public"] .hiw-section-glow {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 55% at 50% 0%, rgba(0,106,255,0.18) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 80% 90%, rgba(0,106,255,0.07) 0%, transparent 60%);
}
body[data-portal="public"] .hiw-header { text-align: center; margin-bottom: var(--m-s-12); }
body[data-portal="public"] .hiw-eyebrow {
  color: #4d9aff !important; border-color: rgba(0,106,255,0.3) !important;
  background: rgba(0,106,255,0.1) !important;
}
body[data-portal="public"] .hiw-title {
  font-family: var(--m-font-base); font-size: clamp(24px, 3.5vw, 38px);
  font-weight: 800; color: #fff; letter-spacing: -0.025em;
  margin-top: var(--m-s-3); margin-bottom: var(--m-s-3); line-height: 1.15;
}
body[data-portal="public"] .hiw-subtitle {
  font-size: 15.5px; color: rgba(255,255,255,0.68);
  max-width: 460px; margin: 0 auto; line-height: 1.65;
}
body[data-portal="public"] .hiw-track { position: relative; max-width: 880px; margin: 0 auto; }
body[data-portal="public"] .hiw-connector {
  position: absolute; top: 44px; left: calc(100% / 6); right: calc(100% / 6);
  height: 2px; background: linear-gradient(to right, var(--m-brand), rgba(0,106,255,0.25)); border-radius: 2px;
}
body[data-portal="public"] .hiw-steps {
  display: flex; justify-content: space-between; align-items: flex-start; gap: var(--m-s-6);
}
body[data-portal="public"] .hiw-step { flex: 1; display: flex; flex-direction: column; align-items: center; text-align: center; }
body[data-portal="public"] .hiw-step-bubble {
  width: 88px; height: 88px; border-radius: 50%; background: var(--m-brand);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--m-s-6); flex-shrink: 0; position: relative;
  box-shadow: 0 0 0 10px rgba(0,106,255,0.12), 0 6px 24px rgba(0,106,255,0.35);
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}
body[data-portal="public"] .hiw-step-bubble:hover {
  box-shadow: 0 0 0 14px rgba(0,106,255,0.15), 0 8px 32px rgba(0,106,255,0.45);
  transform: translateY(-2px);
}
body[data-portal="public"] .hiw-step-bubble--last { background: linear-gradient(135deg, var(--m-brand) 0%, #0050CC 100%); }
body[data-portal="public"] .hiw-step-bubble span {
  font-family: var(--m-font-base); font-size: 24px; font-weight: 900;
  color: #fff; letter-spacing: -0.03em; line-height: 1;
}
body[data-portal="public"] .hiw-step-body { display: flex; flex-direction: column; align-items: center; }
body[data-portal="public"] .hiw-step-icon { font-size: 20px; color: #4d9aff; margin-bottom: var(--m-s-3); opacity: 0.85; }
body[data-portal="public"] .hiw-step-title {
  font-family: var(--m-font-base); font-size: 16px; font-weight: 700;
  color: #fff; margin-bottom: var(--m-s-2); letter-spacing: -0.01em;
}
body[data-portal="public"] .hiw-step-desc {
  font-size: 13.5px; color: rgba(255,255,255,0.68); line-height: 1.7; max-width: 210px;
}
body[data-portal="public"] .hiw-cta {
  display: flex; align-items: center; justify-content: center;
  gap: var(--m-s-5); margin-top: var(--m-s-12); flex-wrap: wrap;
}
body[data-portal="public"] .hiw-cta-link {
  font-size: 14px; font-weight: 600; color: rgba(255,255,255,0.55);
  text-decoration: none; display: flex; align-items: center; gap: 6px;
  transition: color 0.2s;
}
body[data-portal="public"] .hiw-cta-link:hover { color: rgba(255,255,255,0.9); }
body[data-portal="public"] .hiw-cta-link i { font-size: 11px; }
@media (max-width: 700px) {
  body[data-portal="public"] .hiw-connector { display: none; }
  body[data-portal="public"] .hiw-steps { flex-direction: column; align-items: center; gap: var(--m-s-8); }
  body[data-portal="public"] .hiw-step { width: 100%; max-width: 320px; }
  body[data-portal="public"] .hiw-section { padding: var(--m-s-12) 0 var(--m-s-10); }
  body[data-portal="public"] .hiw-cta { flex-direction: column; gap: var(--m-s-3); }
}

/* ── Why-us section (dark strip in light page) ───────────── */
body[data-portal="public"] .why-section {
  background: var(--m-ink); padding: var(--m-s-24) 0;
  position: relative; overflow: hidden; margin-top: var(--m-s-10);
}
body[data-portal="public"] .why-section::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(to right, transparent 5%, rgba(0,106,255,0.3) 30%, rgba(0,106,255,0.3) 70%, transparent 95%);
}
body[data-portal="public"] .why-bg {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 80% 60% at 50% -10%, rgba(0,106,255,0.07) 0%, transparent 60%);
}
body[data-portal="public"] .why-section .section-eyebrow {
  color: #4d9aff; background: rgba(0,106,255,0.12); border: 1px solid rgba(0,106,255,0.20);
}
body[data-portal="public"] .why-section .section-title { color: #fff; }
body[data-portal="public"] .why-section .section-subtitle { color: rgba(255,255,255,0.50); }
body[data-portal="public"] .why-section-title {
  font-family: var(--m-font-base); font-size: clamp(32px, 4vw, 52px);
  font-weight: 700; color: #fff; line-height: 1.1; letter-spacing: -0.01em;
  max-width: 500px; margin: 0 auto var(--m-s-16);
}
body[data-portal="public"] .why-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--m-s-5); margin-top: var(--m-s-12);
}
body[data-portal="public"] .why-card {
  padding: var(--m-s-8); border-radius: var(--m-r-2xl);
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07);
  transition: all var(--m-dur-slow) var(--m-ease); position: relative; overflow: hidden;
}
body[data-portal="public"] .why-card::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(to right, transparent, #4d9aff, transparent);
  opacity: 0; transition: opacity var(--m-dur-slow) var(--m-ease);
}
body[data-portal="public"] .why-card:hover {
  background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.12); transform: translateY(-3px);
}
body[data-portal="public"] .why-card:hover::after { opacity: 1; }
body[data-portal="public"] .why-card-num {
  font-family: var(--m-font-base); font-size: 44px; font-weight: 800;
  line-height: 1; color: rgba(0,106,255,0.13); letter-spacing: -0.025em; margin-bottom: var(--m-s-4);
}
body[data-portal="public"] .why-card-icon {
  width: 46px; height: 46px; border-radius: var(--m-r-lg);
  background: rgba(0,106,255,0.18); border: 1px solid rgba(0,106,255,0.28);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: #80bbff; margin-bottom: var(--m-s-5);
}
body[data-portal="public"] .why-card h3 {
  font-family: var(--m-font-base); font-size: 20px; color: #fff;
  margin-bottom: var(--m-s-2); font-weight: 700; letter-spacing: -0.01em;
}
body[data-portal="public"] .why-card p { font-size: 14.5px; color: rgba(255,255,255,0.58); line-height: 1.78; }
body[data-portal="public"] .why-cta-btn {
  margin-top: var(--m-s-2); padding: 14px 32px; font-size: 15px;
  font-weight: 600; border-radius: var(--m-r-full); letter-spacing: 0.01em;
}
@media (max-width: 900px) {
  body[data-portal="public"] .why-grid { grid-template-columns: 1fr; gap: var(--m-s-4); }
}

/* ── Scroll-to-top floating button ────────────────────────── */
body[data-portal="public"] .scroll-top {
  position: fixed; bottom: var(--m-s-6); left: var(--m-s-6);
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--m-white); border: 1px solid var(--m-border);
  color: var(--m-text); font-size: 14px; cursor: pointer;
  display: none; align-items: center; justify-content: center;
  box-shadow: var(--m-shadow-md); transition: all var(--m-dur) var(--m-ease); z-index: 50;
}
body[data-portal="public"] .scroll-top:hover {
  background: var(--m-ink); color: #fff; border-color: var(--m-ink); transform: translateY(-2px);
}
body[data-portal="public"] .scroll-top.visible { display: flex; }

/* ── Toast notifications (dark pill, bottom-right) ───────── */
body[data-portal="public"] .toast-container {
  position: fixed; bottom: var(--m-s-6); right: var(--m-s-6);
  z-index: 70; display: flex; flex-direction: column; gap: var(--m-s-3);
  pointer-events: none;
}
body[data-portal="public"] .toast {
  background: var(--m-ink); color: #fff; border-radius: var(--m-r-xl);
  padding: var(--m-s-4) var(--m-s-5);
  display: flex; align-items: center; gap: var(--m-s-3);
  min-width: 300px; max-width: 400px; box-shadow: var(--m-shadow-lg);
  pointer-events: all; font-size: 14px; font-weight: 500;
  animation: toastIn 250ms var(--m-ease-out) forwards;
  border: 1px solid rgba(255,255,255,0.08);
}
body[data-portal="public"] .toast.toast-success i { color: #34d399; }
body[data-portal="public"] .toast.toast-error i { color: #f87171; }
@keyframes toastIn {
  from { transform: translateY(20px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}

/* ── Image lazy-load fade-in (CSP-safe; no inline JS) ────── */
body[data-portal="public"] .property-card-img img:not(.cp-img-loaded) { opacity: 0; }
body[data-portal="public"] .property-card-img img.cp-img-loaded {
  opacity: 1; transition: opacity 300ms var(--m-ease-out);
}

/* ── Generic spinner used in the empty state inline icon ── */
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
body[data-portal="public"] .spinner {
  width: 36px; height: 36px; border: 3px solid var(--m-border);
  border-top-color: var(--m-brand); border-radius: 50%; animation: spin 0.7s linear infinite;
}

/* ============================================================
   LISTINGS PAGE COMPONENTS (sub-phase 7.3.2)
   Scoped to body[data-portal="public"][data-page="listings"]
   where listings-only, otherwise body[data-portal="public"] for
   shared components reused on /property.html (sub-phase 7.3.3).
   ============================================================ */

/* ── Listings page header (search row above the filter bar) ── */
body[data-portal="public"] .listings-page-header {
  background: var(--m-white);
  border-bottom: 1px solid var(--m-border);
  padding: 28px 0 20px;
  margin-top: var(--m-nav-h);
}
body[data-portal="public"] .listings-page-header .container {
  max-width: var(--m-max-w);
  margin: 0 auto;
  padding: 0 var(--m-s-6);
}
body[data-portal="public"] .listings-page-title {
  font-size: clamp(22px, 3vw, 28px);
  font-weight: 700;
  color: var(--m-ink);
  letter-spacing: -0.02em;
  margin: 0 0 4px;
}
body[data-portal="public"] .listings-page-subtitle {
  font-size: 14px;
  color: var(--m-muted);
  margin: 0 0 18px;
}
body[data-portal="public"] .listings-page-subtitle strong {
  color: var(--m-brand);
  font-weight: 600;
}
body[data-portal="public"] .listings-search-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
body[data-portal="public"] .listings-search-row .search-field {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--m-surface);
  border: 1px solid var(--m-border);
  border-radius: var(--m-r-lg);
  padding: 0 14px;
  height: 42px;
  font-size: 14px;
  color: var(--m-text);
  transition: border-color 0.15s;
  /* Reset homepage search-field stack styles */
  flex-direction: row;
  border-bottom: 1px solid var(--m-border);
  border-right: 1px solid var(--m-border);
  margin: 0;
}
body[data-portal="public"] .listings-search-row .search-field:first-child { border-radius: var(--m-r-lg); }
body[data-portal="public"] .listings-search-row .search-field:focus-within { border-color: var(--m-brand); }
body[data-portal="public"] .listings-search-row .search-field i {
  color: var(--m-muted-2); font-size: 12px; flex-shrink: 0;
}
body[data-portal="public"] .listings-search-row .search-field input,
body[data-portal="public"] .listings-search-row .search-field select {
  border: none; background: transparent; outline: none;
  font-size: 14px; color: var(--m-text); width: 100%;
  font-family: var(--m-font-base);
}
body[data-portal="public"] .listings-search-row .search-field.sf-text { flex: 1; min-width: 180px; }
body[data-portal="public"] .listings-search-row .search-field.sf-select { min-width: 120px; }
body[data-portal="public"] .listings-search-btn {
  height: 42px; padding: 0 20px;
  background: var(--m-brand); color: #fff;
  border: none; border-radius: var(--m-r-lg);
  font-size: 14px; font-weight: 600; cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px;
  transition: background 0.15s, opacity 0.15s;
  white-space: nowrap;
  font-family: var(--m-font-base);
}
body[data-portal="public"] .listings-search-btn:hover { background: var(--m-brand-dark); }
@media (max-width: 640px) {
  body[data-portal="public"] .listings-page-header { padding: 16px 0 14px; }
  body[data-portal="public"] .listings-search-row .search-field.sf-select { min-width: 100px; }
  body[data-portal="public"] .listings-page-title { font-size: 20px; }
}

/* ── Filter bar (sticky pills row under the page header) ── */
body[data-portal="public"] .filter-bar {
  background: var(--m-white);
  border-bottom: 1px solid var(--m-border);
  position: sticky; top: var(--m-nav-h); z-index: 40;
  box-shadow: 0 1px 0 var(--m-border), 0 4px 16px rgba(0,0,0,0.04);
}
body[data-portal="public"] .filter-bar-inner {
  max-width: var(--m-max-w); margin: 0 auto;
  padding: 0 var(--m-s-6); height: 56px;
  display: flex; align-items: center; gap: var(--m-s-2);
  overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 24px, #000 calc(100% - 48px), transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 24px, #000 calc(100% - 48px), transparent 100%);
}
body[data-portal="public"] .filter-bar-inner::-webkit-scrollbar { display: none; }
body[data-portal="public"] .filter-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 15px; border-radius: var(--m-r-full);
  font-family: var(--m-font-base); font-size: 12.5px; font-weight: 600;
  border: 1.5px solid var(--m-border); background: var(--m-white);
  color: var(--m-muted); cursor: pointer; white-space: nowrap;
  transition: all var(--m-dur) var(--m-ease); flex-shrink: 0; letter-spacing: -0.01em;
}
body[data-portal="public"] .filter-pill:hover {
  border-color: var(--m-ink); color: var(--m-ink); background: var(--m-surface);
}
body[data-portal="public"] .filter-pill.active {
  background: var(--m-brand); border-color: var(--m-brand); color: #fff;
}
body[data-portal="public"] .filter-pill i { font-size: 10.5px; }
body[data-portal="public"] .filter-divider {
  width: 1px; height: 20px; background: var(--m-border); flex-shrink: 0; margin: 0 var(--m-s-1);
}
body[data-portal="public"] .filter-count {
  margin-left: auto; font-size: 12.5px; color: var(--m-muted-2);
  white-space: nowrap; flex-shrink: 0; font-weight: 500; padding-right: var(--m-s-2);
}
body[data-portal="public"] .filter-active-badge {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--m-brand); color: #fff;
  border-radius: var(--m-r-full); min-width: 18px; height: 18px;
  font-size: 10px; font-weight: 700; padding: 0 5px;
  line-height: 1; margin-left: 2px;
}
body[data-portal="public"] .filter-pill-clear {
  border-color: #e53e3e !important;
  color: #e53e3e !important;
}
body[data-portal="public"] .filter-pill-clear:hover {
  background: #e53e3e !important;
  color: #fff !important;
}
body[data-portal="public"] .mobile-filters-btn {
  display: none;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border: 1.5px solid var(--m-brand);
  border-radius: var(--m-r-full);
  background: #fff;
  color: var(--m-brand);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  font-family: var(--m-font-base);
}
body[data-portal="public"] .mobile-filters-btn:hover {
  background: var(--m-brand);
  color: #fff;
}
body[data-portal="public"] .mobile-filters-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e53e3e;
  color: #fff;
  border-radius: 50%;
  font-size: 10px;
  width: 18px;
  height: 18px;
  font-weight: 700;
}

/* ── Advanced filter dropdown (popover from "More Filters" pill) ── */
body[data-portal="public"] .filter-dropdown-wrap { position: relative; flex-shrink: 0; }
body[data-portal="public"] .filter-dropdown {
  position: absolute; top: calc(100% + 8px); left: 0;
  background: var(--m-white); border: 1px solid var(--m-border);
  border-radius: var(--m-r-2xl); box-shadow: var(--m-shadow-lg);
  padding: var(--m-s-5); min-width: 300px; z-index: 200;
  display: none; flex-direction: column; gap: var(--m-s-4);
  animation: dropDown 150ms var(--m-ease-out) forwards;
}
body[data-portal="public"] .filter-dropdown.open { display: flex; }
@keyframes dropDown {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
body[data-portal="public"] .filter-dropdown-title {
  font-size: 11.5px; font-weight: 700; color: var(--m-muted-2);
  text-transform: uppercase; letter-spacing: 0.08em;
  padding-bottom: var(--m-s-3); border-bottom: 1px solid var(--m-border);
}
body[data-portal="public"] .filter-dropdown-row { display: flex; flex-direction: column; gap: 5px; }
body[data-portal="public"] .filter-dropdown-row label {
  font-size: 12.5px; font-weight: 600; color: var(--m-text);
}
body[data-portal="public"] .filter-dropdown-row select,
body[data-portal="public"] .filter-dropdown-row input {
  width: 100%; padding: 9px 12px;
  border: 1.5px solid var(--m-border); border-radius: var(--m-r);
  font-size: 13.5px; font-family: var(--m-font-base); outline: none;
  appearance: none; transition: border-color var(--m-dur) var(--m-ease);
  background: var(--m-surface); color: var(--m-text);
}
body[data-portal="public"] .filter-dropdown-row select:focus,
body[data-portal="public"] .filter-dropdown-row input:focus {
  border-color: var(--m-brand);
  box-shadow: 0 0 0 3px rgba(0,106,255,0.18);
}
body[data-portal="public"] .filter-dropdown-actions {
  display: flex; gap: var(--m-s-2);
  padding-top: var(--m-s-2); border-top: 1px solid var(--m-border);
}
body[data-portal="public"] .filter-dropdown-actions button {
  flex: 1; padding: 10px; border-radius: var(--m-r);
  font-size: 13px; font-weight: 600; cursor: pointer;
  font-family: var(--m-font-base); transition: all var(--m-dur) var(--m-ease); border: none;
}
body[data-portal="public"] .filter-btn-apply {
  background: var(--m-brand); color: #fff;
}
body[data-portal="public"] .filter-btn-apply:hover { background: var(--m-brand-dark); }
body[data-portal="public"] .filter-btn-clear {
  background: var(--m-surface); color: var(--m-text);
}
body[data-portal="public"] .filter-btn-clear:hover { background: var(--m-border); }
body[data-portal="public"] .filter-dropdown-mobile-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
}
body[data-portal="public"] .filter-dropdown-mobile-header .filter-dropdown-title {
  margin-bottom: 0; padding-bottom: 0; border-bottom: none;
}
body[data-portal="public"] .filter-dropdown-clear-all {
  background: none; border: none; color: #e53e3e;
  font-size: 13px; font-weight: 600; cursor: pointer;
  display: flex; align-items: center; gap: 4px;
  padding: 4px 8px; border-radius: 4px;
  font-family: var(--m-font-base);
}
body[data-portal="public"] .filter-dropdown-clear-all:hover { background: #fff5f5; }
@media (max-width: 640px) {
  body[data-portal="public"] .filter-dropdown {
    position: fixed; top: auto; bottom: 0; left: 0; right: 0;
    width: 100%; max-width: none; min-width: auto;
    border-radius: var(--m-r-2xl) var(--m-r-2xl) 0 0;
    border: 1px solid var(--m-border);
    border-bottom: none;
    z-index: 300;
    animation: slideUp 200ms var(--m-ease-out) forwards;
  }
  @keyframes slideUp {
    from { transform: translateY(100%); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
  }
  body[data-portal="public"] .mobile-filters-btn { display: inline-flex; }
  body[data-portal="public"] .filter-bar-inner .filter-pill,
  body[data-portal="public"] .filter-bar-inner .filter-divider,
  body[data-portal="public"] .filter-bar-inner #moreFiltersWrap {
    display: none !important;
  }
  body[data-portal="public"] .filter-bar-inner #clearAllPill { display: none !important; }
}
@media (min-width: 641px) {
  body[data-portal="public"] .mobile-filters-btn { display: none !important; }
}

/* ── Listings section (results grid) ── */
body[data-portal="public"] .listings-section {
  padding: var(--m-s-12) 0 var(--m-s-24);
  background: var(--m-surface);
}
body[data-portal="public"] .listings-header {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: var(--m-s-8); flex-wrap: wrap; gap: var(--m-s-4);
}
body[data-portal="public"] .listings-heading,
body[data-portal="public"] .listings-header h2 {
  font-family: var(--m-font-base); font-size: clamp(22px, 3vw, 30px);
  font-weight: 700; color: var(--m-ink);
  letter-spacing: -0.01em; line-height: 1; margin: 0;
}
body[data-portal="public"] .listings-subheading {
  font-size: 13.5px; color: var(--m-muted-2); margin-top: 4px;
}
body[data-portal="public"] .listings-controls {
  display: flex; align-items: center; gap: var(--m-s-3);
}
body[data-portal="public"] .listings-sort {
  display: flex; align-items: center; gap: var(--m-s-2);
  font-size: 13.5px; color: var(--m-muted);
}
body[data-portal="public"] .listings-sort select {
  border: 1.5px solid var(--m-border); border-radius: var(--m-r-xl);
  padding: 8px 32px 8px 12px; font-size: 12.5px; font-family: var(--m-font-base);
  outline: none; cursor: pointer; background: var(--m-white);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
  background-repeat: no-repeat; background-position: right 8px center;
  background-size: 16px; appearance: none; color: var(--m-text);
  transition: border-color var(--m-dur) var(--m-ease);
}
body[data-portal="public"] .listings-sort select:focus { border-color: var(--m-brand); }
body[data-portal="public"] .view-toggle {
  display: flex; background: var(--m-white);
  border: 1px solid var(--m-border); border-radius: var(--m-r-xl);
  overflow: hidden; box-shadow: var(--m-shadow-sm);
}
body[data-portal="public"] .view-toggle-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 14px; border: none; background: transparent;
  font-size: 12.5px; font-weight: 500; color: var(--m-muted);
  cursor: pointer; transition: all var(--m-dur) var(--m-ease);
  font-family: var(--m-font-base);
}
body[data-portal="public"] .view-toggle-btn:hover {
  color: var(--m-text); background: var(--m-surface);
}
body[data-portal="public"] .view-toggle-btn.active {
  background: var(--m-brand); color: #fff;
}
body[data-portal="public"] .view-toggle-btn i { font-size: 11px; }

/* ── Property card extensions for the full grid (overlays, badges, dots) ── */
body[data-portal="public"] .property-card-img::after {
  content: '';
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(ellipse 130% 110% at 50% 40%, transparent 48%, rgba(0,0,0,0.18) 100%),
    linear-gradient(to top, rgba(0,0,0,0.42) 0%, rgba(0,0,0,0.14) 30%, transparent 58%);
}
body[data-portal="public"] .property-card-slides {
  position: absolute; inset: 0; width: 100%; height: 100%;
  display: flex;
  transition: transform 380ms cubic-bezier(0.22,1,0.36,1);
}
body[data-portal="public"] .property-card-slide {
  min-width: 100%; width: 100%; height: 100%;
  flex-shrink: 0; position: relative; overflow: hidden;
  opacity: 1; transition: none; /* override homepage opacity-0 default */
}
body[data-portal="public"] .property-card-slide img {
  display: block; width: 100%; height: 100%;
  object-fit: cover; object-position: center center;
  opacity: 0;
  filter: blur(20px) saturate(0.7);
  transform: scale(1.04);
  transition: transform 600ms cubic-bezier(0.22,1,0.36,1), opacity 400ms ease, filter 400ms ease;
  will-change: opacity, filter, transform;
}
body[data-portal="public"] .property-card-slide img.cp-img-loaded {
  opacity: 1; filter: none; transform: scale(1);
}
body[data-portal="public"] .property-card:hover .property-card-slide img.cp-img-loaded {
  transform: scale(1.05);
  transition: transform 5s cubic-bezier(0.22,1,0.36,1), opacity 400ms ease, filter 400ms ease;
}
body[data-portal="public"] .property-card-badge {
  position: absolute; top: 12px; left: 12px; z-index: 6;
  border-radius: 100px; padding: 5px 11px 5px 9px;
  font-size: 10.5px; font-weight: 700; letter-spacing: 0.04em;
  display: inline-flex; align-items: center; gap: 5px;
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 2px 10px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.35);
  pointer-events: none;
}
body[data-portal="public"] .property-card-badge i { font-size: 9px; flex-shrink: 0; }
body[data-portal="public"] .property-card-badge.badge-featured  { background: #006aff; color: #fff; }
body[data-portal="public"] .property-card-badge.badge-verified  { background: rgba(255,255,255,0.92); color: #006aff; }
body[data-portal="public"] .property-card-badge.badge-available { background: rgba(5,150,105,0.90); color: #fff; }
body[data-portal="public"] .property-card-badge.badge-avail-date { background: rgba(217,119,6,0.90); color: #fff; }
body[data-portal="public"] .property-card-type-chip {
  position: absolute; bottom: 10px; left: 10px; z-index: 7;
  background: rgba(0,0,0,0.54); color: rgba(255,255,255,0.95);
  border-radius: 100px; padding: 4px 11px;
  font-size: 10.5px; font-weight: 600; letter-spacing: 0.04em;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  pointer-events: none;
  box-shadow: 0 1px 6px rgba(0,0,0,0.25);
}
body[data-portal="public"] .property-card-photo-count {
  position: absolute; bottom: 10px; left: 10px; z-index: 7;
  background: rgba(0,0,0,0.52); color: rgba(255,255,255,0.92);
  border-radius: 100px; padding: 4px 10px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.01em;
  display: inline-flex; align-items: center; gap: 5px;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  pointer-events: none;
}
body[data-portal="public"] .property-card-photo-count i { font-size: 9px; opacity: 0.82; }
body[data-portal="public"] .property-card-dots {
  position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%);
  z-index: 7; display: flex; align-items: center; gap: 5px;
  pointer-events: none;
}
body[data-portal="public"] .property-card-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: rgba(255,255,255,0.50);
  transition: background 220ms ease, width 260ms cubic-bezier(0.34,1.56,0.64,1), border-radius 260ms ease;
  flex-shrink: 0;
}
body[data-portal="public"] .property-card-dot.active {
  background: #fff; width: 14px; border-radius: 100px;
}
body[data-portal="public"] .property-card-type {
  font-size: 10.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--m-brand); margin-bottom: 5px; line-height: 1;
}
body[data-portal="public"] .property-card-price-dollar { color: var(--m-brand); }
body[data-portal="public"] .property-card-price-unit {
  font-size: 13px; font-weight: 500; color: var(--m-muted-2); letter-spacing: 0;
}
body[data-portal="public"] .property-card-specs {
  display: flex; align-items: center; flex-wrap: wrap;
  font-size: 13px; font-weight: 600; color: var(--m-muted);
  margin-bottom: 8px; gap: 0;
}
body[data-portal="public"] .property-card-spec-item {
  display: flex; align-items: center; gap: 4px; white-space: nowrap;
}
body[data-portal="public"] .property-card-spec-item i {
  font-size: 10px; color: var(--m-brand);
}
body[data-portal="public"] .property-card-spec-sep {
  margin: 0 8px; color: var(--m-muted-2); font-size: 10px; user-select: none;
}
/* Heart pop animation when a card is saved */
@keyframes cp-heart-pop {
  0%   { transform: scale(1.0); }
  35%  { transform: scale(1.45); }
  65%  { transform: scale(0.90); }
  100% { transform: scale(1.0); }
}
body[data-portal="public"] .property-card-save.saved {
  color: #ef4444; background: #fff;
  box-shadow: 0 4px 18px rgba(239,68,68,0.28);
  animation: cp-heart-pop 420ms cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"] .property-card-save.saved { animation: none; }
}

/* ── Empty state (no listings match) ── */
body[data-portal="public"] .empty-state {
  text-align: center;
  padding: var(--m-s-24) var(--m-s-6);
  grid-column: 1 / -1;
}
body[data-portal="public"] .empty-state-icon {
  width: 72px; height: 72px;
  background: var(--m-brand-pale); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--m-s-5);
  font-size: 28px; color: var(--m-brand);
  border: 1px solid rgba(0,106,255,0.15);
}
body[data-portal="public"] .empty-state h3 {
  font-family: var(--m-font-base);
  font-size: 22px; font-weight: 700; color: var(--m-ink);
  margin-bottom: var(--m-s-2);
}
body[data-portal="public"] .empty-state p {
  font-size: 15px; color: var(--m-muted-2);
  max-width: 360px; margin: 0 auto;
}

/* ── Map view (Leaflet container + custom markers + popup) ── */
body[data-portal="public"] #mapPanel {
  display: none; position: relative;
  height: calc(100vh - var(--m-nav-h) - 56px);
  height: calc(100dvh - var(--m-nav-h) - 56px);
  min-height: 500px;
  background: var(--m-surface);
  border-radius: var(--m-r-2xl);
  overflow: hidden;
}
body[data-portal="public"] #mapPanel.active { display: block; }
body[data-portal="public"] #listingsMap { width: 100%; height: 100%; }
body[data-portal="public"] .map-marker-price {
  background: var(--m-ink); color: #fff;
  border-radius: var(--m-r); padding: 5px 10px;
  font-family: var(--m-font-base); font-size: 12px; font-weight: 700;
  box-shadow: var(--m-shadow-md); white-space: nowrap;
  border: 2px solid rgba(255,255,255,0.15);
}
body[data-portal="public"] .map-popup-card {
  display: flex; flex-direction: column;
  text-decoration: none; color: var(--m-text);
}
body[data-portal="public"] .map-popup-img {
  width: 100%; height: 140px; object-fit: cover;
  border-radius: var(--m-r); margin-bottom: var(--m-s-3);
}
body[data-portal="public"] .map-popup-price {
  font-family: var(--m-font-base);
  font-size: 22px; font-weight: 700; color: var(--m-ink);
}
body[data-portal="public"] .map-popup-price span {
  font-size: 12px; color: var(--m-muted-2);
}
body[data-portal="public"] .map-popup-title {
  font-size: 13px; color: var(--m-muted); margin: 2px 0 4px;
}
body[data-portal="public"] .map-popup-meta {
  display: flex; gap: 8px; font-size: 12px; color: var(--m-muted-2);
}
body[data-portal="public"] .map-popup-apply {
  display: block; margin-top: 10px; text-align: center;
  background: var(--m-brand); color: #fff;
  padding: 8px; border-radius: var(--m-r-full);
  font-size: 13px; font-weight: 700;
}
body[data-portal="public"] #mapLoadingSpinner {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%); z-index: 10;
  display: none; align-items: center; justify-content: center;
  flex-direction: column; gap: 12px;
}
body[data-portal="public"] #mapLoadingSpinner .spinner {
  width: 40px; height: 40px;
  border: 3px solid var(--m-border);
  border-top-color: var(--m-brand);
  border-radius: 50%; animation: spin 0.7s linear infinite;
}
body[data-portal="public"] #mapLoadingSpinner p {
  color: var(--m-muted-2); font-size: 13px; margin: 0;
}

/* ── Pagination (numbered page buttons) ── */
body[data-portal="public"] .pagination {
  display: flex; align-items: center; gap: 4px;
  flex-wrap: wrap; justify-content: center;
}
body[data-portal="public"] .pg-btn {
  min-width: 38px; height: 38px; padding: 0 10px;
  border: 1px solid var(--m-border);
  border-radius: var(--m-r);
  background: var(--m-white);
  color: var(--m-text);
  font-size: 14px; font-weight: 500; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  font-family: var(--m-font-base);
}
body[data-portal="public"] .pg-btn:hover:not(:disabled) {
  background: var(--m-surface-2);
  border-color: var(--m-brand);
}
body[data-portal="public"] .pg-btn.pg-active {
  background: var(--m-brand);
  border-color: var(--m-brand);
  color: #fff;
  font-weight: 700; cursor: default;
}
body[data-portal="public"] .pg-btn:disabled {
  opacity: 0.35; cursor: not-allowed;
}
body[data-portal="public"] .pg-ellipsis {
  min-width: 28px; text-align: center;
  color: var(--m-muted-2); font-size: 14px; user-select: none;
}
body[data-portal="public"] .pg-prev,
body[data-portal="public"] .pg-next { font-size: 12px; }
@media (max-width: 480px) {
  body[data-portal="public"] .pg-btn { min-width: 34px; height: 34px; font-size: 13px; }
}

/* ============================================================
   PROPERTY DETAIL PAGE COMPONENTS — sub-phase 7.3.3
   Scoped to body[data-portal="public"][data-page="property"].
   Token sources: --m-* defined above.
   ============================================================ */

/* ── GALLERY MOSAIC ───────────────────────────────────────── */
body[data-portal="public"][data-page="property"] .gallery-mosaic {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 6px;
  height: clamp(300px, 48vw, 660px);
  background: #0a0a0a;
  position: relative;
  overflow: hidden;
  border-radius: var(--m-r-2xl);
  box-shadow: 0 8px 40px rgba(0,0,0,0.18);
  contain: layout style;
  margin-top: var(--m-nav-h);
}
@media (max-width: 900px) {
  body[data-portal="public"][data-page="property"] .gallery-mosaic {
    grid-template-columns: 1fr;
    gap: 8px;
    height: auto;
  }
  body[data-portal="public"][data-page="property"] .mosaic-main,
  body[data-portal="public"][data-page="property"] .mosaic-side,
  body[data-portal="public"][data-page="property"] .mosaic-cell,
  body[data-portal="public"][data-page="property"] .mosaic-main-img,
  body[data-portal="public"][data-page="property"] .mosaic-cell img { height: auto; }
  body[data-portal="public"][data-page="property"] .mosaic-main,
  body[data-portal="public"][data-page="property"] .mosaic-cell { border-radius: var(--m-r-lg); }
  body[data-portal="public"][data-page="property"] .mosaic-side {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, minmax(98px, 1fr));
  }
}
@media (max-width: 500px) {
  body[data-portal="public"][data-page="property"] .gallery-mosaic {
    height: auto;
    box-shadow: none;
    border-radius: var(--m-r-xl);
  }
  body[data-portal="public"][data-page="property"] .mosaic-main:hover .mosaic-main-img,
  body[data-portal="public"][data-page="property"] .mosaic-cell:hover img { transform: none; }
  body[data-portal="public"][data-page="property"] .mosaic-side { display: none !important; }
}

/* Gallery skeleton shimmer */
body[data-portal="public"][data-page="property"] .gallery-mosaic.skeleton-loading .mosaic-main,
body[data-portal="public"][data-page="property"] .gallery-mosaic.skeleton-loading .mosaic-cell {
  background: linear-gradient(90deg, #1a1a1a 0%, #2a2a2a 50%, #1a1a1a 100%);
  background-size: 200% 100%;
  animation: cp-gallery-shimmer 1.6s ease-in-out infinite;
}
body[data-portal="public"][data-page="property"] .gallery-mosaic.skeleton-loading .mosaic-main-img,
body[data-portal="public"][data-page="property"] .gallery-mosaic.skeleton-loading .mosaic-cell img,
body[data-portal="public"][data-page="property"] .gallery-mosaic.skeleton-loading .lqip-bg { opacity: 0; }
@keyframes cp-gallery-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

body[data-portal="public"][data-page="property"] .mosaic-main {
  position: relative; overflow: hidden; cursor: zoom-in;
  border-radius: var(--m-r-lg) 0 0 var(--m-r-lg);
  touch-action: pan-y;
}
body[data-portal="public"][data-page="property"] .mosaic-main::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.22) 0%, transparent 50%);
  pointer-events: none; z-index: 1; opacity: 0;
  transition: opacity 300ms ease;
}
body[data-portal="public"][data-page="property"] .mosaic-main:hover::after { opacity: 1; }
body[data-portal="public"][data-page="property"] .mosaic-main-img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  display: block; position: relative; z-index: 1; will-change: transform;
}
body[data-portal="public"][data-page="property"] .mosaic-main:hover .mosaic-main-img { transform: scale(1.04); }

body[data-portal="public"][data-page="property"] .mosaic-side {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 6px;
}
body[data-portal="public"][data-page="property"] .mosaic-cell {
  position: relative; overflow: hidden; cursor: zoom-in; background: #111;
}
body[data-portal="public"][data-page="property"] .mosaic-cell:nth-child(2) { border-radius: 0 var(--m-r-lg) 0 0; }
body[data-portal="public"][data-page="property"] .mosaic-cell:nth-child(4) { border-radius: 0 0 var(--m-r-lg) 0; }
body[data-portal="public"][data-page="property"] .mosaic-cell::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.30) 0%, transparent 55%);
  pointer-events: none; z-index: 1; opacity: 0;
  transition: opacity 280ms ease;
}
body[data-portal="public"][data-page="property"] .mosaic-cell:hover::after { opacity: 1; }
body[data-portal="public"][data-page="property"] .mosaic-cell img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  display: block; position: relative; z-index: 1; will-change: transform;
}
body[data-portal="public"][data-page="property"] .mosaic-cell:hover img { transform: scale(1.07); }

body[data-portal="public"][data-page="property"] .mosaic-cell-overlay {
  position: absolute; inset: 0; z-index: 2;
  background: rgba(0,0,0,0.50);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px;
  color: #fff; font-family: var(--m-font-base);
  pointer-events: none; transition: background 200ms ease;
}
body[data-portal="public"][data-page="property"] .mosaic-cell:hover .mosaic-cell-overlay { background: rgba(0,0,0,0.58); }
body[data-portal="public"][data-page="property"] .mosaic-overlay-icon  { font-size: 22px; opacity: 0.92; }
body[data-portal="public"][data-page="property"] .mosaic-overlay-label { font-size: 12px; font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase; }

body[data-portal="public"][data-page="property"] .mosaic-expand-btn {
  position: absolute; bottom: var(--m-s-5); right: var(--m-s-5); z-index: 10;
  background: rgba(255,255,255,0.97);
  border: 1.5px solid rgba(255,255,255,0.7);
  border-radius: var(--m-r-lg); padding: 10px 18px;
  font-family: var(--m-font-base); font-size: 13px; font-weight: 700;
  color: var(--m-ink); cursor: pointer;
  display: flex; align-items: center; gap: 8px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.28), 0 2px 8px rgba(0,0,0,0.16);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  opacity: 0; pointer-events: none; transform: translateY(4px);
  transition: opacity 220ms ease, transform 220ms ease, box-shadow 200ms ease, background 200ms ease;
}
body[data-portal="public"][data-page="property"] .gallery-mosaic:hover .mosaic-expand-btn {
  opacity: 1; pointer-events: auto; transform: translateY(0);
}
body[data-portal="public"][data-page="property"] .mosaic-expand-btn:hover {
  background: #fff; transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.32), 0 4px 12px rgba(0,0,0,0.18);
}
body[data-portal="public"][data-page="property"] .mosaic-expand-btn i { font-size: 12px; color: var(--m-brand); }
body[data-portal="public"][data-page="property"] .mosaic-expand-btn .mosaic-photo-count {
  background: transparent; color: inherit;
  border-radius: 6px; padding: 0;
  font-size: 11px; font-weight: 700; letter-spacing: 0.03em;
}
body[data-portal="public"][data-page="property"] .mosaic-nav-btn { display: none !important; }
body[data-portal="public"][data-page="property"] .mosaic-mobile-count { display: none !important; }
body[data-portal="public"][data-page="property"] #galleryExpand { display: none; }

/* ── GALLERY THUMBNAIL STRIP ─────────────────────────────── */
body[data-portal="public"][data-page="property"] .gallery-strip {
  display: flex; gap: 6px;
  overflow-x: auto;
  padding: 10px var(--m-s-6) 8px;
  scrollbar-width: none; -webkit-overflow-scrolling: touch;
  margin-top: 0;
}
@media (max-width: 640px) {
  body[data-portal="public"][data-page="property"] .gallery-strip { padding-left: var(--m-s-4); padding-right: var(--m-s-4); }
}
body[data-portal="public"][data-page="property"] .gallery-strip::-webkit-scrollbar { display: none; }
body[data-portal="public"][data-page="property"] .gallery-strip:empty { display: none; }
body[data-portal="public"][data-page="property"] .gallery-strip-thumb {
  flex-shrink: 0; width: 108px; height: 72px;
  border-radius: var(--m-r-lg); overflow: hidden; cursor: pointer;
  border: 2.5px solid transparent; opacity: 0.58;
  transition: opacity 180ms ease, border-color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
  background: var(--m-surface-2); padding: 0;
}
body[data-portal="public"][data-page="property"] .gallery-strip-thumb img {
  width: 100%; height: 100%; object-fit: cover; display: block; pointer-events: none;
}
body[data-portal="public"][data-page="property"] .gallery-strip-thumb:hover { opacity: 0.85; transform: translateY(-2px); }
body[data-portal="public"][data-page="property"] .gallery-strip-thumb.active {
  opacity: 1; border-color: var(--m-brand);
  transform: translateY(-2px);
  box-shadow: 0 4px 18px rgba(0,106,255,0.22);
}

/* ── LIGHTBOX ─────────────────────────────────────────────── */
@keyframes cp-lb-open       { from { opacity: 0; } to { opacity: 1; } }
@keyframes cp-lb-stage-in   { from { opacity: 0; transform: scale(0.97); } to { opacity: 1; transform: scale(1); } }
@keyframes cp-lb-spin       { to { transform: rotate(360deg); } }
@keyframes cp-lb-slide-left  { from { opacity: 0; transform: translateX(48px) scale(0.97); } to { opacity: 1; transform: translateX(0) scale(1); } }
@keyframes cp-lb-slide-right { from { opacity: 0; transform: translateX(-48px) scale(0.97); } to { opacity: 1; transform: translateX(0) scale(1); } }

body[data-portal="public"][data-page="property"] .lightbox {
  display: none; position: fixed; inset: 0; z-index: 300;
  background: rgba(0,0,0,0.97);
  flex-direction: column; align-items: stretch; justify-content: stretch;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
}
body[data-portal="public"][data-page="property"] .lightbox.open {
  display: flex; animation: cp-lb-open 220ms ease forwards;
}
body[data-portal="public"][data-page="property"] .lightbox.open .lightbox-stage {
  animation: cp-lb-stage-in 280ms cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
body[data-portal="public"][data-page="property"] .lb-spinner {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none; z-index: 6; opacity: 0;
  transition: opacity 160ms ease;
}
body[data-portal="public"][data-page="property"] .lb-spinner.visible { opacity: 1; }
body[data-portal="public"][data-page="property"] .lb-spinner::after {
  content: ''; width: 40px; height: 40px;
  border: 3px solid rgba(255,255,255,0.15);
  border-top-color: rgba(255,255,255,0.85);
  border-radius: 50%; animation: cp-lb-spin 700ms linear infinite;
}
body[data-portal="public"][data-page="property"] .lb-lqip-bg {
  position: absolute; inset: 0; z-index: 2;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  filter: blur(28px); transform: scale(1.08);
  pointer-events: none; opacity: 0;
  transition: opacity 200ms ease;
  border-radius: 8px; overflow: hidden;
}
body[data-portal="public"][data-page="property"] .lb-lqip-bg.visible { opacity: 1; }
body[data-portal="public"][data-page="property"] .lb-lqip-bg.faded   { opacity: 0; transition: opacity 500ms ease; }
body[data-portal="public"][data-page="property"] .lightbox-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 28px; flex-shrink: 0; position: relative; z-index: 2;
  background: linear-gradient(to bottom, rgba(0,0,0,0.55) 0%, transparent 100%);
}
body[data-portal="public"][data-page="property"] .lightbox-counter {
  font-family: var(--m-font-base); font-size: 13px; font-weight: 700;
  color: rgba(255,255,255,0.90);
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--m-r-full);
  padding: 6px 18px; letter-spacing: 0.04em; text-transform: uppercase;
}
body[data-portal="public"][data-page="property"] .lightbox-close {
  background: rgba(255,255,255,0.12);
  border: 1.5px solid rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.92);
  width: 44px; height: 44px; border-radius: 50%;
  font-size: 17px;
  display: flex; align-items: center; justify-content: center; cursor: pointer;
  transition: background 180ms ease, transform 180ms ease, border-color 180ms ease;
}
body[data-portal="public"][data-page="property"] .lightbox-close:hover {
  background: rgba(255,255,255,0.24); border-color: rgba(255,255,255,0.32);
  transform: scale(1.10) rotate(90deg);
}
body[data-portal="public"][data-page="property"] .lightbox-stage {
  flex: 1; display: flex; align-items: center; justify-content: center;
  position: relative; min-height: 0;
  padding: 0 clamp(52px, 10vw, 76px);
  touch-action: pan-y;
}
body[data-portal="public"][data-page="property"] .lightbox-img-wrap {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
  will-change: opacity, transform; position: relative;
}
body[data-portal="public"][data-page="property"] .lightbox-img-wrap.slide-in-left  { animation: cp-lb-slide-left  240ms cubic-bezier(0.22,0.61,0.36,1) both; }
body[data-portal="public"][data-page="property"] .lightbox-img-wrap.slide-in-right { animation: cp-lb-slide-right 240ms cubic-bezier(0.22,0.61,0.36,1) both; }
body[data-portal="public"][data-page="property"] .lightbox-img-wrap.slide-out-left  { animation: cp-lb-slide-right 160ms ease both reverse; }
body[data-portal="public"][data-page="property"] .lightbox-img-wrap.slide-out-right { animation: cp-lb-slide-left  160ms ease both reverse; }
body[data-portal="public"][data-page="property"] .lightbox-img {
  max-width: 100%; max-height: 100%; object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 32px 96px rgba(0,0,0,0.80);
  display: block; will-change: opacity, transform;
  transition: opacity 200ms ease;
  position: relative; z-index: 3;
}
body[data-portal="public"][data-page="property"] .lightbox-img.loading { opacity: 0; }
body[data-portal="public"][data-page="property"] .lightbox-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(255,255,255,0.10);
  border: 1.5px solid rgba(255,255,255,0.20);
  color: rgba(255,255,255,0.94);
  font-size: 20px;
  display: flex; align-items: center; justify-content: center; cursor: pointer;
  transition: background 180ms ease, transform 200ms ease, border-color 180ms ease;
  z-index: 5;
}
body[data-portal="public"][data-page="property"] .lightbox-nav:hover {
  background: rgba(255,255,255,0.24); border-color: rgba(255,255,255,0.40);
  transform: translateY(-50%) scale(1.10);
}
body[data-portal="public"][data-page="property"] .lightbox-nav.prev { left: 16px; }
body[data-portal="public"][data-page="property"] .lightbox-nav.next { right: 16px; }
body[data-portal="public"][data-page="property"] .lightbox-thumbs {
  flex-shrink: 0; display: flex; align-items: center; gap: 7px;
  padding: 14px 28px 22px;
  overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch;
  background: linear-gradient(to top, rgba(0,0,0,0.55) 0%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 24px, black calc(100% - 24px), transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, black 24px, black calc(100% - 24px), transparent 100%);
}
body[data-portal="public"][data-page="property"] .lightbox-thumbs::-webkit-scrollbar { display: none; }
body[data-portal="public"][data-page="property"] .lb-thumb {
  flex-shrink: 0; width: 80px; height: 58px;
  border-radius: 6px; overflow: hidden; cursor: pointer;
  border: 2.5px solid transparent; opacity: 0.48;
  transition: opacity 180ms ease, border-color 180ms ease, transform 180ms ease;
  background: #222; padding: 0;
}
body[data-portal="public"][data-page="property"] .lb-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
body[data-portal="public"][data-page="property"] .lb-thumb:hover  { opacity: 0.82; transform: translateY(-3px); }
body[data-portal="public"][data-page="property"] .lb-thumb.active {
  opacity: 1; border-color: #fff;
  transform: translateY(-3px); box-shadow: 0 4px 16px rgba(0,0,0,0.40);
}

/* ── DETAIL LAYOUT ────────────────────────────────────────── */
body[data-portal="public"][data-page="property"] .property-detail { padding: 0 0 var(--m-s-24); }
body[data-portal="public"][data-page="property"] .detail-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--m-s-10);
  align-items: start;
  margin-top: var(--m-s-10);
}
body[data-portal="public"][data-page="property"] .container {
  max-width: var(--m-max-w);
  margin: 0 auto;
  padding: 0 var(--m-s-6);
}
@media (max-width: 640px) {
  body[data-portal="public"][data-page="property"] .container { padding: 0 var(--m-s-4); }
}

/* Breadcrumb */
body[data-portal="public"][data-page="property"] .detail-breadcrumb {
  display: flex; align-items: center; gap: var(--m-s-2);
  font-size: 13px; color: var(--m-muted-2);
  margin-bottom: var(--m-s-5);
}
body[data-portal="public"][data-page="property"] .detail-breadcrumb a {
  color: var(--m-muted-2); text-decoration: none;
  transition: color var(--m-dur) var(--m-ease);
}
body[data-portal="public"][data-page="property"] .detail-breadcrumb a:hover { color: var(--m-brand); }
body[data-portal="public"][data-page="property"] .detail-breadcrumb i { font-size: 9px; }

/* Header */
body[data-portal="public"][data-page="property"] .detail-header { margin-bottom: var(--m-s-5); }
body[data-portal="public"][data-page="property"] .detail-price {
  font-family: var(--m-font-base);
  font-size: 44px; font-weight: 800;
  color: var(--m-ink);
  line-height: 1; letter-spacing: -0.03em;
  margin-bottom: var(--m-s-2);
  display: flex; align-items: baseline; gap: 6px;
}
body[data-portal="public"][data-page="property"] .detail-price span {
  font-size: 16px; font-weight: 500; color: var(--m-muted-2); letter-spacing: 0;
}
body[data-portal="public"][data-page="property"] .detail-title {
  font-family: var(--m-font-base);
  font-size: clamp(20px, 3vw, 28px); font-weight: 700;
  color: var(--m-ink);
  line-height: 1.2; margin-bottom: var(--m-s-2);
  letter-spacing: -0.02em;
}
body[data-portal="public"][data-page="property"] .detail-address {
  font-size: 14.5px; color: var(--m-muted);
  display: flex; align-items: center; gap: var(--m-s-2); flex-wrap: wrap;
}
body[data-portal="public"][data-page="property"] .detail-address i { color: var(--m-brand); font-size: 12px; }

/* Meta row */
body[data-portal="public"][data-page="property"] .detail-meta-row {
  display: flex; flex-wrap: wrap; gap: var(--m-s-2);
  margin-bottom: var(--m-s-8);
  padding: var(--m-s-5) 0;
  border-top: 1px solid var(--m-border);
  border-bottom: 1px solid var(--m-border);
}
body[data-portal="public"][data-page="property"] .detail-meta-item {
  display: flex; align-items: center; gap: var(--m-s-3);
  background: var(--m-white);
  border: 1px solid var(--m-border);
  border-radius: var(--m-r-xl);
  padding: 10px 18px; min-width: 110px;
  transition: border-color var(--m-dur) var(--m-ease), box-shadow var(--m-dur) var(--m-ease), transform var(--m-dur) var(--m-ease);
  box-shadow: var(--m-shadow-sm);
}
body[data-portal="public"][data-page="property"] .detail-meta-item:hover {
  border-color: rgba(0,106,255,0.22);
  box-shadow: 0 4px 16px rgba(0,106,255,0.08);
  transform: translateY(-1px);
}
body[data-portal="public"][data-page="property"] .detail-meta-icon {
  width: 34px; height: 34px; border-radius: var(--m-r);
  background: var(--m-brand-pale);
  border: 1px solid rgba(0,106,255,0.12);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
body[data-portal="public"][data-page="property"] .detail-meta-icon i { color: var(--m-brand); font-size: 13px; }
body[data-portal="public"][data-page="property"] .detail-meta-text  { display: flex; flex-direction: column; gap: 2px; }
body[data-portal="public"][data-page="property"] .detail-meta-label { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.10em; color: var(--m-muted-2); }
body[data-portal="public"][data-page="property"] .detail-meta-value { font-size: 15px; font-weight: 700; color: var(--m-ink); letter-spacing: -0.01em; }

/* Share row */
body[data-portal="public"][data-page="property"] .share-row {
  display: flex; gap: var(--m-s-2); margin-bottom: var(--m-s-6); flex-wrap: wrap;
}
body[data-portal="public"][data-page="property"] .share-btn {
  display: inline-flex; align-items: center; gap: var(--m-s-2);
  padding: 8px 16px; border-radius: var(--m-r-lg);
  font-size: 12.5px; font-weight: 600;
  color: var(--m-muted);
  background: var(--m-white);
  border: 1.5px solid var(--m-border);
  cursor: pointer; transition: all var(--m-dur) var(--m-ease);
  font-family: var(--m-font-base);
}
body[data-portal="public"][data-page="property"] .share-btn:hover {
  border-color: var(--m-ink); color: var(--m-ink); background: var(--m-surface);
}
body[data-portal="public"][data-page="property"] .share-btn.saved {
  color: #dc2626; border-color: #fecaca; background: #fef2f2;
}

/* Sections */
body[data-portal="public"][data-page="property"] .detail-section { margin-bottom: var(--m-s-8); }
body[data-portal="public"][data-page="property"] .detail-section-title {
  font-family: var(--m-font-base); font-size: 17px; font-weight: 700;
  color: var(--m-ink);
  margin-bottom: var(--m-s-5);
  padding-bottom: var(--m-s-3);
  letter-spacing: -0.02em;
  display: flex; align-items: center; gap: var(--m-s-2);
  position: relative;
}
body[data-portal="public"][data-page="property"] .detail-section-title::after {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 36px; height: 2.5px;
  background: var(--m-brand); border-radius: 2px;
}
body[data-portal="public"][data-page="property"] .detail-desc {
  font-size: 15.5px; color: var(--m-muted); line-height: 1.85;
}
body[data-portal="public"][data-page="property"] .detail-desc.truncated {
  display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
}
body[data-portal="public"][data-page="property"] .detail-read-more {
  display: inline-flex; align-items: center; gap: 5px;
  margin-top: var(--m-s-2);
  font-size: 13.5px; font-weight: 600;
  color: var(--m-brand);
  background: none; border: none; cursor: pointer;
  padding: 4px 0;
  font-family: var(--m-font-base);
  transition: color var(--m-dur) var(--m-ease);
}
body[data-portal="public"][data-page="property"] .detail-read-more:hover { color: var(--m-brand-dark); }

/* Amenities */
body[data-portal="public"][data-page="property"] .amenities-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: var(--m-s-3);
}
body[data-portal="public"][data-page="property"] .amenity-item {
  display: flex; align-items: center; gap: var(--m-s-2);
  background: var(--m-white); border: 1px solid var(--m-border);
  border-radius: var(--m-r-lg); padding: 10px 14px;
  font-size: 13px; font-weight: 500; color: var(--m-ink);
  transition: border-color var(--m-dur) var(--m-ease), background var(--m-dur) var(--m-ease), box-shadow var(--m-dur) var(--m-ease);
  box-shadow: var(--m-shadow-sm);
}
body[data-portal="public"][data-page="property"] .amenity-item:hover {
  border-color: rgba(0,106,255,0.22);
  background: var(--m-brand-pale);
  box-shadow: 0 2px 12px rgba(0,106,255,0.08);
}
body[data-portal="public"][data-page="property"] .amenity-item i {
  color: var(--m-brand); font-size: 12px; width: 14px; text-align: center;
}
body[data-portal="public"][data-page="property"] .amenity-item i.icon-green  { color: #059669; }
body[data-portal="public"][data-page="property"] .amenity-item i.icon-sky    { color: #0ea5e9; }
body[data-portal="public"][data-page="property"] .amenity-item i.icon-amber  { color: #d97706; }
body[data-portal="public"][data-page="property"] .amenity-item i.icon-purple { color: #7c3aed; }
body[data-portal="public"][data-page="property"] .amenity-item i.icon-rose   { color: #e11d48; }
body[data-portal="public"][data-page="property"] .amenity-item i.icon-teal   { color: #0d9488; }

/* Detail tabs */
body[data-portal="public"][data-page="property"] .detail-tabs-wrap { padding: 0; min-height: 120px; }
body[data-portal="public"][data-page="property"] .detail-tabs {
  display: flex; gap: 0;
  border-bottom: 2px solid var(--m-border);
  margin-bottom: var(--m-s-5);
  overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch;
}
body[data-portal="public"][data-page="property"] .detail-tabs::-webkit-scrollbar { display: none; }
body[data-portal="public"][data-page="property"] .detail-tab {
  padding: 10px 20px;
  font-size: 13.5px; font-weight: 600;
  color: var(--m-muted-2);
  background: none; border: none;
  border-bottom: 2.5px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  font-family: var(--m-font-base);
  border-radius: var(--m-r) var(--m-r) 0 0;
  white-space: nowrap;
  display: inline-flex; align-items: center; gap: 6px;
  transition: color 160ms ease, border-color 160ms ease, background 160ms ease;
  min-height: 44px;
}
body[data-portal="public"][data-page="property"] .detail-tab i { font-size: 11px; }
body[data-portal="public"][data-page="property"] .detail-tab:hover { color: var(--m-ink); background: var(--m-white); }
body[data-portal="public"][data-page="property"] .detail-tab.active {
  color: var(--m-brand); border-bottom-color: var(--m-brand);
}
body[data-portal="public"][data-page="property"] .detail-tab-panel { display: none; }
body[data-portal="public"][data-page="property"] .detail-tab-panel.active {
  display: block; animation: cp-tab-fade 0.22s ease;
}
@keyframes cp-tab-fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }

/* Map */
body[data-portal="public"][data-page="property"] .map-container {
  border-radius: var(--m-r-xl); overflow: hidden; height: 240px;
  border: 1px solid var(--m-border);
}
body[data-portal="public"][data-page="property"] #propertyMiniMap { width: 100%; height: 100%; }
body[data-portal="public"][data-page="property"] .leaflet-control-attribution { display: none !important; }
body[data-portal="public"][data-page="property"] .map-open-btn {
  display: inline-flex; align-items: center; gap: 7px;
  margin-top: 10px; padding: 9px 18px;
  background: var(--m-white);
  border: 1.5px solid var(--m-border);
  border-radius: var(--m-r-lg);
  font-size: 13px; font-weight: 600;
  color: var(--m-brand); text-decoration: none;
  transition: all 180ms ease;
  box-shadow: var(--m-shadow-sm);
}
body[data-portal="public"][data-page="property"] .map-open-btn:hover {
  border-color: var(--m-brand);
  background: var(--m-brand-pale);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(0,106,255,0.12);
}
body[data-portal="public"][data-page="property"] .map-open-btn i { font-size: 12px; }

/* Sticky sidebar */
body[data-portal="public"][data-page="property"] .detail-sidebar {
  position: sticky; top: calc(var(--m-nav-h) + var(--m-s-6));
  display: flex; flex-direction: column; gap: var(--m-s-4);
}

/* Apply card */
body[data-portal="public"][data-page="property"] .apply-card {
  background: var(--m-white);
  border-radius: var(--m-r-2xl);
  border: 1px solid var(--m-border);
  box-shadow: 0 8px 32px rgba(0,0,0,0.10), 0 2px 6px rgba(0,0,0,0.05);
  overflow: hidden;
}
body[data-portal="public"][data-page="property"] .apply-card-header {
  background: linear-gradient(155deg, #04101E 0%, #0A1B34 50%, #0D2248 100%);
  padding: var(--m-s-6) var(--m-s-6) var(--m-s-5);
  position: relative; overflow: hidden;
}
body[data-portal="public"][data-page="property"] .apply-card-header::before {
  content: ''; position: absolute;
  top: -40px; right: -30px; width: 160px; height: 160px;
  background: radial-gradient(ellipse, rgba(0,106,255,0.18) 0%, transparent 70%);
  pointer-events: none;
}
body[data-portal="public"][data-page="property"] .apply-card-price {
  font-family: var(--m-font-base);
  font-size: 36px; font-weight: 800;
  color: #fff; line-height: 1; letter-spacing: -0.03em;
  display: flex; align-items: baseline; gap: 5px;
}
body[data-portal="public"][data-page="property"] .apply-card-price span {
  font-size: 14px; font-weight: 400; color: rgba(255,255,255,0.48); letter-spacing: 0;
}
body[data-portal="public"][data-page="property"] .apply-card-avail {
  display: flex; align-items: center; gap: 7px;
  font-size: 12.5px; font-weight: 500;
  margin-top: var(--m-s-2); color: rgba(255,255,255,0.58);
}
body[data-portal="public"][data-page="property"] .apply-card-avail i { font-size: 8px; color: #34d399; }
body[data-portal="public"][data-page="property"] .apply-card-body { padding: var(--m-s-5) var(--m-s-6); }
body[data-portal="public"][data-page="property"] .apply-cost-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--m-s-3) 0;
  border-top: 1px solid var(--m-border);
  font-size: 13.5px;
}
body[data-portal="public"][data-page="property"] .apply-cost-row:first-child { border-top: none; }
body[data-portal="public"][data-page="property"] .apply-cost-label { color: var(--m-muted); font-weight: 500; }
body[data-portal="public"][data-page="property"] .apply-cost-value { color: var(--m-ink); font-weight: 700; }
body[data-portal="public"][data-page="property"] .apply-btn {
  display: flex; align-items: center; justify-content: center; gap: var(--m-s-2);
  width: 100%; padding: 15px; margin-top: var(--m-s-5);
  background: var(--m-brand); color: #fff;
  font-size: 15px; font-weight: 700; border: none;
  border-radius: var(--m-r-xl); cursor: pointer;
  font-family: var(--m-font-base); letter-spacing: -0.01em;
  transition: all 200ms ease; text-decoration: none;
  box-shadow: 0 4px 20px rgba(0,106,255,0.32);
}
body[data-portal="public"][data-page="property"] .apply-btn:hover {
  background: var(--m-brand-dark);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,106,255,0.42);
}
body[data-portal="public"][data-page="property"] .apply-disclaimer {
  font-size: 11.5px; color: var(--m-muted-2); text-align: center;
  margin-top: var(--m-s-3);
  display: flex; align-items: center; justify-content: center; gap: 5px;
  line-height: 1.5;
}
body[data-portal="public"][data-page="property"] .apply-track-link {
  display: block; text-align: center; margin-top: var(--m-s-3);
  font-size: 12.5px; color: var(--m-brand); text-decoration: none;
  font-weight: 600;
  transition: color var(--m-dur) var(--m-ease);
}
body[data-portal="public"][data-page="property"] .apply-track-link:hover { color: var(--m-brand-dark); }

/* Landlord card */
body[data-portal="public"][data-page="property"] .landlord-card {
  background: var(--m-white); border: 1px solid var(--m-border);
  border-radius: var(--m-r-xl); padding: var(--m-s-4) var(--m-s-5);
  display: flex; align-items: center; gap: var(--m-s-3);
  box-shadow: var(--m-shadow-sm);
}
body[data-portal="public"][data-page="property"] .landlord-card-avatar {
  width: 50px; height: 50px; border-radius: 50%;
  background: linear-gradient(135deg, var(--m-brand) 0%, #0050CC 100%);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--m-font-base); font-size: 20px; font-weight: 700;
  color: #fff; flex-shrink: 0; overflow: hidden;
  box-shadow: 0 2px 10px rgba(0,106,255,0.22);
}
body[data-portal="public"][data-page="property"] .landlord-card-avatar img {
  width: 100%; height: 100%; object-fit: cover;
}
body[data-portal="public"][data-page="property"] .landlord-card-label {
  font-size: 10px; font-weight: 700; color: var(--m-muted-2);
  text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 2px;
}
body[data-portal="public"][data-page="property"] .landlord-card-name {
  font-size: 14px; font-weight: 700; color: var(--m-ink); letter-spacing: -0.01em;
}
body[data-portal="public"][data-page="property"] .landlord-card-tagline {
  font-size: 12px; color: var(--m-muted-2);
}
body[data-portal="public"][data-page="property"] .landlord-card-verified {
  color: var(--m-brand); font-size: 18px;
  flex-shrink: 0; margin-left: auto;
  filter: drop-shadow(0 0 4px rgba(0,106,255,0.25));
}

/* Listed by */
body[data-portal="public"][data-page="property"] .detail-listed-by {
  font-size: 13.5px; color: var(--m-muted-2);
  margin-top: var(--m-s-2);
  display: flex; align-items: center; gap: 6px;
}
body[data-portal="public"][data-page="property"] .detail-listed-by i { color: var(--m-brand); font-size: 11px; }
body[data-portal="public"][data-page="property"] .detail-listed-by span { color: var(--m-ink); font-weight: 600; }

/* Contact card */
body[data-portal="public"][data-page="property"] .contact-card {
  background: var(--m-white); border: 1px solid var(--m-border);
  border-radius: var(--m-r-2xl); padding: var(--m-s-6);
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}
body[data-portal="public"][data-page="property"] .contact-card-title {
  font-family: var(--m-font-base); font-size: 17px; font-weight: 700;
  color: var(--m-ink); margin-bottom: var(--m-s-5); letter-spacing: -0.01em;
}
body[data-portal="public"][data-page="property"] .contact-form-group { margin-bottom: var(--m-s-4); }
body[data-portal="public"][data-page="property"] .contact-form-group .form-label,
body[data-portal="public"][data-page="property"] .contact-form-group label {
  display: block; font-size: 11.5px; font-weight: 700;
  color: var(--m-ink); letter-spacing: 0.06em;
  text-transform: uppercase; margin-bottom: 5px;
}
body[data-portal="public"][data-page="property"] .contact-form-group .form-input,
body[data-portal="public"][data-page="property"] .contact-form-group .form-textarea,
body[data-portal="public"][data-page="property"] .contact-form-group input,
body[data-portal="public"][data-page="property"] .contact-form-group textarea {
  width: 100%; padding: 10px 13px;
  border: 1.5px solid var(--m-border);
  border-radius: var(--m-r-lg);
  font-size: 14px; color: var(--m-ink);
  background: var(--m-surface); outline: none;
  font-family: var(--m-font-base);
  transition: border-color var(--m-dur) var(--m-ease), box-shadow var(--m-dur) var(--m-ease);
}
body[data-portal="public"][data-page="property"] .contact-form-group .form-input:focus,
body[data-portal="public"][data-page="property"] .contact-form-group .form-textarea:focus,
body[data-portal="public"][data-page="property"] .contact-form-group input:focus,
body[data-portal="public"][data-page="property"] .contact-form-group textarea:focus {
  border-color: var(--m-brand);
  box-shadow: 0 0 0 3px rgba(0,106,255,0.18);
}
body[data-portal="public"][data-page="property"] .contact-form-group .form-textarea,
body[data-portal="public"][data-page="property"] .contact-form-group textarea { height: 90px; resize: none; }

/* Contact card drawer chrome */
body[data-portal="public"][data-page="property"] .contact-drawer-handle-bar {
  display: none; width: 40px; height: 4px;
  background: var(--m-border-strong); border-radius: 2px;
  margin: 0 auto var(--m-s-4);
}
body[data-portal="public"][data-page="property"] .contact-card-header-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--m-s-3); margin-bottom: var(--m-s-4);
}
body[data-portal="public"][data-page="property"] .contact-card-header-row .share-row { margin-bottom: 0; }
body[data-portal="public"][data-page="property"] .contact-drawer-close-btn {
  display: none; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid var(--m-border);
  background: var(--m-white);
  color: var(--m-muted);
  font-size: 14px; cursor: pointer; flex-shrink: 0;
  transition: background var(--m-dur) var(--m-ease), color var(--m-dur) var(--m-ease);
}
body[data-portal="public"][data-page="property"] .contact-drawer-close-btn:hover {
  background: var(--m-surface); color: var(--m-ink);
}
body[data-portal="public"][data-page="property"] .contact-drawer-overlay {
  position: fixed; inset: 0; z-index: 290;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
  opacity: 0; pointer-events: none;
  transition: opacity 300ms ease;
}
body[data-portal="public"][data-page="property"] .contact-drawer-overlay.active {
  opacity: 1; pointer-events: auto;
}

/* Mobile sticky bar — message button */
body[data-portal="public"][data-page="property"] .mob-actions {
  display: flex; align-items: center; gap: 8px; flex-shrink: 0;
}
body[data-portal="public"][data-page="property"] .mob-msg-btn {
  display: none; align-items: center; justify-content: center;
  width: 46px; height: 46px;
  background: rgba(255,255,255,0.12);
  border: 1.5px solid rgba(255,255,255,0.25);
  border-radius: 8px;
  color: #fff; font-size: 18px;
  cursor: pointer; flex-shrink: 0;
  transition: background 160ms ease;
}
body[data-portal="public"][data-page="property"] .mob-msg-btn:hover { background: rgba(255,255,255,0.22); }

/* LQIP for mosaic */
body[data-portal="public"][data-page="property"] .lqip-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  filter: blur(24px); transform: scale(1.1);
  z-index: 0;
  transition: opacity 600ms ease;
  pointer-events: none; will-change: opacity;
}
body[data-portal="public"][data-page="property"] .lqip-bg.faded { opacity: 0; }

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width: 900px) {
  body[data-portal="public"][data-page="property"] .detail-layout { grid-template-columns: 1fr; }
  body[data-portal="public"][data-page="property"] .detail-sidebar { position: static; }
}
@media (max-width: 768px) {
  body[data-portal="public"][data-page="property"] .detail-main { display: flex; flex-direction: column; }
  body[data-portal="public"][data-page="property"] .map-container { order: 10; }
  body[data-portal="public"][data-page="property"] .gallery-mosaic {
    grid-template-columns: 1fr;
    height: clamp(280px, 75vw, 420px);
    border-radius: var(--m-r-xl);
  }
  body[data-portal="public"][data-page="property"] .mosaic-side { display: none; }
  body[data-portal="public"][data-page="property"] .mosaic-main { border-radius: var(--m-r-xl); }
  body[data-portal="public"][data-page="property"] .mosaic-main::after {
    background: linear-gradient(to top, rgba(0,0,0,0.30) 0%, transparent 58%);
  }
  body[data-portal="public"][data-page="property"] .mosaic-expand-btn {
    opacity: 1; pointer-events: auto; transform: translateY(0);
    bottom: 10px; left: auto; right: 10px;
    width: auto; min-width: 48px; min-height: 36px; max-width: 72px;
    padding: 7px 9px; gap: 5px; font-size: 12px;
    color: #fff;
    background: transparent !important;
    border-color: transparent;
    border-radius: 999px; box-shadow: none;
    text-shadow: 0 1px 4px rgba(0,0,0,0.85), 0 2px 10px rgba(0,0,0,0.65);
  }
  body[data-portal="public"][data-page="property"] .mosaic-expand-btn .mosaic-expand-label { display: none; }
  body[data-portal="public"][data-page="property"] .mosaic-expand-btn .mosaic-photo-count {
    background: transparent; color: #fff; padding: 0; font-size: 12px;
  }
  body[data-portal="public"][data-page="property"] .lightbox-stage { padding: 0; }
  body[data-portal="public"][data-page="property"] .lightbox-img-wrap { align-items: center; height: auto; min-height: 0; }
  body[data-portal="public"][data-page="property"] .lightbox-img {
    width: 100%; max-width: 100%; height: auto; max-height: 72vh;
    border-radius: 0; object-fit: contain;
  }
  body[data-portal="public"][data-page="property"] .lightbox-nav {
    width: 38px; height: 38px; font-size: 15px;
    background: rgba(0,0,0,0.45);
    border-color: rgba(255,255,255,0.15);
  }
  body[data-portal="public"][data-page="property"] .lightbox-nav.prev { left: 8px; }
  body[data-portal="public"][data-page="property"] .lightbox-nav.next { right: 8px; }
  body[data-portal="public"][data-page="property"] .lb-thumb { width: 60px; height: 44px; }
  body[data-portal="public"][data-page="property"] .gallery-strip-thumb { width: 84px; height: 56px; }
}
@media (max-width: 767px) {
  body[data-portal="public"][data-page="property"] .contact-drawer-handle-bar { display: block; }
  body[data-portal="public"][data-page="property"] .contact-drawer-close-btn  { display: flex; }
  body[data-portal="public"][data-page="property"] .mob-msg-btn               { display: flex; }
  body[data-portal="public"][data-page="property"] #contactCard {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 300;
    border-radius: 20px 20px 0 0;
    border-bottom-left-radius: 0; border-bottom-right-radius: 0;
    transform: translateY(100%);
    transition: transform 360ms cubic-bezier(0.22, 1, 0.36, 1);
    max-height: 88vh;
    overflow-y: auto; -webkit-overflow-scrolling: touch;
    padding-top: var(--m-s-4);
    padding-bottom: calc(var(--m-s-6) + env(safe-area-inset-bottom));
    box-shadow: 0 -8px 40px rgba(0,0,0,0.30);
  }
  body[data-portal="public"][data-page="property"] #contactCard.drawer-open { transform: translateY(0); }
}
@media (max-width: 480px) {
  body[data-portal="public"][data-page="property"] .detail-price { font-size: 32px; }
  body[data-portal="public"][data-page="property"] .lightbox-header { padding: 12px 16px; }
  body[data-portal="public"][data-page="property"] .lightbox-thumbs { padding: 10px 16px 16px; gap: 5px; }
  body[data-portal="public"][data-page="property"] .lb-thumb { width: 54px; height: 40px; }
  body[data-portal="public"][data-page="property"] .gallery-strip-thumb { width: 68px; height: 46px; }
  body[data-portal="public"][data-page="property"] .gallery-strip { gap: 5px; }
}
@media (min-width: 1200px) {
  body[data-portal="public"][data-page="property"] .gallery-strip-thumb { width: 116px; height: 78px; }
  body[data-portal="public"][data-page="property"] .lb-thumb { width: 88px; height: 64px; }
}
@media (min-width: 1440px) {
  body[data-portal="public"][data-page="property"] .gallery-mosaic { height: clamp(620px, 42vw, 800px); }
  body[data-portal="public"][data-page="property"] .gallery-strip-thumb { width: 124px; height: 84px; }
  body[data-portal="public"][data-page="property"] .lb-thumb { width: 96px; height: 70px; }
  body[data-portal="public"][data-page="property"] .lightbox-nav { width: 60px; height: 60px; font-size: 22px; }
  body[data-portal="public"][data-page="property"] .lightbox-stage { padding: 0 clamp(64px, 8vw, 96px); }
}
@media (min-width: 1920px) {
  body[data-portal="public"][data-page="property"] .gallery-mosaic { height: clamp(740px, 40vw, 880px); }
  body[data-portal="public"][data-page="property"] .gallery-strip-thumb { width: 136px; height: 92px; }
  body[data-portal="public"][data-page="property"] .lb-thumb { width: 106px; height: 78px; }
  body[data-portal="public"][data-page="property"] .lightbox-nav { width: 68px; height: 68px; font-size: 24px; }
}
@media (min-width: 2560px) {
  body[data-portal="public"][data-page="property"] .gallery-mosaic { height: clamp(860px, 36vw, 1000px); }
  body[data-portal="public"][data-page="property"] .gallery-strip-thumb { width: 152px; height: 102px; }
  body[data-portal="public"][data-page="property"] .lb-thumb { width: 120px; height: 88px; }
}


/* =====================================================================
   TESTIMONIALS + STATS BAR — added April 2026 (homepage social proof)
   Scoped to body[data-portal="public"][data-page="home"] when possible,
   but generic enough to work site-wide via .testimonials-section / .stats-bar.
   ===================================================================== */

/* ── Testimonials section ────────────────────────────────────────── */
body[data-portal="public"] .testimonials-section {
  padding: clamp(56px, 9vw, 96px) 0 clamp(40px, 6vw, 72px);
  background: var(--m-bg, #fafbfc);
  position: relative;
}

body[data-portal="public"] .testimonials-title {
  margin-top: 6px;
}

body[data-portal="public"] .testimonials-subtitle {
  max-width: 620px;
  margin: 14px auto 0;
  color: var(--m-text-soft, #5b6473);
  font-size: clamp(15px, 1.6vw, 17px);
  line-height: 1.55;
  text-align: center;
}

body[data-portal="public"] .testimonials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
  margin-top: clamp(32px, 5vw, 56px);
  align-items: stretch;
}

body[data-portal="public"] .testimonial-card {
  position: relative;
  margin: 0;
  padding: 32px 26px 26px;
  background: #ffffff;
  border: 1px solid var(--m-border, #e6e9ee);
  border-radius: 16px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 6px 18px rgba(15, 23, 42, 0.04);
  display: flex;
  flex-direction: column;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

body[data-portal="public"] .testimonial-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 2px 4px rgba(15, 23, 42, 0.05), 0 14px 32px rgba(15, 23, 42, 0.08);
  border-color: #d6dbe3;
}

body[data-portal="public"] .testimonial-quote-icon {
  font-size: 22px;
  color: var(--m-accent, #1f6feb);
  opacity: 0.85;
  margin-bottom: 14px;
}

body[data-portal="public"] .testimonial-text {
  margin: 0 0 22px;
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--m-text, #1f2937);
  font-style: normal;
  flex: 1;
}

body[data-portal="public"] .testimonial-meta {
  border-top: 1px solid var(--m-border, #eceff3);
  padding-top: 14px;
}

body[data-portal="public"] .testimonial-name {
  font-weight: 700;
  font-size: 15px;
  color: var(--m-text, #1f2937);
  letter-spacing: -0.01em;
}

body[data-portal="public"] .testimonial-detail {
  margin-top: 3px;
  font-size: 13.5px;
  color: var(--m-text-soft, #6b7280);
}

@media (max-width: 600px) {
  body[data-portal="public"] .testimonials-grid { gap: 16px; }
  body[data-portal="public"] .testimonial-card { padding: 26px 22px 22px; }
  body[data-portal="public"] .testimonial-text { font-size: 15px; }
}

/* ── Stats / trust bar ───────────────────────────────────────────── */
body[data-portal="public"] .stats-bar {
  padding: clamp(40px, 6vw, 64px) 0;
  background: linear-gradient(180deg, #ffffff 0%, #f4f6fa 100%);
  border-top: 1px solid var(--m-border, #e6e9ee);
}

body[data-portal="public"] .stats-bar-header {
  text-align: center;
  margin-bottom: clamp(24px, 4vw, 36px);
}

body[data-portal="public"] .stats-bar-title {
  margin: 0;
  font-size: clamp(18px, 2.2vw, 22px);
  font-weight: 700;
  color: var(--m-text, #1f2937);
  letter-spacing: -0.01em;
}

body[data-portal="public"] .stats-bar-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

body[data-portal="public"] .stats-bar-item {
  text-align: center;
  padding: 18px 12px;
  background: #ffffff;
  border: 1px solid var(--m-border, #e6e9ee);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

body[data-portal="public"] .stats-bar-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
}

body[data-portal="public"] .stats-bar-icon {
  font-size: 22px;
  color: var(--m-accent, #1f6feb);
  margin-bottom: 4px;
}

body[data-portal="public"] .stats-bar-num {
  font-size: clamp(22px, 2.6vw, 28px);
  font-weight: 800;
  color: var(--m-text, #0f172a);
  letter-spacing: -0.02em;
  line-height: 1;
}

body[data-portal="public"] .stats-bar-num-sub {
  font-size: 0.55em;
  font-weight: 600;
  color: var(--m-text-soft, #6b7280);
  margin-left: 2px;
}

body[data-portal="public"] .stats-bar-label {
  font-size: 13px;
  color: var(--m-text-soft, #5b6473);
  font-weight: 500;
  letter-spacing: 0.01em;
}

@media (max-width: 900px) {
  body[data-portal="public"] .stats-bar-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (max-width: 420px) {
  body[data-portal="public"] .stats-bar-grid { grid-template-columns: 1fr; }
  body[data-portal="public"] .stats-bar-item { flex-direction: row; justify-content: center; padding: 16px 14px; gap: 12px; }
  body[data-portal="public"] .stats-bar-icon { margin-bottom: 0; font-size: 20px; }
}

/* ── Mobile sticky CTA bar (Phase 1) ─────────────────────────────────── */
body[data-portal="public"] .mobile-cta-bar {
  position: fixed; bottom: 0; left: 0; right: 0;
  z-index: 90;
  display: none;
  gap: 8px;
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom, 0px));
  background: rgba(255,255,255,0.96);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  backdrop-filter: saturate(180%) blur(14px);
  border-top: 1px solid var(--m-border);
  box-shadow: 0 -6px 18px rgba(15,23,42,0.06);
}
body[data-portal="public"] .mobile-cta-bar a {
  flex: 1; text-align: center;
  padding: 13px 14px;
  border-radius: var(--m-r-lg);
  font-weight: 600; font-size: 14px;
  text-decoration: none;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  min-height: 44px;
}
body[data-portal="public"] .mobile-cta-bar .mcta-primary {
  background: var(--m-brand); color: #fff;
}
body[data-portal="public"] .mobile-cta-bar .mcta-primary:hover { background: var(--m-brand-dark); color: #fff; }
body[data-portal="public"] .mobile-cta-bar .mcta-ghost {
  background: var(--m-surface-2); color: var(--m-ink);
}
@media (max-width: 768px) {
  body[data-portal="public"] .mobile-cta-bar { display: flex; }
  body[data-portal="public"]:not([data-page="apply"]) { padding-bottom: 76px; }
}

/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9 — mv2-* additive layer (Public Marketing Refresh v2)       ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.0, agent_issues #30) ║
   ║  Pruned: 2026-04-27 — see batch-3 cleanup commit                    ║
   ║                                                                      ║
   ║  Purpose: an additive token + utility namespace that built a        ║
   ║  premium, mobile-first public-marketing surface WITHOUT touching    ║
   ║  any existing class name, ID, or token.                             ║
   ║                                                                      ║
   ║  Design direction: Editorial / Boutique (warm off-white, restrained ║
   ║  gold accent, Fraunces italic emphasis, generous whitespace).       ║
   ║                                                                      ║
   ║  Status: phases 9.1–9.13 shipped what they needed. The dormant       ║
   ║  generic primitives that were never opted into (.mv2-section,       ║
   ║  .mv2-card, .mv2-pill, .mv2-container, .mv2-divider, .mv2-stat-*,   ║
   ║  .mv2-snap-row, .mv2-cta-bar, .mv2-accent-rule, .mv2-btn--inverse,  ║
   ║  .mv2-section--ink/--white, etc.) were removed in the batch-3       ║
   ║  cleanup. Survivors are page-specific concrete components used by   ║
   ║  index/listings/property/about/etc.                                 ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

:root {
  /* ── Color tokens ──────────────────────────────────────────────── */
  --mv2-bg-warm:        #FAF8F5;   /* warm off-white page bg */
  --mv2-bg-warm-2:      #F4EFE7;   /* slightly deeper warm panel */
  --mv2-ink:            #0A1729;   /* primary text (matches existing --m-ink) */
  --mv2-ink-2:          #1A2540;
  --mv2-muted:          #4B5563;
  --mv2-muted-2:        #6B7280;
  --mv2-hairline:       #E8E2D6;   /* warm hairline (replaces cool grey) */
  --mv2-hairline-strong:#D6CDB9;
  --mv2-accent:         #D4A017;   /* gold — used SPARINGLY, one moment per section */
  --mv2-gold:           #D4A017;   /* alias — matches --mv2-accent and --m-gold */
  --mv2-accent-pale:    #FAF3DD;
  --mv2-accent-strong:  #B8860B;
  --mv2-brand:          #006AFF;   /* reserved for primary buttons + links only */
  --mv2-brand-dark:     #0054CC;
  --mv2-success:        #047857;
  --mv2-overlay-ink:    rgba(10, 23, 41, 0.72);  /* hero photo overlay */

  /* ── Typography tokens ─────────────────────────────────────────── */
  --mv2-font-display:   'Fraunces', 'Georgia', 'Times New Roman', serif;
  --mv2-font-body:      'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --mv2-fs-eyebrow:     0.78rem;
  --mv2-fs-body:        clamp(1rem, 0.95rem + 0.2vw, 1.0625rem);   /* 16 → 17 px */
  --mv2-fs-lede:        clamp(1.0625rem, 1rem + 0.4vw, 1.1875rem); /* 17 → 19 px */
  --mv2-fs-h2:          clamp(1.625rem, 1.4rem + 1.2vw, 2.25rem);  /* 26 → 36 px */
  --mv2-fs-h1:          clamp(2rem, 1.6rem + 2.4vw, 3.25rem);      /* 32 → 52 px */
  --mv2-lh-body:        1.7;
  --mv2-lh-tight:       1.15;
  --mv2-letter-eyebrow: 0.14em;
  --mv2-max-prose:      62ch;        /* readable measure for body copy */

  /* ── Spacing rhythm ────────────────────────────────────────────── */
  --mv2-section-y-mobile:  clamp(48px, 9vw, 72px);
  --mv2-section-y-desktop: clamp(72px, 7vw, 112px);
  --mv2-container-x:       clamp(20px, 4vw, 32px);
  --mv2-stack-1: 8px;
  --mv2-stack-2: 12px;
  --mv2-stack-3: 16px;
  --mv2-stack-4: 24px;
  --mv2-stack-5: 32px;
  --mv2-stack-6: 48px;

  /* ── Radii + shadows ───────────────────────────────────────────── */
  --mv2-r-sm:   8px;
  --mv2-r-md:   14px;
  --mv2-r-lg:   22px;
  --mv2-r-pill: 999px;
  --mv2-shadow-hairline: 0 0 0 1px var(--mv2-hairline);
  --mv2-shadow-soft:     0 1px 2px rgba(10,23,41,.04), 0 8px 24px rgba(10,23,41,.06);
  --mv2-shadow-lift:     0 2px 4px rgba(10,23,41,.05), 0 18px 40px rgba(10,23,41,.10);
  --mv2-shadow-gold:     0 0 0 1px rgba(212,160,23,.35), 0 6px 18px rgba(212,160,23,.18);

  /* ── Motion tokens (honoring reduced-motion downstream) ────────── */
  --mv2-dur:        220ms;
  --mv2-dur-slow:   380ms;
  --mv2-ease:       cubic-bezier(.4, 0, .2, 1);
  --mv2-ease-out:   cubic-bezier(.2, .8, .2, 1);

  /* ── Touch targets + safe area ─────────────────────────────────── */
  --mv2-tap-min:    44px;
  --mv2-safe-bot:   env(safe-area-inset-bottom, 0px);

  /* ── Sticky CTA bar height (used to pad page bottom on mobile) ── */
  --mv2-cta-bar-h:  64px;
}
/* ── Eyebrow tag ─────────────────────────────────────────────────── */
body[data-portal="public"] .mv2-eyebrow {
  font-family: var(--mv2-font-body);
  font-size: var(--mv2-fs-eyebrow);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--mv2-letter-eyebrow);
  color: var(--mv2-accent-strong);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 var(--mv2-stack-3);
}
body[data-portal="public"] .mv2-eyebrow::before {
  content: "";
  width: 18px;
  height: 1px;
  background: var(--mv2-accent);
  display: inline-block;
}

/* ── Headline (display, with italic emphasis support) ─────────────── */
body[data-portal="public"] .mv2-headline {
  font-family: var(--mv2-font-display);
  font-weight: 400;
  font-size: var(--mv2-fs-h1);
  line-height: var(--mv2-lh-tight);
  letter-spacing: -0.01em;
  color: var(--mv2-ink);
  margin: 0 0 var(--mv2-stack-4);
  text-wrap: balance;
}
body[data-portal="public"] .mv2-headline em {
  font-style: normal;
  font-weight: 700;
  color: var(--mv2-gold);
  font-feature-settings: "ss01" 1;
  text-decoration: underline;
  text-decoration-color: rgba(212, 160, 23, 0.38);
  text-underline-offset: 4px;
  text-decoration-thickness: 2px;
}
body[data-portal="public"] .mv2-headline--md { font-size: var(--mv2-fs-h2); }

body[data-portal="public"] .mv2-lede {
  font-size: var(--mv2-fs-lede);
  line-height: var(--mv2-lh-body);
  color: var(--mv2-muted);
  max-width: var(--mv2-max-prose);
  margin: 0 0 var(--mv2-stack-5);
}

/* ── Button (primary / ghost) — uses brand blue, not gold ───────── */
body[data-portal="public"] .mv2-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: var(--mv2-tap-min);
  padding: 12px 22px;
  border-radius: var(--mv2-r-pill);
  font-family: var(--mv2-font-body);
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background var(--mv2-dur) var(--mv2-ease),
              color var(--mv2-dur) var(--mv2-ease),
              border-color var(--mv2-dur) var(--mv2-ease),
              box-shadow var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"] .mv2-btn--primary {
  background: var(--mv2-brand);
  color: #FFFFFF;
}
body[data-portal="public"] .mv2-btn--primary:hover { background: var(--mv2-brand-dark); }
body[data-portal="public"] .mv2-btn--ghost {
  background: transparent;
  color: var(--mv2-ink);
  border-color: var(--mv2-hairline-strong);
}
body[data-portal="public"] .mv2-btn--ghost:hover { background: #FFFFFF; border-color: var(--mv2-ink); }
@media (min-width: 769px) {
}
@media (min-width: 769px) {
}

/* ── Focus ring (consistent across all mv2-* interactives) ───────── */
body[data-portal="public"] .mv2-btn:focus-visible,
body[data-portal="public"] a.mv2-pill:focus-visible {
  outline: 2px solid var(--mv2-brand);
  outline-offset: 3px;
}

/* ── Reduced motion: kill non-essential transitions ──────────────── */
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"] .mv2-card,
  body[data-portal="public"] .mv2-btn,
  body[data-portal="public"] .mv2-pill {
    transition: none;
  }
  body[data-portal="public"] .mv2-card--lift:hover { transform: none; }
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.1 — homepage hero refresh (index.html)                     ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.1, agent_issues #31) ║
   ║                                                                      ║
   ║  New hero: cinematic photo background with warm overlay, italic     ║
   ║  Fraunces emphasis headline, refined search bar, micro-trust row.   ║
   ║  All four search IDs (#searchInput, #bedroomsFilter, #maxRentFilter,║
   ║  #searchBtn) preserved on identical input/select/button elements.   ║
   ║                                                                      ║
   ║  Scope: only matches `body[data-portal="public"][data-page="home"]  ║
   ║  .mv2-hero` — listings/property/etc unaffected.                     ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

body[data-portal="public"][data-page="home"] .mv2-hero {
  position: relative;
  isolation: isolate;
  min-height: clamp(560px, 88svh, 820px);
  display: flex;
  align-items: center;
  padding: clamp(80px, 14vw, 140px) 0 clamp(56px, 10vw, 96px);
  background: var(--mv2-bg-warm);
  overflow: hidden;
}

/* ── Background photo + overlays ─────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: hidden;
}
body[data-portal="public"][data-page="home"] .mv2-hero__bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
}
body[data-portal="public"][data-page="home"] .mv2-hero__bg-overlay {
  position: absolute;
  inset: 0;
  background:
    /* darker bottom-left for text legibility */
    linear-gradient(135deg, rgba(10, 23, 41, 0.78) 0%, rgba(10, 23, 41, 0.55) 45%, rgba(10, 23, 41, 0.30) 100%),
    /* warm wash overall */
    linear-gradient(180deg, rgba(20, 14, 5, 0.08) 0%, rgba(10, 23, 41, 0.0) 60%);
}
body[data-portal="public"][data-page="home"] .mv2-hero__bg-vignette {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 40%, transparent 35%, rgba(0, 0, 0, 0.18) 100%);
  pointer-events: none;
}

/* ── Content layout ──────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hero__inner {
  width: 100%;
  color: #FFFFFF;
}
body[data-portal="public"][data-page="home"] .mv2-hero__content {
  max-width: 720px;
}

/* ── Eyebrow (override mv2-eyebrow color for over-photo legibility) ─ */
body[data-portal="public"][data-page="home"] .mv2-hero .mv2-eyebrow {
  color: #F4DD8A;                                    /* warm gold over photo */
  margin-bottom: var(--mv2-stack-3);
}
body[data-portal="public"][data-page="home"] .mv2-hero .mv2-eyebrow::before {
  background: #F4DD8A;
}
body[data-portal="public"][data-page="home"] .mv2-hero .mv2-eyebrow-pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #B7F1C6;
  box-shadow: 0 0 0 0 rgba(183, 241, 198, 0.8);
  animation: mv2-pulse 2.4s ease-out infinite;
  display: inline-block;
}
@keyframes mv2-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(183, 241, 198, 0.7); }
  70%  { box-shadow: 0 0 0 12px rgba(183, 241, 198, 0); }
  100% { box-shadow: 0 0 0 0 rgba(183, 241, 198, 0); }
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-hero .mv2-eyebrow-pulse { animation: none; }
}

/* ── Headline (override mv2-headline color for over-photo) ────────── */
body[data-portal="public"][data-page="home"] .mv2-hero .mv2-headline {
  color: #FFFFFF;
  font-size: clamp(2.125rem, 1.6rem + 3vw, 3.75rem);
  margin-bottom: var(--mv2-stack-4);
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.30);
}
body[data-portal="public"][data-page="home"] .mv2-hero .mv2-headline em {
  color: #F4DD8A;
  font-style: normal;
  font-weight: 700;
  text-decoration: underline;
  text-decoration-color: rgba(244, 221, 138, 0.45);
  text-underline-offset: 5px;
  text-decoration-thickness: 2px;
}

/* ── Lede ────────────────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hero .mv2-lede {
  color: rgba(255, 255, 255, 0.92);
  margin-bottom: var(--mv2-stack-5);
  max-width: 56ch;
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.25);
}

/* ── Search card (floating glass effect) ─────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hero__search {
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: saturate(160%) blur(8px);
  border-radius: var(--mv2-r-lg);
  padding: 14px;
  box-shadow: 0 18px 48px rgba(10, 23, 41, 0.30), 0 2px 6px rgba(10, 23, 41, 0.18);
  margin-bottom: var(--mv2-stack-5);
  max-width: 720px;
  border: 1px solid rgba(255, 255, 255, 0.6);
}
body[data-portal="public"][data-page="home"] .mv2-hero__search-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items: stretch;
}
@media (min-width: 769px) {
  body[data-portal="public"][data-page="home"] .mv2-hero__search-row {
    grid-template-columns: 1.6fr 1fr 1.1fr auto;
    gap: 8px;
  }
}

/* ── Search field ────────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hero__search-field {
  position: relative;
  display: flex;
  align-items: center;
  background: var(--mv2-bg-warm);
  border: 1px solid var(--mv2-hairline);
  border-radius: var(--mv2-r-md);
  min-height: 52px;
  padding: 0 14px 0 42px;
  transition: border-color var(--mv2-dur) var(--mv2-ease),
              background var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="home"] .mv2-hero__search-field:focus-within {
  border-color: var(--mv2-brand);
  background: #FFFFFF;
  box-shadow: 0 0 0 3px rgba(0, 106, 255, 0.12);
}
body[data-portal="public"][data-page="home"] .mv2-hero__search-field > i {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--mv2-muted-2);
  font-size: 14px;
  pointer-events: none;
}
body[data-portal="public"][data-page="home"] .mv2-hero__search-field input,
body[data-portal="public"][data-page="home"] .mv2-hero__search-field select {
  flex: 1;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 0.96rem;
  color: var(--mv2-ink);
  padding: 0;
  outline: none;
  min-width: 0;
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
}
body[data-portal="public"][data-page="home"] .mv2-hero__search-field select {
  padding-right: 22px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path fill='%236B7280' d='M6 8L2 4h8z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 0 center;
  cursor: pointer;
}
body[data-portal="public"][data-page="home"] .mv2-hero__search-field input::placeholder {
  color: var(--mv2-muted-2);
}

/* ── Search button ───────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hero__search-btn {
  min-height: 52px;
  padding: 0 22px;
  border-radius: var(--mv2-r-md);
  font-weight: 600;
  white-space: nowrap;
}
@media (max-width: 768px) {
  body[data-portal="public"][data-page="home"] .mv2-hero__search-btn {
    width: 100%;
    margin-top: 4px;
  }
}

/* ── Micro-trust signals row ─────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hero__trust {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 18px 26px;
  align-items: center;
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.92rem;
}
body[data-portal="public"][data-page="home"] .mv2-hero__trust li {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
body[data-portal="public"][data-page="home"] .mv2-hero__trust li i {
  color: #F4DD8A;
  font-size: 14px;
}

/* ── Mobile tweaks ───────────────────────────────────────────────── */
@media (max-width: 768px) {
  body[data-portal="public"][data-page="home"] .mv2-hero {
    min-height: clamp(620px, 92svh, 760px);
    padding: clamp(72px, 18vw, 100px) 0 clamp(40px, 8vw, 64px);
    align-items: flex-end;          /* anchor content to bottom on small screens */
  }
  body[data-portal="public"][data-page="home"] .mv2-hero__content {
    max-width: 100%;
  }
  body[data-portal="public"][data-page="home"] .mv2-hero .mv2-lede {
    margin-bottom: var(--mv2-stack-4);
  }
  body[data-portal="public"][data-page="home"] .mv2-hero__search {
    padding: 10px;
  }
  body[data-portal="public"][data-page="home"] .mv2-hero__trust {
    gap: 10px 18px;
    font-size: 0.86rem;
  }
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.2 — Featured listings refresh + freshness chip             ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.2, agent_issues #32) ║
   ║                                                                      ║
   ║  - mv2-featured: warm-white section with editorial header           ║
   ║  - mobile horizontal snap-scroll (3-up grid on desktop)             ║
   ║  - .property-card-fresh-chip: small "Just listed" chip in top-left  ║
   ║    of the card, stacked under the existing availability badge       ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

body[data-portal="public"][data-page="home"] .mv2-featured {
  background: var(--mv2-bg-warm);
  padding: var(--mv2-section-y-mobile) 0;
  position: relative;
}
@media (min-width: 769px) {
  body[data-portal="public"][data-page="home"] .mv2-featured {
    padding: var(--mv2-section-y-desktop) 0;
  }
}

/* Header row */
body[data-portal="public"][data-page="home"] .mv2-featured__header {
  display: flex;
  flex-direction: column;
  gap: var(--mv2-stack-3);
  margin-bottom: var(--mv2-stack-5);
  align-items: flex-start;
}
@media (min-width: 769px) {
  body[data-portal="public"][data-page="home"] .mv2-featured__header {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    gap: var(--mv2-stack-5);
  }
}
body[data-portal="public"][data-page="home"] .mv2-featured__heading {
  max-width: 640px;
}
body[data-portal="public"][data-page="home"] .mv2-featured__title {
  margin-bottom: var(--mv2-stack-2);
}
body[data-portal="public"][data-page="home"] .mv2-featured__subtitle {
  color: var(--mv2-muted);
  font-size: var(--mv2-fs-body);
  line-height: var(--mv2-lh-body);
  margin: 0;
  max-width: 56ch;
}
body[data-portal="public"][data-page="home"] .mv2-featured__view-all {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--mv2-brand);
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  padding: 6px 0;
  border-bottom: 1px solid transparent;
  transition: border-color var(--mv2-dur) var(--mv2-ease),
              color var(--mv2-dur) var(--mv2-ease);
  white-space: nowrap;
}
body[data-portal="public"][data-page="home"] .mv2-featured__view-all:hover {
  color: var(--mv2-brand-dark);
  border-bottom-color: var(--mv2-brand);
}
body[data-portal="public"][data-page="home"] .mv2-featured__view-all i {
  font-size: 12px;
  transition: transform var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="home"] .mv2-featured__view-all:hover i { transform: translateX(3px); }

/* Bottom CTA */
body[data-portal="public"][data-page="home"] .mv2-featured__cta {
  display: flex;
  justify-content: center;
  margin-top: var(--mv2-stack-6);
}

/* ── Mobile horizontal snap-scroll ─────────────────────────────────
   Higher specificity than the global .property-grid rule, so the same
   <div id="featuredGrid" class="property-grid"> renders as snap-row on
   mobile only on the home page. Listings.html is unaffected. */
@media (max-width: 768px) {
  body[data-portal="public"][data-page="home"] #featuredGrid {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: var(--mv2-container-x);
    -webkit-overflow-scrolling: touch;
    padding: 4px var(--mv2-container-x) 22px;
    margin: 0 calc(-1 * var(--mv2-container-x));
    scrollbar-width: none;
  }
  body[data-portal="public"][data-page="home"] #featuredGrid::-webkit-scrollbar { display: none; }
  body[data-portal="public"][data-page="home"] #featuredGrid > .property-card,
  body[data-portal="public"][data-page="home"] #featuredGrid > .property-card-skeleton {
    flex: 0 0 86%;
    max-width: 340px;
    scroll-snap-align: start;
  }
}

/* ── Freshness chip (rendered by card-builder.js) ──────────────────
   Uses absolute positioning inside .property-card-img, stacked under
   the existing top-left badge with a small gap. Visible on every card
   that has p.created_at within the last 7 days. */
body[data-portal="public"] .property-card-fresh-chip {
  position: absolute;
  top: 56px;                    /* sits under the existing badge (≈40px tall + gap) */
  left: 12px;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px 5px 9px;
  background: rgba(4, 120, 87, 0.95);
  color: #FFFFFF;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  border-radius: var(--mv2-r-pill);
  box-shadow: 0 2px 8px rgba(4, 120, 87, 0.30);
  pointer-events: none;
}
body[data-portal="public"] .property-card-fresh-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #B7F1C6;
  box-shadow: 0 0 0 0 rgba(183, 241, 198, 0.8);
  animation: mv2-fresh-pulse 2.4s ease-out infinite;
}
@keyframes mv2-fresh-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(183, 241, 198, 0.8); }
  70%  { box-shadow: 0 0 0 8px rgba(183, 241, 198, 0); }
  100% { box-shadow: 0 0 0 0 rgba(183, 241, 198, 0); }
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"] .property-card-fresh-dot { animation: none; }
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.3 — How It Works: vertical scroll-progress timeline        ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.3, agent_issues #33) ║
   ║                                                                      ║
   ║  - Vertical rail with progress fill driven by --hiw-progress (0-1)  ║
   ║    set by the inline rAF script in the section.                      ║
   ║  - Step bubbles transition to active state when their center crosses ║
   ║    the viewport anchor (55% down).                                   ║
   ║  - Reduced motion: rail full, all steps active by default, no transit║
   ╚══════════════════════════════════════════════════════════════════════╝ */

body[data-portal="public"][data-page="home"] .mv2-hiw {
  background: #FFFFFF;
  padding: var(--mv2-section-y-mobile) 0;
  position: relative;
}
@media (min-width: 769px) {
  body[data-portal="public"][data-page="home"] .mv2-hiw {
    padding: var(--mv2-section-y-desktop) 0;
  }
}

/* Header */
body[data-portal="public"][data-page="home"] .mv2-hiw__header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--mv2-stack-7);
}
body[data-portal="public"][data-page="home"] .mv2-hiw__header .mv2-eyebrow {
  justify-content: center;
}
body[data-portal="public"][data-page="home"] .mv2-hiw__subtitle {
  color: var(--mv2-muted);
  font-size: var(--mv2-fs-body);
  line-height: var(--mv2-lh-body);
  margin: var(--mv2-stack-3) auto 0;
  max-width: 56ch;
}

/* ── Track + rail ─────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hiw__track {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  position: relative;
  max-width: 760px;
  --hiw-progress: 0;
  --hiw-bubble-size: 56px;
  --hiw-rail-x: 28px;          /* center of bubble = (56/2) */
}
@media (min-width: 769px) {
  body[data-portal="public"][data-page="home"] .mv2-hiw__track {
    --hiw-bubble-size: 72px;
    --hiw-rail-x: 36px;
  }
}
body[data-portal="public"][data-page="home"] .mv2-hiw__rail {
  position: absolute;
  top: var(--hiw-bubble-size);
  bottom: var(--hiw-bubble-size);
  left: var(--hiw-rail-x);
  width: 2px;
  background: var(--mv2-hairline);
  transform: translateX(-1px);
  border-radius: 2px;
  overflow: hidden;
  z-index: 0;
}
body[data-portal="public"][data-page="home"] .mv2-hiw__rail-fill {
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, var(--mv2-brand) 0%, var(--mv2-brand-dark) 100%);
  transform: scaleY(var(--hiw-progress));
  transform-origin: top center;
  transition: transform 240ms var(--mv2-ease);
  will-change: transform;
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-hiw__rail-fill { transition: none; }
}

/* ── Step row ─────────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hiw__step {
  position: relative;
  display: grid;
  grid-template-columns: var(--hiw-bubble-size) 1fr;
  gap: clamp(16px, 3vw, 28px);
  align-items: flex-start;
  padding: 8px 0 clamp(36px, 6vw, 72px);
  z-index: 1;
}
body[data-portal="public"][data-page="home"] .mv2-hiw__step:last-child {
  padding-bottom: 0;
}

/* ── Bubble (default = pre-active state) ──────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hiw__bubble {
  width: var(--hiw-bubble-size);
  height: var(--hiw-bubble-size);
  border-radius: 50%;
  background: #FFFFFF;
  border: 2px solid var(--mv2-hairline);
  color: var(--mv2-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex-shrink: 0;
  transition: background var(--mv2-dur-lg) var(--mv2-ease),
              border-color var(--mv2-dur-lg) var(--mv2-ease),
              color var(--mv2-dur-lg) var(--mv2-ease),
              transform var(--mv2-dur-lg) var(--mv2-ease),
              box-shadow var(--mv2-dur-lg) var(--mv2-ease);
}
body[data-portal="public"][data-page="home"] .mv2-hiw__bubble-num {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 700;
  font-size: clamp(0.95rem, 0.9rem + 0.3vw, 1.15rem);
  line-height: 1;
  position: absolute;
  top: 6px;
  right: 8px;
  color: inherit;
  opacity: 0.65;
}
body[data-portal="public"][data-page="home"] .mv2-hiw__bubble-icon {
  font-size: clamp(18px, 1.2vw + 14px, 24px);
}

/* ── Bubble: active state ─────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hiw__step.is-active .mv2-hiw__bubble {
  background: var(--mv2-brand);
  border-color: var(--mv2-brand);
  color: #FFFFFF;
  transform: scale(1.04);
  box-shadow: 0 8px 24px rgba(0, 106, 255, 0.28);
}
body[data-portal="public"][data-page="home"] .mv2-hiw__step.is-active .mv2-hiw__bubble-num {
  opacity: 0.9;
}

/* ── Step body ────────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hiw__body {
  padding-top: 6px;
  transition: opacity var(--mv2-dur-lg) var(--mv2-ease),
              transform var(--mv2-dur-lg) var(--mv2-ease);
  opacity: 0.62;
  transform: translateY(2px);
}
body[data-portal="public"][data-page="home"] .mv2-hiw__step.is-active .mv2-hiw__body {
  opacity: 1;
  transform: translateY(0);
}
body[data-portal="public"][data-page="home"] .mv2-hiw__step-title {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 600;
  font-size: clamp(1.25rem, 1rem + 1vw, 1.625rem);
  line-height: 1.25;
  color: var(--mv2-ink);
  margin: 0 0 8px;
}
body[data-portal="public"][data-page="home"] .mv2-hiw__step-desc {
  color: var(--mv2-muted);
  font-size: var(--mv2-fs-body);
  line-height: var(--mv2-lh-body);
  margin: 0;
  max-width: 56ch;
}

/* Reduced motion fallback: all bodies fully visible by default */
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-hiw__bubble,
  body[data-portal="public"][data-page="home"] .mv2-hiw__body { transition: none; }
  body[data-portal="public"][data-page="home"] .mv2-hiw__body { opacity: 1; transform: none; }
}

/* ── CTA ──────────────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hiw__cta {
  display: flex;
  flex-direction: column;
  gap: var(--mv2-stack-3);
  align-items: center;
  margin-top: var(--mv2-stack-7);
  text-align: center;
}
@media (min-width: 769px) {
  body[data-portal="public"][data-page="home"] .mv2-hiw__cta {
    flex-direction: row;
    justify-content: center;
    gap: var(--mv2-stack-5);
  }
}
body[data-portal="public"][data-page="home"] .mv2-hiw__cta-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--mv2-brand);
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  padding: 10px 0;
  border-bottom: 1px solid transparent;
  transition: border-color var(--mv2-dur) var(--mv2-ease),
              color var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="home"] .mv2-hiw__cta-link:hover {
  color: var(--mv2-brand-dark);
  border-bottom-color: var(--mv2-brand);
}
body[data-portal="public"][data-page="home"] .mv2-hiw__cta-link i {
  font-size: 12px;
  transition: transform var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="home"] .mv2-hiw__cta-link:hover i { transform: translateX(3px); }

/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.4 — "Verified, every time" trust block                     ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.4, agent_issues #34) ║
   ║                                                                      ║
   ║  4-pillar trust section between Featured & HIW. Warm-bg, centered   ║
   ║  header, 4-up grid on desktop, 2x2 on tablet, 1-up on mobile.       ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

body[data-portal="public"][data-page="home"] .mv2-trustblock {
  background: var(--mv2-bg-warm);
  padding: var(--mv2-section-y-mobile) 0;
  position: relative;
}
@media (min-width: 769px) {
  body[data-portal="public"][data-page="home"] .mv2-trustblock {
    padding: var(--mv2-section-y-desktop) 0;
  }
}

/* Header */
body[data-portal="public"][data-page="home"] .mv2-trustblock__header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--mv2-stack-7);
}
body[data-portal="public"][data-page="home"] .mv2-trustblock__header .mv2-eyebrow {
  justify-content: center;
}
body[data-portal="public"][data-page="home"] .mv2-trustblock__subtitle {
  color: var(--mv2-muted);
  font-size: var(--mv2-fs-body);
  line-height: var(--mv2-lh-body);
  margin: var(--mv2-stack-3) auto 0;
  max-width: 60ch;
}

/* Pillar grid */
body[data-portal="public"][data-page="home"] .mv2-trustblock__pillars {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--mv2-stack-5);
  max-width: 1100px;
}
@media (min-width: 600px) {
  body[data-portal="public"][data-page="home"] .mv2-trustblock__pillars {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--mv2-stack-5) var(--mv2-stack-5);
  }
}
@media (min-width: 1024px) {
  body[data-portal="public"][data-page="home"] .mv2-trustblock__pillars {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--mv2-stack-5);
  }
}

/* Single pillar */
body[data-portal="public"][data-page="home"] .mv2-trustblock__pillar {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  padding: 0;
}
body[data-portal="public"][data-page="home"] .mv2-trustblock__pillar-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: rgba(212, 160, 23, 0.10);
  color: var(--mv2-gold);
  font-size: 22px;
  margin-bottom: var(--mv2-stack-3);
  box-shadow: inset 0 0 0 1px rgba(212, 160, 23, 0.18);
}
body[data-portal="public"][data-page="home"] .mv2-trustblock__pillar-title {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 600;
  font-size: clamp(1.125rem, 0.95rem + 0.5vw, 1.3rem);
  line-height: 1.25;
  color: var(--mv2-ink);
  margin: 0 0 8px;
}
body[data-portal="public"][data-page="home"] .mv2-trustblock__pillar-desc {
  color: var(--mv2-muted);
  font-size: 0.95rem;
  line-height: 1.55;
  margin: 0;
  max-width: 36ch;
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.5 — Testimonials humanization                              ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.5, agent_issues #35) ║
   ║                                                                      ║
   ║  - Initials avatar circles (italic Fraunces, soft gold tint)        ║
   ║  - Middle card promoted to "story tile": italic display quote +     ║
   ║    gold left accent + warmer paper bg                                ║
   ║  - Mobile: 1-up vertical, then horizontal snap carousel >=600px,    ║
   ║    3-up grid on desktop (story tile spans 2 columns)                 ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

body[data-portal="public"][data-page="home"] .mv2-testimonials {
  background: #FFFFFF;
  padding: var(--mv2-section-y-mobile) 0;
  position: relative;
}
@media (min-width: 769px) {
  body[data-portal="public"][data-page="home"] .mv2-testimonials {
    padding: var(--mv2-section-y-desktop) 0;
  }
}

/* Header */
body[data-portal="public"][data-page="home"] .mv2-testimonials__header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--mv2-stack-7);
}
body[data-portal="public"][data-page="home"] .mv2-testimonials__header .mv2-eyebrow {
  justify-content: center;
}
body[data-portal="public"][data-page="home"] .mv2-testimonials__subtitle {
  color: var(--mv2-muted);
  font-size: var(--mv2-fs-body);
  line-height: var(--mv2-lh-body);
  margin: var(--mv2-stack-3) auto 0;
  max-width: 56ch;
}

/* ── Row layout ───────────────────────────────────────────────────
   Mobile (<600px): vertical stack
   Tablet (600–1023px): horizontal snap carousel
   Desktop (>=1024px): 3-column grid; story tile spans 2 columns
*/
body[data-portal="public"][data-page="home"] .mv2-testimonials__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--mv2-stack-4);
  max-width: 1200px;
  margin: 0 auto;
}
@media (min-width: 600px) and (max-width: 1023px) {
  body[data-portal="public"][data-page="home"] .mv2-testimonials__row {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 14px;
    padding: 6px var(--mv2-container-x) 22px;
    margin: 0 calc(-1 * var(--mv2-container-x));
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  body[data-portal="public"][data-page="home"] .mv2-testimonials__row::-webkit-scrollbar { display: none; }
  body[data-portal="public"][data-page="home"] .mv2-testimonials__row > .mv2-testimonial {
    flex: 0 0 86%;
    max-width: 460px;
    scroll-snap-align: start;
  }
}
@media (min-width: 1024px) {
  body[data-portal="public"][data-page="home"] .mv2-testimonials__row {
    grid-template-columns: 1fr 1.5fr 1fr;
    gap: var(--mv2-stack-5);
    align-items: stretch;
  }
}

/* ── Single testimonial card ─────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-testimonial {
  background: #FFFFFF;
  border: 1px solid var(--mv2-hairline);
  border-radius: var(--mv2-r-lg);
  padding: 28px 24px 24px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
  transition: border-color var(--mv2-dur) var(--mv2-ease),
              box-shadow var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="home"] .mv2-testimonial:hover {
  border-color: rgba(0, 106, 255, 0.18);
  box-shadow: 0 6px 24px rgba(10, 23, 41, 0.06);
}

/* Story tile variant */
body[data-portal="public"][data-page="home"] .mv2-testimonial--story {
  background: var(--mv2-bg-warm);
  border-color: rgba(212, 160, 23, 0.30);
  box-shadow: 0 1px 0 rgba(212, 160, 23, 0.12) inset;
}
body[data-portal="public"][data-page="home"] .mv2-testimonial--story::before {
  content: "";
  position: absolute;
  left: 0; top: 24px; bottom: 24px;
  width: 3px;
  background: linear-gradient(180deg, var(--mv2-gold) 0%, rgba(212, 160, 23, 0.5) 100%);
  border-radius: 0 3px 3px 0;
}
body[data-portal="public"][data-page="home"] .mv2-testimonial__quote-icon {
  position: absolute;
  top: 22px;
  right: 22px;
  font-size: 22px;
  color: rgba(212, 160, 23, 0.45);
}

/* ── Initials avatar ─────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: 0.01em;
  color: #5A4416;
  background: rgba(212, 160, 23, 0.16);
  border: 1px solid rgba(212, 160, 23, 0.28);
  flex-shrink: 0;
}
/* per-card hue tints (additive variety, still in the warm gold family) */
body[data-portal="public"][data-page="home"] .mv2-avatar--mt {
  background: rgba(0, 106, 255, 0.10);
  color: #1B3A87;
  border-color: rgba(0, 106, 255, 0.22);
}
body[data-portal="public"][data-page="home"] .mv2-avatar--ps {
  /* keep the gold default — it's the story tile */
}
body[data-portal="public"][data-page="home"] .mv2-avatar--jk {
  background: rgba(4, 120, 87, 0.10);
  color: #044E37;
  border-color: rgba(4, 120, 87, 0.22);
}

/* ── Quote text ──────────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-testimonial__quote {
  margin: 0;
  color: var(--mv2-ink);
  font-size: 1rem;
  line-height: 1.6;
  font-style: normal;
}
body[data-portal="public"][data-page="home"] .mv2-testimonial__quote--display {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 500;
  font-size: clamp(1.15rem, 0.95rem + 0.7vw, 1.45rem);
  line-height: 1.45;
  color: var(--mv2-ink);
  padding-left: 8px;
}

/* ── Meta ────────────────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-testimonial__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: auto;
  padding-top: 6px;
}
body[data-portal="public"][data-page="home"] .mv2-testimonial__name {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--mv2-ink);
}
body[data-portal="public"][data-page="home"] .mv2-testimonial__detail {
  font-size: 0.85rem;
  color: var(--mv2-muted);
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.6 — City spotlight strip                                   ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.6, agent_issues #36) ║
   ║                                                                      ║
   ║  Pill row of 8 markets, each → /listings.html?city=<Name>.          ║
   ║  Mobile: horizontal snap scroll. Desktop: wrap to 2 rows of 4.      ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

body[data-portal="public"][data-page="home"] .mv2-cities {
  background: #FFFFFF;
  padding: clamp(48px, 7vw, 80px) 0;
  position: relative;
}

body[data-portal="public"][data-page="home"] .mv2-cities__header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--mv2-stack-5);
}
body[data-portal="public"][data-page="home"] .mv2-cities__header .mv2-eyebrow {
  justify-content: center;
}
body[data-portal="public"][data-page="home"] .mv2-cities__subtitle {
  color: var(--mv2-muted);
  font-size: var(--mv2-fs-body);
  line-height: var(--mv2-lh-body);
  margin: var(--mv2-stack-3) auto 0;
  max-width: 56ch;
}

/* ── Pill row ──────────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-cities__row {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 600px) {
  body[data-portal="public"][data-page="home"] .mv2-cities__row {
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 4px var(--mv2-container-x) 18px;
    margin: 0 calc(-1 * var(--mv2-container-x));
    gap: 10px;
    scrollbar-width: none;
    justify-content: flex-start;
  }
  body[data-portal="public"][data-page="home"] .mv2-cities__row::-webkit-scrollbar { display: none; }
  body[data-portal="public"][data-page="home"] .mv2-cities__item {
    scroll-snap-align: start;
    flex-shrink: 0;
  }
}

body[data-portal="public"][data-page="home"] .mv2-cities__item { margin: 0; }

/* ── Single pill ──────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-cities__pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px 12px 14px;
  background: var(--mv2-bg-warm);
  border: 1px solid var(--mv2-hairline);
  border-radius: var(--mv2-r-pill);
  color: var(--mv2-ink);
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 500;
  white-space: nowrap;
  transition: background var(--mv2-dur) var(--mv2-ease),
              border-color var(--mv2-dur) var(--mv2-ease),
              color var(--mv2-dur) var(--mv2-ease),
              transform var(--mv2-dur) var(--mv2-ease),
              box-shadow var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="home"] .mv2-cities__pill:hover,
body[data-portal="public"][data-page="home"] .mv2-cities__pill:focus-visible {
  background: #FFFFFF;
  border-color: var(--mv2-brand);
  color: var(--mv2-brand-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(0, 106, 255, 0.10);
  outline: none;
}
body[data-portal="public"][data-page="home"] .mv2-cities__pill-icon {
  font-size: 14px;
  color: var(--mv2-gold);
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(212, 160, 23, 0.12);
}
body[data-portal="public"][data-page="home"] .mv2-cities__pill:hover .mv2-cities__pill-icon,
body[data-portal="public"][data-page="home"] .mv2-cities__pill:focus-visible .mv2-cities__pill-icon {
  background: rgba(0, 106, 255, 0.10);
  color: var(--mv2-brand);
}
body[data-portal="public"][data-page="home"] .mv2-cities__pill-name {
  font-weight: 600;
}
body[data-portal="public"][data-page="home"] .mv2-cities__pill-state {
  color: var(--mv2-muted-2);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-cities__pill { transition: none; }
  body[data-portal="public"][data-page="home"] .mv2-cities__pill:hover { transform: none; }
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.7 — Emotional final CTA + mv2 mobile sticky CTA refresh    ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.7, agent_issues #37) ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* ── Final CTA section (warm gradient, editorial close) ───────────── */
body[data-portal="public"][data-page="home"] .mv2-finalcta {
  position: relative;
  padding: clamp(72px, 10vw, 128px) 0;
  overflow: hidden;
  text-align: center;
  isolation: isolate;
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__bg {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse at top, rgba(212, 160, 23, 0.10) 0%, transparent 55%),
    radial-gradient(ellipse at bottom right, rgba(0, 106, 255, 0.06) 0%, transparent 60%),
    linear-gradient(180deg, var(--mv2-bg-warm) 0%, #FFFEFC 100%);
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__bg::after {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(212, 160, 23, 0.35) 50%,
    transparent 100%);
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__inner {
  max-width: 720px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--mv2-stack-4);
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__eyebrow {
  margin: 0;
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__headline {
  margin: 0;
  max-width: 16ch;
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__subtitle {
  margin: 0;
  color: var(--mv2-muted);
  font-size: clamp(1rem, 0.95rem + 0.3vw, 1.15rem);
  line-height: 1.6;
  max-width: 52ch;
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
  margin-top: var(--mv2-stack-3);
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__cta {
  min-height: 52px;
  padding: 0 28px;
  font-size: 1rem;
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__cta i {
  margin-left: 8px;
  font-size: 0.85em;
  transition: transform var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__cta:hover i {
  transform: translateX(3px);
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__reassurance {
  margin: var(--mv2-stack-3) 0 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--mv2-muted-2);
  font-size: 0.85rem;
  font-weight: 500;
}
body[data-portal="public"][data-page="home"] .mv2-finalcta__reassurance i {
  color: var(--mv2-gold);
  font-size: 0.95em;
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-finalcta__cta:hover i { transform: none; }
}

/* ── Mobile sticky CTA refresh (mv2-mcta) ──────────────────────────
   Scoped under [data-portal="public"] so it works on any public page,
   not just home (matches placement of the bar in the markup).
*/
[data-portal="public"] .mv2-mcta {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 60;
  display: flex;
  gap: 10px;
  padding: 10px 14px calc(10px + env(safe-area-inset-bottom, 0px));
  background: rgba(255, 254, 251, 0.92);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-top: 1px solid var(--mv2-hairline);
  box-shadow: 0 -6px 24px rgba(10, 23, 41, 0.06);
  transform: translateY(110%);
  transition: transform 280ms var(--mv2-ease);
}
[data-portal="public"] .mv2-mcta.mv2-mcta--visible {
  transform: translateY(0);
}
[data-portal="public"] .mv2-mcta__btn {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  padding: 0 14px;
  border-radius: var(--mv2-r-md);
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: background var(--mv2-dur) var(--mv2-ease),
              color var(--mv2-dur) var(--mv2-ease),
              border-color var(--mv2-dur) var(--mv2-ease);
}
[data-portal="public"] .mv2-mcta__btn--ghost {
  background: rgba(255, 255, 255, 0.7);
  color: var(--mv2-ink);
  border: 1px solid var(--mv2-hairline);
}
[data-portal="public"] .mv2-mcta__btn--ghost:hover,
[data-portal="public"] .mv2-mcta__btn--ghost:focus-visible {
  background: #FFFFFF;
  color: var(--mv2-brand-dark);
  border-color: var(--mv2-brand);
  outline: none;
}
[data-portal="public"] .mv2-mcta__btn--primary {
  background: linear-gradient(180deg, var(--mv2-brand) 0%, var(--mv2-brand-dark) 100%);
  color: #FFFFFF;
  border: 1px solid var(--mv2-brand-dark);
  box-shadow: 0 2px 8px rgba(0, 106, 255, 0.25);
}
[data-portal="public"] .mv2-mcta__btn--primary:hover,
[data-portal="public"] .mv2-mcta__btn--primary:focus-visible {
  background: var(--mv2-brand-dark);
  color: #FFFFFF;
  outline: none;
}
[data-portal="public"] .mv2-mcta__btn i {
  font-size: 0.9em;
}
@media (min-width: 769px) {
  [data-portal="public"] .mv2-mcta { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  [data-portal="public"] .mv2-mcta { transition: none; }
}

/* On home page when mobile CTA is visible, add bottom padding so footer
   isn't covered. Footer is injected so we add padding to body. */
@media (max-width: 768px) {
  body[data-portal="public"][data-page="home"] { padding-bottom: 76px; }
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.8 — listings.html mv2 refresh                              ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.8, agent_issues #38) ║
   ║                                                                      ║
   ║  Scoped to body[data-portal="public"][data-page="listings"]         ║
   ║  Additive — preserves all #IDs that listings.js depends on.          ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* ── Page header: warm bg, italic Fraunces title ────────────────── */
body[data-portal="public"][data-page="listings"] .mv2-listings-header {
  position: relative;
  padding: clamp(40px, 6vw, 72px) 0 clamp(24px, 3vw, 36px);
  isolation: isolate;
  border-bottom: 1px solid var(--mv2-hairline);
}
body[data-portal="public"][data-page="listings"] .mv2-listings-header__bg {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse at top left, rgba(212, 160, 23, 0.07) 0%, transparent 55%),
    linear-gradient(180deg, var(--mv2-bg-warm) 0%, #FFFEFC 100%);
}
body[data-portal="public"][data-page="listings"] .mv2-listings-header__inner {
  display: flex;
  flex-direction: column;
  gap: var(--mv2-stack-3);
}
body[data-portal="public"][data-page="listings"] .mv2-listings-header__eyebrow {
  margin: 0;
}
body[data-portal="public"][data-page="listings"] .mv2-listings-header__title {
  margin: 0;
  font-family: var(--mv2-display);
  font-weight: 400;
  font-style: normal;
  font-size: clamp(2rem, 1.4rem + 2.4vw, 3.25rem);
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--mv2-ink);
}
body[data-portal="public"][data-page="listings"] .mv2-listings-header__title em {
  font-style: normal;
  font-weight: 700;
  color: var(--mv2-ink);
  background: linear-gradient(180deg, transparent 65%, rgba(212, 160, 23, 0.28) 65%);
  padding: 0 0.05em;
}
body[data-portal="public"][data-page="listings"] .mv2-listings-header__subtitle {
  margin: 0;
  color: var(--mv2-muted);
  font-size: clamp(0.95rem, 0.9rem + 0.25vw, 1.1rem);
  line-height: 1.55;
  max-width: 56ch;
}

/* ── Search row: bigger fields, hairline borders, brand focus ring ── */
body[data-portal="public"][data-page="listings"] .mv2-search-row {
  margin-top: var(--mv2-stack-4);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: stretch;
}
body[data-portal="public"][data-page="listings"] .mv2-search-field {
  position: relative;
  background: #FFFFFF;
  border: 1px solid var(--mv2-hairline);
  border-radius: var(--mv2-r-md);
  transition: border-color var(--mv2-dur) var(--mv2-ease),
              box-shadow var(--mv2-dur) var(--mv2-ease);
  display: flex;
  align-items: center;
  min-height: 50px;
}
body[data-portal="public"][data-page="listings"] .mv2-search-field:focus-within {
  border-color: var(--mv2-brand);
  box-shadow: 0 0 0 3px rgba(0, 106, 255, 0.15);
}
body[data-portal="public"][data-page="listings"] .mv2-search-field > i.fas {
  flex-shrink: 0;
  width: 38px;
  text-align: center;
  font-size: 14px;
  color: var(--mv2-muted-2);
  transition: color var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="listings"] .mv2-search-field:focus-within > i.fas {
  color: var(--mv2-brand);
}
body[data-portal="public"][data-page="listings"] .mv2-search-field input,
body[data-portal="public"][data-page="listings"] .mv2-search-field select {
  flex: 1;
  border: none;
  background: transparent;
  outline: none;
  padding: 12px 14px 12px 0;
  font-size: 0.95rem;
  color: var(--mv2-ink);
  font-family: inherit;
  min-width: 0;
}
body[data-portal="public"][data-page="listings"] .mv2-search-field--text {
  flex: 2 1 280px;
}
body[data-portal="public"][data-page="listings"] .mv2-search-field--select {
  flex: 1 1 150px;
}
body[data-portal="public"][data-page="listings"] .mv2-search-field--select select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='%23788494'><path d='M6 8L2 4h8z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 10px;
  padding-right: 32px;
  cursor: pointer;
}
body[data-portal="public"][data-page="listings"] .mv2-search-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 50px;
  padding: 0 24px;
  border-radius: var(--mv2-r-md);
  background: linear-gradient(180deg, var(--mv2-brand) 0%, var(--mv2-brand-dark) 100%);
  color: #FFFFFF;
  border: 1px solid var(--mv2-brand-dark);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(0, 106, 255, 0.25);
  transition: background var(--mv2-dur) var(--mv2-ease),
              box-shadow var(--mv2-dur) var(--mv2-ease),
              transform var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="listings"] .mv2-search-btn:hover,
body[data-portal="public"][data-page="listings"] .mv2-search-btn:focus-visible {
  background: var(--mv2-brand-dark);
  box-shadow: 0 4px 14px rgba(0, 106, 255, 0.35);
  transform: translateY(-1px);
  outline: none;
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="listings"] .mv2-search-btn:hover { transform: none; }
}
@media (max-width: 600px) {
  body[data-portal="public"][data-page="listings"] .mv2-search-field--text { flex: 1 1 100%; }
  body[data-portal="public"][data-page="listings"] .mv2-search-btn { flex: 1 1 100%; }
}

/* ── Filter bar polish ─────────────────────────────────────────── */
body[data-portal="public"][data-page="listings"] .mv2-filter-bar {
  background: #FFFFFF;
  border-bottom: 1px solid var(--mv2-hairline);
}

/* ── Listings section header ────────────────────────────────────── */
body[data-portal="public"][data-page="listings"] .mv2-listings-section {
  background: #FFFFFF;
  padding-top: clamp(28px, 4vw, 48px);
}
body[data-portal="public"][data-page="listings"] .mv2-listings-heading {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 400;
  font-size: clamp(1.4rem, 1.1rem + 0.8vw, 1.85rem);
  line-height: 1.2;
  letter-spacing: -0.005em;
  color: var(--mv2-ink);
}
/* JS may highlight city/area text inside <em> in the listings heading */
body[data-portal="public"][data-page="listings"] .mv2-listings-heading em {
  font-style: normal;
  font-weight: 700;
  color: var(--mv2-accent-strong);
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.9 — property.html mv2 refresh                              ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.9, agent_issues #39) ║
   ║                                                                      ║
   ║  Scoped to body[data-portal="public"][data-page="property"]         ║
   ║  Additive — no JS-touched IDs altered.                               ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* ── Page bg: warm paper top fade for editorial feel ──────────────── */
body[data-portal="public"][data-page="property"] .mv2-property {
  position: relative;
  isolation: isolate;
}
body[data-portal="public"][data-page="property"] .mv2-property::before {
  content: "";
  position: absolute; left: 0; right: 0; top: 0; height: 280px;
  background: linear-gradient(180deg, var(--mv2-bg-warm) 0%, transparent 100%);
  z-index: -1;
  pointer-events: none;
}

/* ── Breadcrumb: subtle hairline + muted ──────────────────────────── */
body[data-portal="public"][data-page="property"] .mv2-breadcrumb {
  font-size: 0.85rem;
  color: var(--mv2-muted-2);
  letter-spacing: 0.01em;
}
body[data-portal="public"][data-page="property"] .mv2-breadcrumb a {
  color: var(--mv2-muted);
  text-decoration: none;
  transition: color var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="property"] .mv2-breadcrumb a:hover,
body[data-portal="public"][data-page="property"] .mv2-breadcrumb a:focus-visible {
  color: var(--mv2-brand-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
  outline: none;
}

/* ── Detail header: editorial price + Fraunces title ──────────────── */
body[data-portal="public"][data-page="property"] .mv2-detail-header {
  padding-bottom: var(--mv2-stack-3);
  border-bottom: 1px solid var(--mv2-hairline);
  margin-bottom: var(--mv2-stack-4);
}
body[data-portal="public"][data-page="property"] .mv2-detail-header #detailPrice {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 400;
  font-size: clamp(2rem, 1.4rem + 2.4vw, 3rem);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--mv2-ink);
}
body[data-portal="public"][data-page="property"] .mv2-detail-header #detailPrice span {
  font-family: var(--mv2-body);
  font-size: 0.45em;
  font-weight: 500;
  color: var(--mv2-muted);
  margin-left: 4px;
  letter-spacing: 0;
}
body[data-portal="public"][data-page="property"] .mv2-detail-header #detailTitle {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 600;
  font-size: clamp(1.2rem, 1rem + 0.8vw, 1.7rem);
  line-height: 1.3;
  color: var(--mv2-ink);
  margin-top: var(--mv2-stack-2);
}
body[data-portal="public"][data-page="property"] .mv2-detail-header #detailAddress {
  font-size: 0.95rem;
  color: var(--mv2-muted);
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
}
body[data-portal="public"][data-page="property"] .mv2-detail-header #detailAddress i {
  color: var(--mv2-gold);
  font-size: 0.95em;
}

/* ── Section titles (editorial italic Fraunces) ───────────────────── */
body[data-portal="public"][data-page="property"] .mv2-section-title {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 400;
  font-size: clamp(1.25rem, 1.05rem + 0.7vw, 1.6rem);
  line-height: 1.25;
  color: var(--mv2-ink);
  margin-bottom: var(--mv2-stack-3);
  letter-spacing: -0.005em;
}
body[data-portal="public"][data-page="property"] .mv2-section-title em {
  font-style: normal;
  font-weight: 700;
  color: var(--mv2-accent-strong);
  background: linear-gradient(180deg, transparent 65%, rgba(212, 160, 23, 0.22) 65%);
  padding: 0 0.05em;
}

/* ── Apply card sidebar: warm bg, editorial price, polished CTA ──── */
body[data-portal="public"][data-page="property"] .mv2-apply-card {
  background: var(--mv2-bg-warm);
  border: 1px solid var(--mv2-hairline);
  border-radius: var(--mv2-r-lg);
  position: relative;
  overflow: hidden;
}
body[data-portal="public"][data-page="property"] .mv2-apply-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--mv2-gold) 0%, rgba(212, 160, 23, 0.4) 100%);
}
body[data-portal="public"][data-page="property"] .mv2-apply-card #sidebarPrice {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 400;
  font-size: clamp(1.65rem, 1.3rem + 1.4vw, 2.15rem);
  line-height: 1.1;
  color: var(--mv2-ink);
  letter-spacing: -0.01em;
}
body[data-portal="public"][data-page="property"] .mv2-apply-card #sidebarPrice span {
  font-family: var(--mv2-body);
  font-size: 0.45em;
  font-weight: 500;
  color: var(--mv2-muted);
  margin-left: 4px;
}
body[data-portal="public"][data-page="property"] .mv2-apply-card #applyBtn {
  background: linear-gradient(180deg, var(--mv2-brand) 0%, var(--mv2-brand-dark) 100%);
  border: 1px solid var(--mv2-brand-dark);
  font-weight: 600;
  letter-spacing: 0.01em;
  box-shadow: 0 4px 14px rgba(0, 106, 255, 0.25);
  transition: background var(--mv2-dur) var(--mv2-ease),
              box-shadow var(--mv2-dur) var(--mv2-ease),
              transform var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="property"] .mv2-apply-card #applyBtn:hover,
body[data-portal="public"][data-page="property"] .mv2-apply-card #applyBtn:focus-visible {
  background: var(--mv2-brand-dark);
  box-shadow: 0 6px 20px rgba(0, 106, 255, 0.32);
  transform: translateY(-1px);
  outline: none;
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="property"] .mv2-apply-card #applyBtn:hover { transform: none; }
}

/* ── Landlord card: avatar polish ─────────────────────────────────── */
body[data-portal="public"][data-page="property"] .mv2-landlord-card {
  border-color: var(--mv2-hairline);
  border-radius: var(--mv2-r-md);
}
body[data-portal="public"][data-page="property"] .mv2-landlord-card #landlordAvatar {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 700;
  background: rgba(212, 160, 23, 0.16);
  color: #5A4416;
  border: 1px solid rgba(212, 160, 23, 0.28);
}
body[data-portal="public"][data-page="property"] .mv2-landlord-card #landlordVerified {
  color: var(--mv2-brand);
}

/* ── Contact card: cleaner inputs ─────────────────────────────────── */
body[data-portal="public"][data-page="property"] .mv2-contact-card .form-input,
body[data-portal="public"][data-page="property"] .mv2-contact-card .form-textarea {
  border: 1px solid var(--mv2-hairline);
  border-radius: var(--mv2-r-sm);
  padding: 11px 13px;
  font-size: 0.95rem;
  background: #FFFFFF;
  transition: border-color var(--mv2-dur) var(--mv2-ease),
              box-shadow var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="property"] .mv2-contact-card .form-input:focus,
body[data-portal="public"][data-page="property"] .mv2-contact-card .form-textarea:focus {
  border-color: var(--mv2-brand);
  box-shadow: 0 0 0 3px rgba(0, 106, 255, 0.15);
  outline: none;
}
body[data-portal="public"][data-page="property"] .mv2-contact-card .form-label {
  font-weight: 600;
  color: var(--mv2-ink);
  letter-spacing: 0.01em;
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.10 — Secondary marketing pages (about, how-to-apply,       ║
   ║                how-it-works, faq) mv2 refresh                        ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.10, agent_issues #40)║
   ║                                                                      ║
   ║  Shared CSS — 4 pages have identical .info-hero/.info-page/.info-   ║
   ║  content/.info-section skeleton; selector list scopes per data-page. ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* ── Hero: warm paper bg, italic Fraunces title ─────────────────── */
body[data-portal="public"][data-page="about"] .mv2-info-hero,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-hero,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-hero,
body[data-portal="public"][data-page="faq"] .mv2-info-hero {
  position: relative;
  padding: clamp(56px, 8vw, 96px) 0 clamp(40px, 5vw, 64px);
  isolation: isolate;
  border-bottom: 1px solid var(--mv2-hairline);
  text-align: center;
}
body[data-portal="public"][data-page="about"] .mv2-info-hero__bg,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-hero__bg,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-hero__bg,
body[data-portal="public"][data-page="faq"] .mv2-info-hero__bg {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse at top, rgba(212, 160, 23, 0.10) 0%, transparent 55%),
    radial-gradient(ellipse at bottom right, rgba(0, 106, 255, 0.05) 0%, transparent 60%),
    linear-gradient(180deg, var(--mv2-bg-warm) 0%, #FFFEFC 100%);
}
body[data-portal="public"][data-page="about"] .mv2-info-hero-inner,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-hero-inner,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-hero-inner,
body[data-portal="public"][data-page="faq"] .mv2-info-hero-inner {
  position: relative;
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--mv2-stack-3);
  align-items: center;
}

/* ── Hero title (italic Fraunces with gold marker on emphasis) ──── */
body[data-portal="public"][data-page="about"] .mv2-info-hero-title,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-hero-title,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-hero-title,
body[data-portal="public"][data-page="faq"] .mv2-info-hero-title {
  margin: 0;
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 400;
  font-size: clamp(2rem, 1.4rem + 2.4vw, 3.25rem);
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--mv2-ink);
  text-wrap: balance;
}
body[data-portal="public"][data-page="about"] .mv2-info-hero-title em,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-hero-title em,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-hero-title em,
body[data-portal="public"][data-page="faq"] .mv2-info-hero-title em {
  font-style: normal;
  font-weight: 700;
  color: var(--mv2-ink);
  background: linear-gradient(180deg, transparent 65%, rgba(212, 160, 23, 0.30) 65%);
  padding: 0 0.05em;
}

/* ── Hero subtitle ──────────────────────────────────────────────── */
body[data-portal="public"][data-page="about"] .mv2-info-hero-sub,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-hero-sub,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-hero-sub,
body[data-portal="public"][data-page="faq"] .mv2-info-hero-sub {
  margin: 0;
  color: var(--mv2-muted);
  font-size: clamp(1rem, 0.95rem + 0.3vw, 1.2rem);
  line-height: 1.55;
  max-width: 56ch;
  text-wrap: pretty;
}

/* ── Page body: white, comfortable reading width ───────────────── */
body[data-portal="public"][data-page="about"] .mv2-info-page,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-page,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-page,
body[data-portal="public"][data-page="faq"] .mv2-info-page {
  background: #FFFFFF;
  padding: clamp(40px, 6vw, 80px) 0;
}
body[data-portal="public"][data-page="about"] .mv2-info-content,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-content,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-content,
body[data-portal="public"][data-page="faq"] .mv2-info-content {
  max-width: 760px;
  margin: 0 auto;
}

/* ── Sections within the body get rhythm + Fraunces h2s ────────── */
body[data-portal="public"][data-page="about"] .mv2-info-section,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section,
body[data-portal="public"][data-page="faq"] .mv2-info-section {
  margin-bottom: var(--mv2-stack-6);
}
body[data-portal="public"][data-page="about"] .mv2-info-section:last-child,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section:last-child,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section:last-child,
body[data-portal="public"][data-page="faq"] .mv2-info-section:last-child {
  margin-bottom: 0;
}
body[data-portal="public"][data-page="about"] .mv2-info-section h2,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section h2,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section h2,
body[data-portal="public"][data-page="faq"] .mv2-info-section h2 {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 400;
  font-size: clamp(1.4rem, 1.15rem + 1vw, 1.85rem);
  line-height: 1.25;
  letter-spacing: -0.005em;
  color: var(--mv2-ink);
  margin: 0 0 var(--mv2-stack-3);
}
body[data-portal="public"][data-page="about"] .mv2-info-section p,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section p,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section p,
body[data-portal="public"][data-page="faq"] .mv2-info-section p {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--mv2-ink);
  margin: 0 0 var(--mv2-stack-3);
}
body[data-portal="public"][data-page="about"] .mv2-info-section p:last-child,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section p:last-child,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section p:last-child,
body[data-portal="public"][data-page="faq"] .mv2-info-section p:last-child {
  margin-bottom: 0;
}
body[data-portal="public"][data-page="about"] .mv2-info-section ul, .mv2-info-section ol,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section ul, .mv2-info-section ol,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section ul, .mv2-info-section ol,
body[data-portal="public"][data-page="faq"] .mv2-info-section ul, .mv2-info-section ol {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--mv2-ink);
  padding-left: 1.4em;
  margin: 0 0 var(--mv2-stack-3);
}
body[data-portal="public"][data-page="about"] .mv2-info-section li,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section li,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section li,
body[data-portal="public"][data-page="faq"] .mv2-info-section li {
  margin-bottom: 0.4em;
}
body[data-portal="public"][data-page="about"] .mv2-info-section li::marker,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section li::marker,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section li::marker,
body[data-portal="public"][data-page="faq"] .mv2-info-section li::marker {
  color: var(--mv2-gold);
}
body[data-portal="public"][data-page="about"] .mv2-info-section a,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section a,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section a,
body[data-portal="public"][data-page="faq"] .mv2-info-section a {
  color: var(--mv2-brand-dark);
  text-decoration: underline;
  text-decoration-color: rgba(0, 106, 255, 0.35);
  text-underline-offset: 3px;
  transition: text-decoration-color var(--mv2-dur) var(--mv2-ease);
}
body[data-portal="public"][data-page="about"] .mv2-info-section a:hover, .mv2-info-section a:focus-visible,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section a:hover, .mv2-info-section a:focus-visible,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section a:hover, .mv2-info-section a:focus-visible,
body[data-portal="public"][data-page="faq"] .mv2-info-section a:hover, .mv2-info-section a:focus-visible {
  text-decoration-color: var(--mv2-brand-dark);
  outline: none;
}
body[data-portal="public"][data-page="about"] .mv2-info-section strong,
body[data-portal="public"][data-page="how-to-apply"] .mv2-info-section strong,
body[data-portal="public"][data-page="how-it-works"] .mv2-info-section strong,
body[data-portal="public"][data-page="faq"] .mv2-info-section strong {
  font-weight: 600;
  color: var(--mv2-ink);
}
/* ╚══════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase 9.11 — Shared nav + footer mv2 refresh                       ║
   ║  Added: 2026-04-26 (DESIGN_EXTENSION_PLAN.md §9.11, agent_issues #41)║
   ║                                                                      ║
   ║  Both components hydrated by /js/components.js into every public     ║
   ║  page. CSS scoped to [data-portal="public"] so admin / landlord      ║
   ║  / tenant portals are unaffected.                                    ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* ── Main desktop nav ──────────────────────────────────────────── */
[data-portal="public"] .mv2-nav {
  background: rgba(255, 254, 251, 0.94);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--mv2-hairline);
}
[data-portal="public"] .mv2-nav-inner {
  align-items: center;
}
[data-portal="public"] .mv2-nav-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--mv2-ink);
}
[data-portal="public"] .mv2-nav-logo-name {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 500;
  font-size: 1.15rem;
  line-height: 1.05;
  letter-spacing: -0.005em;
  color: var(--mv2-ink);
}
[data-portal="public"] .mv2-nav-logo-tagline {
  font-family: var(--mv2-body);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mv2-muted-2);
  margin-top: 1px;
}

/* ── Desktop nav links ─────────────────────────────────────────── */
[data-portal="public"] .mv2-nav-links {
  display: flex;
  align-items: center;
  gap: 4px;
}
[data-portal="public"] .mv2-nav-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: var(--mv2-r-sm);
  color: var(--mv2-ink);
  text-decoration: none;
  font-size: 0.92rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  transition: background var(--mv2-dur) var(--mv2-ease),
              color var(--mv2-dur) var(--mv2-ease);
}
[data-portal="public"] .mv2-nav-link:hover,
[data-portal="public"] .mv2-nav-link:focus-visible {
  background: rgba(0, 106, 255, 0.06);
  color: var(--mv2-brand-dark);
  outline: none;
}
[data-portal="public"] .mv2-nav-link.active::after {
  content: "";
  position: absolute;
  left: 14px; right: 14px; bottom: 2px;
  height: 2px;
  background: var(--mv2-gold);
  border-radius: 2px;
}
[data-portal="public"] .mv2-nav-link--landlord {
  background: rgba(212, 160, 23, 0.10);
  color: #5A4416;
  font-weight: 600;
}
[data-portal="public"] .mv2-nav-link--landlord:hover,
[data-portal="public"] .mv2-nav-link--landlord:focus-visible {
  background: rgba(212, 160, 23, 0.18);
  color: #4A3812;
}

/* ── Mobile drawer ─────────────────────────────────────────────── */
[data-portal="public"] .mv2-nav-drawer {
  background: #FFFEFB;
}
[data-portal="public"] .mv2-nav-drawer-header {
  border-bottom: 1px solid var(--mv2-hairline);
  padding-bottom: 14px;
}
[data-portal="public"] .mv2-nav-drawer-link {
  border-radius: var(--mv2-r-sm);
  font-weight: 500;
  transition: background var(--mv2-dur) var(--mv2-ease),
              color var(--mv2-dur) var(--mv2-ease);
}
[data-portal="public"] .mv2-nav-drawer-link:hover,
[data-portal="public"] .mv2-nav-drawer-link:focus-visible {
  background: rgba(0, 106, 255, 0.06);
  color: var(--mv2-brand-dark);
  outline: none;
}
[data-portal="public"] .mv2-nav-drawer-link.active {
  background: rgba(212, 160, 23, 0.12);
  color: #5A4416;
}
[data-portal="public"] .mv2-nav-drawer-link i {
  color: var(--mv2-gold);
}

/* ── Footer ─────────────────────────────────────────────────────── */
[data-portal="public"] .mv2-footer {
  background: var(--mv2-bg-warm);
  border-top: 1px solid var(--mv2-hairline);
  padding: clamp(48px, 7vw, 80px) 0 clamp(28px, 3vw, 40px);
  position: relative;
}
[data-portal="public"] .mv2-footer::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(212, 160, 23, 0.30) 50%,
    transparent 100%);
}
[data-portal="public"] .mv2-footer-logo-text {
  font-family: var(--mv2-display);
  font-style: normal;
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: -0.005em;
  color: var(--mv2-ink);
}
[data-portal="public"] .mv2-footer-desc {
  color: var(--mv2-muted);
  font-size: 0.92rem;
  line-height: 1.6;
  max-width: 32ch;
  margin: 12px 0 16px;
}
[data-portal="public"] .mv2-footer-col-title {
  font-family: var(--mv2-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--mv2-muted-2);
  margin-bottom: 14px;
}
[data-portal="public"] .mv2-footer-link {
  display: block;
  color: var(--mv2-ink);
  text-decoration: none;
  font-size: 0.92rem;
  padding: 4px 0;
  transition: color var(--mv2-dur) var(--mv2-ease);
}
[data-portal="public"] .mv2-footer-link:hover,
[data-portal="public"] .mv2-footer-link:focus-visible {
  color: var(--mv2-brand-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
  outline: none;
}
[data-portal="public"] .mv2-footer-bottom {
  border-top: 1px solid var(--mv2-hairline);
  margin-top: clamp(36px, 5vw, 56px);
  padding-top: 22px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px;
  font-size: 0.82rem;
  color: var(--mv2-muted-2);
}
[data-portal="public"] .mv2-footer-eq i {
  color: var(--mv2-gold);
  margin-right: 4px;
}
[data-portal="public"] .mv2-footer-bottom-links {
  margin-left: auto;
  display: flex;
  gap: 18px;
}
[data-portal="public"] .mv2-footer-bottom-links a {
  color: var(--mv2-muted);
  text-decoration: none;
  transition: color var(--mv2-dur) var(--mv2-ease);
}
[data-portal="public"] .mv2-footer-bottom-links a:hover,
[data-portal="public"] .mv2-footer-bottom-links a:focus-visible {
  color: var(--mv2-brand-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
  outline: none;
}
@media (max-width: 600px) {
  [data-portal="public"] .mv2-footer-bottom-links {
    margin-left: 0;
    flex-basis: 100%;
  }
}
/* ╚══════════════════════════════════════════════════════════════════╝ */

/* ╔══════════════════════════════════════════════════════════════════╗
   ║ Policy / legal page chrome — breadcrumb + sticky side TOC        ║
   ║ Used by: policies, privacy, terms, fair-housing, *-policy pages  ║
   ╚══════════════════════════════════════════════════════════════════╝ */

[data-portal="public"] .policy-breadcrumb {
  font-size: 0.85rem;
  color: var(--m-muted);
  padding: 14px 0 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  font-family: 'Inter', system-ui, sans-serif;
}
[data-portal="public"] .policy-breadcrumb a {
  color: var(--m-muted);
  text-decoration: none;
  transition: color .18s ease;
}
[data-portal="public"] .policy-breadcrumb a:hover,
[data-portal="public"] .policy-breadcrumb a:focus-visible {
  color: var(--m-brand);
  text-decoration: underline;
  text-underline-offset: 3px;
  outline: none;
}
[data-portal="public"] .policy-breadcrumb .sep {
  color: var(--m-soft);
  user-select: none;
}
[data-portal="public"] .policy-breadcrumb [aria-current="page"] {
  color: var(--m-text);
  font-weight: 600;
}

/* Sticky right-side TOC, only on wide screens. Built dynamically by
   /js/policy-toc.js — pages that already include their own .policy-toc
   block are skipped by the script. */
[data-portal="public"] .policy-toc-side {
  position: fixed;
  top: 110px;
  right: max(20px, calc((100vw - 1180px) / 2 - 220px));
  width: 220px;
  max-height: calc(100vh - 160px);
  overflow-y: auto;
  padding: 16px 18px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(15,23,42,.06);
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 0.82rem;
  z-index: 5;
}
[data-portal="public"] .policy-toc-side h4 {
  margin: 0 0 10px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--m-muted);
  font-weight: 700;
}
[data-portal="public"] .policy-toc-side ol {
  list-style: none;
  margin: 0; padding: 0;
  counter-reset: policy-toc-counter;
}
[data-portal="public"] .policy-toc-side li {
  counter-increment: policy-toc-counter;
  margin: 0 0 4px;
  line-height: 1.4;
}
[data-portal="public"] .policy-toc-side a {
  color: var(--m-muted);
  text-decoration: none;
  display: block;
  padding: 5px 8px 5px 26px;
  border-radius: 6px;
  position: relative;
  transition: background .15s ease, color .15s ease;
}
[data-portal="public"] .policy-toc-side a::before {
  content: counter(policy-toc-counter);
  position: absolute;
  left: 6px; top: 5px;
  font-size: 10px;
  color: var(--m-soft);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}
[data-portal="public"] .policy-toc-side a:hover {
  background: var(--m-brand-pale);
  color: var(--m-brand-dark);
}
[data-portal="public"] .policy-toc-side a.is-active {
  background: var(--m-brand-pale);
  color: var(--m-brand-dark);
  font-weight: 600;
}
[data-portal="public"] .policy-toc-side a.is-active::before {
  color: var(--m-brand);
}
@media (max-width: 1280px) {
  [data-portal="public"] .policy-toc-side { display: none; }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase L1 — Living Hero (Ken Burns + live activity chip)            ║
   ║  Added: BATCH_01 of IMPLEMENTATION_PLAN.md                          ║
   ║  Scope: home page only (body[data-page="home"])                     ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* ── Slow Ken Burns drift on the hero photo ──────────────────────────── */
@keyframes mv2-kenburns {
  0%   { transform: scale(1.06) translate3d(0, 0, 0); }
  50%  { transform: scale(1.14) translate3d(-1.5%, -1.2%, 0); }
  100% { transform: scale(1.06) translate3d(0, 0, 0); }
}
body[data-portal="public"][data-page="home"] .mv2-hero__bg-img {
  animation: mv2-kenburns 28s ease-in-out infinite;
  will-change: transform;
  transform-origin: center 35%;
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-hero__bg-img {
    animation: none;
  }
}

/* ── Live activity chip ─────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-hero__live {
  margin-top: 18px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px 8px 12px;
  background: rgba(10, 23, 41, 0.42);
  border: 1px solid rgba(255, 255, 255, 0.18);
  backdrop-filter: saturate(160%) blur(8px);
  -webkit-backdrop-filter: saturate(160%) blur(8px);
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.96);
  font-size: 0.88rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  max-width: min(100%, 460px);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 600ms ease, transform 600ms ease;
}
body[data-portal="public"][data-page="home"] .mv2-hero__live[data-ready="true"] {
  opacity: 1;
  transform: translateY(0);
}
body[data-portal="public"][data-page="home"] .mv2-hero__live-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(183, 241, 198, 0.18);
  color: #B7F1C6;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  flex-shrink: 0;
}
body[data-portal="public"][data-page="home"] .mv2-hero__live-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #B7F1C6;
  box-shadow: 0 0 0 0 rgba(183, 241, 198, 0.7);
  animation: mv2-pulse 2.4s ease-out infinite;
  display: inline-block;
}
body[data-portal="public"][data-page="home"] .mv2-hero__live-text {
  display: inline-block;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  opacity: 1;
  transition: opacity 350ms ease;
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-hero__live-dot { animation: none; }
  body[data-portal="public"][data-page="home"] .mv2-hero__live { transition: none; }
  body[data-portal="public"][data-page="home"] .mv2-hero__live-text { transition: none; }
}
@media (max-width: 768px) {
  body[data-portal="public"][data-page="home"] .mv2-hero__live {
    margin-top: 14px;
    font-size: 0.82rem;
    padding: 7px 12px 7px 10px;
    gap: 8px;
  }
  body[data-portal="public"][data-page="home"] .mv2-hero__live-label {
    font-size: 0.66rem;
    padding: 2px 6px;
  }
}
/* ╚══════════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase L2 — Mobile sticky search pill + full-screen sheet           ║
   ║  Added: BATCH_02 of IMPLEMENTATION_PLAN.md                          ║
   ║  Scope: home page on viewports ≤768px only                          ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* ── Sticky search pill (mobile only) ───────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-msearch-pill {
  display: none;
  position: fixed;
  top: max(8px, env(safe-area-inset-top, 8px));
  left: 12px;
  right: 12px;
  z-index: 1100;                                /* above #site-nav */
  align-items: center;
  gap: 12px;
  padding: 12px 16px 12px 18px;
  min-height: 52px;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  border: 1px solid rgba(10, 23, 41, 0.08);
  border-radius: 999px;
  box-shadow: 0 12px 36px rgba(10, 23, 41, 0.18), 0 2px 6px rgba(10, 23, 41, 0.10);
  color: var(--mv2-ink, #1f2937);
  font-family: inherit;
  font-size: 0.96rem;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  opacity: 0;
  transform: translateY(-12px);
  transition: opacity 240ms ease, transform 240ms ease;
  pointer-events: none;
  width: auto;
}
@media (max-width: 768px) {
  body[data-portal="public"][data-page="home"] .mv2-msearch-pill {
    display: inline-flex;
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-pill[data-visible="true"] {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
}
body[data-portal="public"][data-page="home"] .mv2-msearch-pill__icon {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--mv2-brand, #006AFF);
  color: #fff;
  font-size: 13px;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-pill__text {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: rgba(31, 41, 55, 0.78);
}
body[data-portal="public"][data-page="home"] .mv2-msearch-pill__filters {
  flex-shrink: 0;
  font-size: 12px;
  color: var(--mv2-muted-2, #6B7280);
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-msearch-pill { transition: none; }
}

/* ── Backdrop ───────────────────────────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1190;
  background: rgba(10, 23, 41, 0.45);
  opacity: 0;
  transition: opacity 220ms ease;
}
@media (max-width: 768px) {
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet-backdrop {
    display: block;
    pointer-events: none;
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet-backdrop[data-open="true"] {
    opacity: 1;
    pointer-events: auto;
  }
}

/* ── Full-screen sheet (slides down from top) ──────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1200;
  background: #FFFFFF;
  border-radius: 0 0 24px 24px;
  box-shadow: 0 24px 60px rgba(10, 23, 41, 0.22);
  padding: max(8px, env(safe-area-inset-top, 8px)) 16px 22px;
  transform: translateY(-110%);
  transition: transform 320ms cubic-bezier(0.32, 0.72, 0.16, 1);
  max-height: 100dvh;
  overflow-y: auto;
}
@media (max-width: 768px) {
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet {
    display: block;
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet[data-open="true"] {
    transform: translateY(0);
  }
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet { transition: none; }
}

body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__handle {
  width: 44px;
  height: 5px;
  border-radius: 999px;
  background: rgba(10, 23, 41, 0.14);
  margin: 8px auto 14px;
  cursor: grab;
  touch-action: none;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 4px 14px;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__title {
  font-family: "Fraunces", "Inter", serif;
  font-style: normal;
  font-weight: 600;
  font-size: 1.35rem;
  color: var(--mv2-ink, #1f2937);
  margin: 0;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__close {
  appearance: none;
  border: 0;
  background: rgba(10, 23, 41, 0.06);
  color: var(--mv2-ink, #1f2937);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 16px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__form {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 0 2px;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__field {
  position: relative;
  display: flex;
  align-items: center;
  background: var(--mv2-bg-warm, #FAF8F5);
  border: 1px solid var(--mv2-hairline, #E5E7EB);
  border-radius: var(--mv2-r-md, 12px);
  min-height: 56px;
  padding: 0 16px 0 46px;
  transition: border-color 200ms ease, background 200ms ease;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__field:focus-within {
  border-color: var(--mv2-brand, #006AFF);
  background: #FFFFFF;
  box-shadow: 0 0 0 3px rgba(0, 106, 255, 0.10);
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__field > i {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--mv2-muted-2, #6B7280);
  font-size: 15px;
  pointer-events: none;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__field input,
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__field select {
  flex: 1;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 1rem;
  color: var(--mv2-ink, #1f2937);
  outline: none;
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__field select {
  padding-right: 22px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path fill='%236B7280' d='M6 8L2 4h8z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 0 center;
  cursor: pointer;
}
body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__submit {
  margin-top: 6px;
  min-height: 56px;
  border-radius: var(--mv2-r-md, 12px);
  font-weight: 600;
  font-size: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
/* ╚══════════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase L3 — Featured listings: horizontal snap-scroll on mobile     ║
   ║  Added: BATCH_03 of IMPLEMENTATION_PLAN.md                          ║
   ║  Scope: home page, .featured-section .property-grid only            ║
   ║  Desktop layout (≥541px) is unchanged.                              ║
   ╚══════════════════════════════════════════════════════════════════════╝ */
@media (max-width: 540px) {
  body[data-portal="public"][data-page="home"] .featured-section .property-grid {
    display: flex;
    grid-template-columns: none;
    overflow-x: auto;
    overflow-y: hidden;
    gap: 12px;
    padding: 4px 4px 14px;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: 4px;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    /* Bleed slightly past the .container padding so cards reach the edge */
    margin-inline: calc(var(--m-s-4, 16px) * -1);
    padding-inline: var(--m-s-4, 16px);
    scroll-padding-left: var(--m-s-4, 16px);
    /* Hide scrollbar but keep functionality */
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  body[data-portal="public"][data-page="home"] .featured-section .property-grid::-webkit-scrollbar {
    display: none;
  }
  body[data-portal="public"][data-page="home"] .featured-section .property-grid > .property-card {
    flex: 0 0 78vw;
    max-width: 320px;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    /* Override the entrance translate so cards always render visible
       in the rail (the IntersectionObserver-driven cp-card-visible
       trigger may not fire reliably for off-screen rail cards). */
    opacity: 1;
    transform: none;
  }
  /* Subtle right-edge fade hint that there's more to scroll */
  body[data-portal="public"][data-page="home"] .featured-section .mv2-featured__container,
  body[data-portal="public"][data-page="home"] .featured-section .container {
    position: relative;
  }
}
@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .featured-section .property-grid {
    scroll-behavior: auto;
  }
}
/* ╚══════════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase L4 — Save-without-signup nudge + heart pulse (BATCH_04)      ║
   ║  Scope: global (works on home, listings, property pages)            ║
   ╚══════════════════════════════════════════════════════════════════════╝ */
@keyframes cp-heart-pulse {
  0%   { transform: scale(1); }
  35%  { transform: scale(1.28); }
  60%  { transform: scale(0.94); }
  100% { transform: scale(1); }
}
.cp-heart-pulse { animation: cp-heart-pulse 600ms cubic-bezier(.22,1,.36,1); }
@media (prefers-reduced-motion: reduce) {
  .cp-heart-pulse { animation: none; }
}

.cp-saved-nudge {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: calc(16px + env(safe-area-inset-bottom, 0px));
  z-index: 10050;
  pointer-events: none;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 280ms cubic-bezier(.22,1,.36,1),
              transform 280ms cubic-bezier(.22,1,.36,1);
  display: flex;
  justify-content: center;
}
.cp-saved-nudge--in { opacity: 1; transform: translateY(0); }

.cp-saved-nudge__inner {
  pointer-events: auto;
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: 420px;
  padding: 12px 12px 12px 14px;
  background: #ffffff;
  color: #1f2937;
  border: 1px solid rgba(15,23,42,0.08);
  border-radius: 14px;
  box-shadow:
    0 12px 32px -8px rgba(15,23,42,0.18),
    0 4px 12px -4px rgba(15,23,42,0.10);
}
.cp-saved-nudge__icon {
  flex: 0 0 36px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #fee2e2;
  color: #e11d48;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}
.cp-saved-nudge__text {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  font-size: 13px;
  line-height: 1.35;
}
.cp-saved-nudge__text strong {
  font-size: 13.5px;
  font-weight: 600;
  color: #0f172a;
}
.cp-saved-nudge__text span {
  color: #475569;
  font-size: 12px;
}
.cp-saved-nudge__cta {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  height: 34px;
  padding: 0 14px;
  border-radius: 9px;
  background: #006aff;
  color: #fff !important;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: background 180ms ease, transform 180ms ease;
}
.cp-saved-nudge__cta:hover { background: #0056d6; }
.cp-saved-nudge__cta:active { transform: scale(0.97); }
.cp-saved-nudge__close {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: transparent;
  border: none;
  color: #64748b;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background 180ms ease, color 180ms ease;
}
.cp-saved-nudge__close:hover { background: #f1f5f9; color: #0f172a; }

/* Lift above the bottom mobile CTA bar if it's present */
body:has(#mobile-cta) .cp-saved-nudge {
  bottom: calc(80px + env(safe-area-inset-bottom, 0px));
}

@media (min-width: 720px) {
  .cp-saved-nudge {
    left: auto;
    right: 24px;
    bottom: 24px;
    justify-content: flex-end;
  }
  .cp-saved-nudge__inner { width: 380px; }
  body:has(#mobile-cta) .cp-saved-nudge { bottom: 24px; }
}

@media (prefers-reduced-motion: reduce) {
  .cp-saved-nudge { transition: opacity 1ms; transform: none; }
}
/* ╚══════════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase L5 — Editorial typography pass (BATCH_05)                    ║
   ║  Scope: body[data-portal="public"][data-page="home"]                ║
   ║                                                                     ║
   ║  Now that the Fraunces upright axis is loaded, display headlines    ║
   ║  actually render in Fraunces (previously fell back to Georgia).     ║
   ║  This block tightens tracking, sets optical sizing, refines         ║
   ║  eyebrows toward an "editorial / architectural" register.           ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* ── Display headlines: real Fraunces with proper optical sizing ──── */
body[data-portal="public"][data-page="home"] .mv2-headline,
body[data-portal="public"][data-page="home"] .featured-title,
body[data-portal="public"][data-page="home"] h2.mv2-headline--md {
  font-family: 'Fraunces', 'Georgia', 'Times New Roman', serif;
  font-optical-sizing: auto;
  font-variation-settings: 'opsz' 96, 'SOFT' 50;
  letter-spacing: -0.022em;
  line-height: 1.05;
  text-wrap: balance;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* The featured section headline was Inter 800 — promote to Fraunces 500
   to unify the editorial voice. Slightly larger to earn the lighter weight. */
body[data-portal="public"][data-page="home"] .featured-title {
  font-weight: 500;
  font-size: clamp(28px, 3.2vw, 44px);
  line-height: 1.08;
  margin-bottom: 6px;
}

/* Gold accent words in home headlines — bold Fraunces + gold underline. */
body[data-portal="public"][data-page="home"] .mv2-headline em,
body[data-portal="public"][data-page="home"] .featured-title em {
  font-style: normal;
  font-weight: 700;
  font-variation-settings: 'opsz' 96, 'SOFT' 50, 'WONK' 0;
  letter-spacing: -0.015em;
  color: var(--mv2-gold);
  text-decoration: underline;
  text-decoration-color: rgba(212, 160, 23, 0.40);
  text-underline-offset: 5px;
  text-decoration-thickness: 2px;
}

/* ── Eyebrows: more tracking + slightly heavier; signals "editorial" ── */
body[data-portal="public"][data-page="home"] .mv2-eyebrow {
  font-weight: 600;
  letter-spacing: 0.18em;
  font-size: 0.72rem;
  font-feature-settings: 'tnum' 1;
}
/* The decorative rule before the eyebrow — extend & soften */
body[data-portal="public"][data-page="home"] .mv2-eyebrow::before {
  width: 24px;
  opacity: 0.85;
}

/* ── Lede: more reading rhythm ───────────────────────────────────── */
body[data-portal="public"][data-page="home"] .mv2-lede {
  line-height: 1.55;
  letter-spacing: -0.001em;
  max-width: 56ch;
}

/* ── Section subtitles (under section headlines) — softer color, italic
   small-caps tracking is too much; just tighten the lede-style tone. */
body[data-portal="public"][data-page="home"] .featured-subtitle {
  font-size: 15px;
  line-height: 1.5;
  color: var(--m-muted-2);
  letter-spacing: -0.001em;
}

/* ── Mobile: pull headline size down a touch so the editorial face
   reads as confident rather than cramped at small widths. */
@media (max-width: 540px) {
  body[data-portal="public"][data-page="home"] .mv2-hero .mv2-headline {
    font-size: clamp(2rem, 7vw, 2.5rem);
    letter-spacing: -0.024em;
  }
  body[data-portal="public"][data-page="home"] .featured-title {
    font-size: clamp(26px, 6.5vw, 32px);
  }
  body[data-portal="public"][data-page="home"] .mv2-eyebrow {
    font-size: 0.68rem;
    letter-spacing: 0.16em;
  }
}
/* ╚══════════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase L6 — Backdrop-blur sticky nav refinement (BATCH_06)          ║
   ║  Scope: body[data-portal="public"][data-page="home"]                ║
   ║                                                                     ║
   ║  Two-state sticky nav: at the very top the nav is more transparent  ║
   ║  so the hero photo subtly bleeds through; once the user starts to   ║
   ║  scroll, the nav frosts up, gains a hairline, and lifts with a soft ║
   ║  shadow. iOS "scroll edge" feel.                                    ║
   ║  Body attribute toggled by /js/cp-scroll-nav.js.                    ║
   ╚══════════════════════════════════════════════════════════════════════╝ */
body[data-portal="public"][data-page="home"] .mv2-nav,
body[data-portal="public"][data-page="home"] .nav {
  transition:
    background-color 280ms cubic-bezier(.22,1,.36,1),
    border-bottom-color 280ms cubic-bezier(.22,1,.36,1),
    box-shadow 280ms cubic-bezier(.22,1,.36,1),
    -webkit-backdrop-filter 280ms cubic-bezier(.22,1,.36,1),
    backdrop-filter 280ms cubic-bezier(.22,1,.36,1);
  will-change: background-color;
}

/* ── Default (no JS yet / pre-toggle) — same as scrolled, safe contrast */
body[data-portal="public"][data-page="home"]:not([data-mv2-scrolled]) .mv2-nav,
body[data-portal="public"][data-page="home"]:not([data-mv2-scrolled]) .nav {
  background: rgba(255, 254, 251, 0.94);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  backdrop-filter: saturate(180%) blur(14px);
}

/* ── Top state: at-rest over the hero photo ─────────────────────── */
body[data-portal="public"][data-page="home"][data-mv2-scrolled="false"] .mv2-nav,
body[data-portal="public"][data-page="home"][data-mv2-scrolled="false"] .nav {
  background: rgba(255, 254, 251, 0.78);
  -webkit-backdrop-filter: saturate(160%) blur(10px);
  backdrop-filter: saturate(160%) blur(10px);
  border-bottom-color: transparent;
  box-shadow: none;
}

/* ── Scrolled state: lifted, fully frosted, hairline visible ──── */
body[data-portal="public"][data-page="home"][data-mv2-scrolled="true"] .mv2-nav,
body[data-portal="public"][data-page="home"][data-mv2-scrolled="true"] .nav {
  background: rgba(255, 254, 251, 0.96);
  -webkit-backdrop-filter: saturate(190%) blur(16px);
  backdrop-filter: saturate(190%) blur(16px);
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow:
    0 1px 0 rgba(0, 0, 0, 0.02),
    0 6px 18px -12px rgba(0, 0, 0, 0.10);
}

@media (prefers-reduced-motion: reduce) {
  body[data-portal="public"][data-page="home"] .mv2-nav,
  body[data-portal="public"][data-page="home"] .nav {
    transition: none;
  }
}
/* ╚══════════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase L7 — Warm dark mode (BATCH_07)                               ║
   ║  Scope: body[data-portal="public"][data-page="home"]                ║
   ║                                                                     ║
   ║  Activates only when the OS reports prefers-color-scheme: dark.     ║
   ║  No user toggle yet — pure system-preference response.              ║
   ║  Warm dark (mahogany / espresso) — never pure black — to keep the   ║
   ║  editorial / architectural feel. Brand blue + gold preserved as     ║
   ║  accent moments. Hero (photo + dark overlay) needs no changes.      ║
   ╚══════════════════════════════════════════════════════════════════════╝ */
@media (prefers-color-scheme: dark) {

  /* ── Token redefinition (both --m-* and --mv2-* token systems) ─── */
  body[data-portal="public"][data-page="home"] {
    color-scheme: dark;
    /* legacy --m-* */
    --m-bg:             #0e0c08;
    --m-white:          #181410;
    --m-surface:        #1f1812;
    --m-surface-2:      #2a221b;
    --m-border:         #2e261c;
    --m-border-strong:  #3d3324;
    --m-ink:            #f5f1e8;
    --m-ink-2:          #e7e0d2;
    --m-text:           #e0d8c8;
    --m-muted:          #b8aea0;
    --m-muted-2:        #9b9183;
    --m-soft:           #6e6759;
    --m-brand-pale:     #102239;     /* deep ink-blue swap */
    --m-gold-pale:      #2a221b;
    --m-shadow-sm:      0 1px 2px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.30);
    --m-shadow-md:      0 6px 16px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.30);
    --m-shadow-lg:      0 18px 40px rgba(0,0,0,.55), 0 6px 14px rgba(0,0,0,.32);
    /* modern --mv2-* */
    --mv2-bg-warm:        #0e0c08;
    --mv2-bg-warm-2:      #1a1610;
    --mv2-ink:            #f5f1e8;
    --mv2-ink-2:          #e7e0d2;
    --mv2-muted:          #b8aea0;
    --mv2-muted-2:        #9b9183;
    --mv2-hairline:       #2e261c;
    --mv2-hairline-strong:#3d3324;
    --mv2-accent:         #f4d27a;
    --mv2-accent-pale:    #2a221b;
    --mv2-accent-strong:  #f4d27a;
    --mv2-shadow-hairline:0 0 0 1px var(--mv2-hairline);
    --mv2-shadow-soft:    0 1px 2px rgba(0,0,0,.50), 0 8px 24px rgba(0,0,0,.45);
    --mv2-shadow-lift:    0 2px 4px rgba(0,0,0,.55), 0 18px 40px rgba(0,0,0,.55);
    --mv2-overlay-ink:    rgba(0, 0, 0, 0.62);
  }

  /* Page background */
  body[data-portal="public"][data-page="home"] {
    background: #0e0c08;
    color: #f5f1e8;
  }

  /* ── Property card image placeholder — slightly lighter than card */
  body[data-portal="public"][data-page="home"] .property-card-img {
    background: #2a221b;
  }
  /* Save/share buttons on cards — light frosted on dark */
  body[data-portal="public"][data-page="home"] .property-card-save,
  body[data-portal="public"][data-page="home"] .property-card-share {
    background: rgba(20, 16, 12, 0.78);
    border-color: rgba(245, 241, 232, 0.20);
    color: #f5f1e8;
  }
  body[data-portal="public"][data-page="home"] .property-card-save:hover,
  body[data-portal="public"][data-page="home"] .property-card-share:hover {
    background: rgba(20, 16, 12, 0.92);
  }
  body[data-portal="public"][data-page="home"] .property-card-save.saved {
    color: #f87171;
  }

  /* ── Nav (overrides Phase L6 frosted bg for dark) ──────────────── */
  body[data-portal="public"][data-page="home"]:not([data-mv2-scrolled]) .mv2-nav,
  body[data-portal="public"][data-page="home"]:not([data-mv2-scrolled]) .nav,
  body[data-portal="public"][data-page="home"][data-mv2-scrolled="true"] .mv2-nav,
  body[data-portal="public"][data-page="home"][data-mv2-scrolled="true"] .nav {
    background: rgba(14, 12, 8, 0.86);
    -webkit-backdrop-filter: saturate(180%) blur(16px);
    backdrop-filter: saturate(180%) blur(16px);
    border-bottom-color: rgba(245, 241, 232, 0.10);
  }
  body[data-portal="public"][data-page="home"][data-mv2-scrolled="false"] .mv2-nav,
  body[data-portal="public"][data-page="home"][data-mv2-scrolled="false"] .nav {
    background: rgba(14, 12, 8, 0.55);
    -webkit-backdrop-filter: saturate(160%) blur(10px);
    backdrop-filter: saturate(160%) blur(10px);
    border-bottom-color: transparent;
  }

  /* Mobile search pill — dark frosted */
  body[data-portal="public"][data-page="home"] .mv2-msearch-pill {
    background: rgba(20, 16, 12, 0.92);
    color: #f5f1e8;
    border-color: rgba(245, 241, 232, 0.10);
    box-shadow: 0 6px 18px -8px rgba(0,0,0,.5);
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-pill__icon {
    color: #b8aea0;
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-pill__filters {
    color: #9b9183;
  }

  /* Mobile search sheet — dark surface */
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet {
    background: #181410;
    color: #f5f1e8;
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__title { color: #f5f1e8; }
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__handle {
    background: rgba(245, 241, 232, 0.20);
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet input,
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet select {
    background: #0e0c08;
    color: #f5f1e8;
    border-color: rgba(245, 241, 232, 0.12);
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet input::placeholder {
    color: #6e6759;
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__close {
    color: #b8aea0;
  }
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__close:hover {
    background: rgba(245, 241, 232, 0.06);
    color: #f5f1e8;
  }

  /* Saved nudge — dark variant */
  body[data-portal="public"][data-page="home"] .cp-saved-nudge__inner {
    background: #181410;
    color: #f5f1e8;
    border-color: rgba(245, 241, 232, 0.10);
    box-shadow:
      0 12px 32px -8px rgba(0,0,0,.55),
      0 4px 12px -4px rgba(0,0,0,.35);
  }
  body[data-portal="public"][data-page="home"] .cp-saved-nudge__icon {
    background: rgba(248, 113, 113, 0.18);
    color: #f87171;
  }
  body[data-portal="public"][data-page="home"] .cp-saved-nudge__text strong { color: #f5f1e8; }
  body[data-portal="public"][data-page="home"] .cp-saved-nudge__text span   { color: #b8aea0; }
  body[data-portal="public"][data-page="home"] .cp-saved-nudge__close       { color: #9b9183; }
  body[data-portal="public"][data-page="home"] .cp-saved-nudge__close:hover {
    background: rgba(245, 241, 232, 0.06);
    color: #f5f1e8;
  }

  /* Live hero chip & lede — keep readable over photo (already photo-dark) */
  body[data-portal="public"][data-page="home"] .mv2-hero__live {
    background: rgba(255, 255, 255, 0.10);
    color: #ffffff;
  }

  /* Skeleton shimmer — darker base */
  body[data-portal="public"][data-page="home"] .property-card.skeleton,
  body[data-portal="public"][data-page="home"] .skeleton-shimmer {
    background: linear-gradient(90deg, #1f1812 25%, #2a221b 50%, #1f1812 75%);
  }

  /* Heart pulse accent fill on dark */
  body[data-portal="public"][data-page="home"] .property-card-save.saved .fa-heart {
    color: #f87171;
  }
}
/* ╚══════════════════════════════════════════════════════════════════════╝ */


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  Phase L8 — Skeleton-screen primitives (BATCH_08)                   ║
   ║                                                                     ║
   ║  Two reusable affordances that replace mechanical spinners site-    ║
   ║  wide with a calmer, type-led shimmer language:                     ║
   ║    • .cp-shimmer-bar  — slim animated horizontal bar (used in       ║
   ║      pull-to-refresh + the "still loading" featured-grid fallback). ║
   ║    • .cp-loading-still — the typographic "Still gathering…" row     ║
   ║      that appears under the featured grid when the fetch is slow.   ║
   ║                                                                     ║
   ║  Honors prefers-reduced-motion (no shimmer translation).            ║
   ║  Dark-mode variants inherit from L7 token redefinition.             ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* Shimmer bar primitive — 3px tall, 240px wide track, 60px traveler */
.cp-shimmer-bar {
  display: inline-block;
  position: relative;
  width: 240px;
  max-width: 60vw;
  height: 3px;
  border-radius: 999px;
  background: rgba(10, 23, 41, 0.06);
  overflow: hidden;
  vertical-align: middle;
}
.cp-shimmer-bar::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 60px;
  border-radius: inherit;
  background: linear-gradient(
    90deg,
    transparent 0%,
    var(--mv2-accent, #d4a017) 50%,
    transparent 100%
  );
  opacity: 0.85;
  animation: cp-shimmer-bar-travel 1.6s cubic-bezier(.4,0,.2,1) infinite;
  will-change: transform;
}
@keyframes cp-shimmer-bar-travel {
  0%   { transform: translateX(-60px); }
  100% { transform: translateX(240px); }
}
@media (prefers-reduced-motion: reduce) {
  .cp-shimmer-bar::after {
    animation: none;
    transform: translateX(90px);  /* park it center-ish */
    opacity: 0.55;
  }
}

/* Pull-to-refresh tweaks — make the bar inline with the label */
.ptr {
  gap: 10px;
}
.ptr .cp-shimmer-bar {
  width: 90px;
  max-width: 90px;
}

/* "Still gathering listings…" row under the featured grid */
.cp-loading-still {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 24px 24px 8px;
  color: var(--mv2-muted, #6b7280);
  font-size: 0.92rem;
  font-family: var(--mv2-font-body, inherit);
  letter-spacing: 0.01em;
  animation: cp-loading-still-fade 240ms ease-out both;
}
.cp-loading-still__text {
  opacity: 0.92;
}
@keyframes cp-loading-still-fade {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .cp-loading-still { animation: none; }
}

/* Dark-mode override for the shimmer track (the traveler picks up
   --mv2-accent which is already lightened in L7). */
@media (prefers-color-scheme: dark) {
  body[data-portal="public"][data-page="home"] .cp-shimmer-bar {
    background: rgba(245, 241, 232, 0.10);
  }
}
/* ╚══════════════════════════════════════════════════════════════════════╝ */


  /* ╔══════════════════════════════════════════════════════════════════════╗
     ║  Featured listings: VERTICAL stack on the homepage (all breakpoints) ║
     ║  Overrides: L1062/L1074/L1077 grid + L5636 mobile horizontal rail.   ║
     ║  Scope: home page only (body[data-page="home"]) → listings.html and  ║
     ║  property.html grids are unaffected.                                 ║
     ╚══════════════════════════════════════════════════════════════════════╝ */
  body[data-portal="public"][data-page="home"] .featured-section .property-grid,
  body[data-portal="public"][data-page="home"] .mv2-featured .property-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--m-s-4, 16px);
    overflow: visible !important;
    overflow-x: visible !important;
    scroll-snap-type: none !important;
    margin-inline: 0 !important;
    padding: 0 !important;
    scroll-padding-inline: 0 !important;
    scroll-padding-left: 0 !important;
  }
  body[data-portal="public"][data-page="home"] .featured-section .property-grid > .property-card,
  body[data-portal="public"][data-page="home"] .mv2-featured .property-grid > .property-card {
    flex: initial !important;
    width: 100% !important;
    max-width: none !important;
    scroll-snap-align: none !important;
    scroll-snap-stop: normal !important;
    opacity: 1;
    transform: none;
  }
  @media (min-width: 540px) {
    body[data-portal="public"][data-page="home"] .featured-section .property-grid,
    body[data-portal="public"][data-page="home"] .mv2-featured .property-grid {
      grid-template-columns: 1fr !important;
      gap: var(--m-s-5, 24px);
    }
    body[data-portal="public"][data-page="home"] .featured-section .property-grid > .property-card,
    body[data-portal="public"][data-page="home"] .mv2-featured .property-grid > .property-card {
      /* Cap card width on wider screens so a single-column stack doesn't
         stretch to ridiculous proportions on desktop. Centered in the column. */
      max-width: 720px !important;
      margin-inline: auto !important;
    }
  }
  /* ╚══════════════════════════════════════════════════════════════════════╝ */

  /* ── Homepage unification (April 29 2026) ─────────────────────────────
     Replaces ad-hoc inline style="" from index.html with tokenized
     utility + skeleton modifier classes. Public homepage stays on the
     marketing token system (--m-*); empty-state, .btn .btn-primary, and
     .why-cta-btn already exist above and use those tokens.
  ─────────────────────────────────────────────────────────────────────── */
  .ta-center { text-align: center; }
  .property-card-body--skeleton { gap: 10px; padding: 20px; }
  

  /* ════════════════════════════════════════════════════════════════════════════ *
   *  PHASE 9.5 — Comprehensive homepage dark theme: explicit toggle + gap fills
   * ────────────────────────────────────────────────────────────────────────────
   *  Triggers below: (a) @media (prefers-color-scheme: dark) and
   *                  (b) html[data-theme="dark"]
   *
   *  The existing @media block earlier in this file remains untouched (provides
   *  baseline OS-level dark mode for nav, hero chip, search pill, cards). This
   *  addendum adds:
   *    1. A complete mirror of that block scoped to html[data-theme="dark"], so
   *       a manual theme toggle works without depending on OS preference.
   *    2. NEW dark-mode rules for previously uncovered sections: cities,
   *       featured-section chrome, how-it-works, testimonials, stats bar,
   *       final-cta, mobile sticky bars, footer, ghost buttons, empty state,
   *       property-card body, trust-block items, why-section.
   *
   *  Most other components already use var(--m-*) / var(--mv2-*) tokens and
   *  auto-adapt via the token redefinition below.
   * ════════════════════════════════════════════════════════════════════════════ */

  /* ─────────────────────────────────────────────────────────────────────────────
     PART 1 — Mirror of existing dark @media block, scoped to html[data-theme="dark"]
     (Token redefinitions + element overrides for nav, search pill/sheet, cards,
     saved-listing nudge, skeletons, etc.)
     ───────────────────────────────────────────────────────────────────────────── */
  

  /* ── Token redefinition (both --m-* and --mv2-* token systems) ─── */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] {
    color-scheme: dark;
    /* legacy --m-* */
    --m-bg:             #0e0c08;
    --m-white:          #181410;
    --m-surface:        #1f1812;
    --m-surface-2:      #2a221b;
    --m-border:         #2e261c;
    --m-border-strong:  #3d3324;
    --m-ink:            #f5f1e8;
    --m-ink-2:          #e7e0d2;
    --m-text:           #e0d8c8;
    --m-muted:          #b8aea0;
    --m-muted-2:        #9b9183;
    --m-soft:           #6e6759;
    --m-brand-pale:     #102239;     /* deep ink-blue swap */
    --m-gold-pale:      #2a221b;
    --m-shadow-sm:      0 1px 2px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.30);
    --m-shadow-md:      0 6px 16px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.30);
    --m-shadow-lg:      0 18px 40px rgba(0,0,0,.55), 0 6px 14px rgba(0,0,0,.32);
    /* modern --mv2-* */
    --mv2-bg-warm:        #0e0c08;
    --mv2-bg-warm-2:      #1a1610;
    --mv2-ink:            #f5f1e8;
    --mv2-ink-2:          #e7e0d2;
    --mv2-muted:          #b8aea0;
    --mv2-muted-2:        #9b9183;
    --mv2-hairline:       #2e261c;
    --mv2-hairline-strong:#3d3324;
    --mv2-accent:         #f4d27a;
    --mv2-accent-pale:    #2a221b;
    --mv2-accent-strong:  #f4d27a;
    --mv2-shadow-hairline:0 0 0 1px var(--mv2-hairline);
    --mv2-shadow-soft:    0 1px 2px rgba(0,0,0,.50), 0 8px 24px rgba(0,0,0,.45);
    --mv2-shadow-lift:    0 2px 4px rgba(0,0,0,.55), 0 18px 40px rgba(0,0,0,.55);
    --mv2-overlay-ink:    rgba(0, 0, 0, 0.62);
  }

  /* Page background */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] {
    background: #0e0c08;
    color: #f5f1e8;
  }

  /* ── Property card image placeholder — slightly lighter than card */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-img {
    background: #2a221b;
  }
  /* Save/share buttons on cards — light frosted on dark */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-save,
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-share {
    background: rgba(20, 16, 12, 0.78);
    border-color: rgba(245, 241, 232, 0.20);
    color: #f5f1e8;
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-save:hover,
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-share:hover {
    background: rgba(20, 16, 12, 0.92);
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-save.saved {
    color: #f87171;
  }

  /* ── Nav (overrides Phase L6 frosted bg for dark) ──────────────── */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"]:not([data-mv2-scrolled]) .mv2-nav,
  html[data-theme="dark"] body[data-portal="public"][data-page="home"]:not([data-mv2-scrolled]) .nav,
  html[data-theme="dark"] body[data-portal="public"][data-page="home"][data-mv2-scrolled="true"] .mv2-nav,
  html[data-theme="dark"] body[data-portal="public"][data-page="home"][data-mv2-scrolled="true"] .nav {
    background: rgba(14, 12, 8, 0.86);
    -webkit-backdrop-filter: saturate(180%) blur(16px);
    backdrop-filter: saturate(180%) blur(16px);
    border-bottom-color: rgba(245, 241, 232, 0.10);
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"][data-mv2-scrolled="false"] .mv2-nav,
  html[data-theme="dark"] body[data-portal="public"][data-page="home"][data-mv2-scrolled="false"] .nav {
    background: rgba(14, 12, 8, 0.55);
    -webkit-backdrop-filter: saturate(160%) blur(10px);
    backdrop-filter: saturate(160%) blur(10px);
    border-bottom-color: transparent;
  }

  /* Mobile search pill — dark frosted */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-pill {
    background: rgba(20, 16, 12, 0.92);
    color: #f5f1e8;
    border-color: rgba(245, 241, 232, 0.10);
    box-shadow: 0 6px 18px -8px rgba(0,0,0,.5);
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-pill__icon {
    color: #b8aea0;
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-pill__filters {
    color: #9b9183;
  }

  /* Mobile search sheet — dark surface */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-sheet {
    background: #181410;
    color: #f5f1e8;
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__title { color: #f5f1e8; }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__handle {
    background: rgba(245, 241, 232, 0.20);
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-sheet input,
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-sheet select {
    background: #0e0c08;
    color: #f5f1e8;
    border-color: rgba(245, 241, 232, 0.12);
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-sheet input::placeholder {
    color: #6e6759;
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__close {
    color: #b8aea0;
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__close:hover {
    background: rgba(245, 241, 232, 0.06);
    color: #f5f1e8;
  }

  /* Saved nudge — dark variant */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .cp-saved-nudge__inner {
    background: #181410;
    color: #f5f1e8;
    border-color: rgba(245, 241, 232, 0.10);
    box-shadow:
      0 12px 32px -8px rgba(0,0,0,.55),
      0 4px 12px -4px rgba(0,0,0,.35);
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .cp-saved-nudge__icon {
    background: rgba(248, 113, 113, 0.18);
    color: #f87171;
  }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .cp-saved-nudge__text strong { color: #f5f1e8; }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .cp-saved-nudge__text span   { color: #b8aea0; }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .cp-saved-nudge__close       { color: #9b9183; }
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .cp-saved-nudge__close:hover {
    background: rgba(245, 241, 232, 0.06);
    color: #f5f1e8;
  }

  /* Live hero chip & lede — keep readable over photo (already photo-dark) */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-hero__live {
    background: rgba(255, 255, 255, 0.10);
    color: #ffffff;
  }

  /* Skeleton shimmer — darker base */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card.skeleton,
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .skeleton-shimmer {
    background: linear-gradient(90deg, #1f1812 25%, #2a221b 50%, #1f1812 75%);
  }

  /* Heart pulse accent fill on dark */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-save.saved .fa-heart {
    color: #f87171;
  }


  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .cp-shimmer-bar {
    background: rgba(245, 241, 232, 0.10);
  }


  /* ─────────────────────────────────────────────────────────────────────────────
     PART 2 — Gap-fill rules for previously uncovered sections, applied under
     html[data-theme="dark"] (explicit toggle).
     ───────────────────────────────────────────────────────────────────────────── */
  html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-hero__search-field:focus-within {
  background: rgba(24, 20, 16, 0.96) !important; box-shadow: 0 0 0 3px rgba(244, 210, 122, 0.20);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__header {
  border-bottom-color: rgba(245, 241, 232, 0.10);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .trust-strip {
  background: var(--m-surface); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .trust-strip__item {
  color: var(--m-muted); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-cities {
  background: var(--m-bg);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-cities__pill:hover,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-cities__pill:focus-visible {
  background: var(--m-surface); border-color: var(--mv2-accent); color: var(--mv2-accent); box-shadow: 0 6px 18px rgba(0,0,0,.45);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-cities__pill:hover .mv2-cities__icon,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-cities__pill:focus-visible .mv2-cities__icon {
  background: rgba(244, 210, 122, 0.12); color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-hiw {
  background: var(--m-bg);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-hiw__bubble {
  background: var(--m-surface); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-hiw__bubble.is-active,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-hiw__step.is-active .mv2-hiw__bubble {
  background: var(--mv2-accent); border-color: var(--mv2-accent); color: #1a1610; box-shadow: 0 8px 24px rgba(244, 210, 122, 0.28);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-testimonials {
  background: var(--m-bg);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-testimonial {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-testimonial:hover {
  border-color: rgba(244, 210, 122, 0.30); box-shadow: 0 6px 24px rgba(0, 0, 0, 0.45);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-testimonial__quote {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-testimonial__name {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-testimonial__role {
  color: var(--m-muted);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-avatar {
  color: var(--mv2-accent); background: rgba(244, 210, 122, 0.16); border-color: rgba(244, 210, 122, 0.28);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .stats-bar {
  background: linear-gradient(180deg, var(--m-surface) 0%, var(--m-surface-2) 100%); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .stats-bar .stat-value,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .stats-bar .stat-number {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .stats-bar .stat-label {
  color: var(--m-muted);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-finalcta__bg {
  background: radial-gradient(ellipse at top, rgba(244, 210, 122, 0.12) 0%, transparent 55%), radial-gradient(ellipse at bottom right, rgba(0, 106, 255, 0.10) 0%, transparent 60%), linear-gradient(180deg, var(--m-bg) 0%, #1a1610 100%);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mobile-cta-bar {
  background: rgba(20, 16, 12, 0.92); border-top-color: rgba(245, 241, 232, 0.10); box-shadow: 0 -6px 18px rgba(0, 0, 0, 0.45);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mobile-cta-bar .mcta-ghost {
  background: var(--m-surface-2); color: var(--m-ink); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-mcta {
  background: rgba(20, 16, 12, 0.92); border-top-color: rgba(245, 241, 232, 0.10); box-shadow: 0 -6px 24px rgba(0, 0, 0, 0.45);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .footer {
  background: #0a0806; color: rgba(245, 241, 232, 0.72);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .footer a,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .footer .footer-link,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-footer a,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-footer .mv2-footer-link {
  color: rgba(245, 241, 232, 0.72);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .footer a:hover,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .footer .footer-link:hover,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-footer a:hover,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-footer .mv2-footer-link:hover {
  color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .footer .footer-col-title,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-footer .mv2-footer-col-title,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .footer-col-title,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-footer-col-title {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .footer .footer-bottom,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-footer .mv2-footer-bottom {
  border-top-color: rgba(245, 241, 232, 0.10);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-btn--ghost:hover,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-btn--ghost:focus-visible {
  background: var(--m-surface); border-color: var(--mv2-accent); color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-featured__cta a,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-featured__cta .btn-secondary {
  color: var(--mv2-accent); border-color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-trustblock__item {
  background: var(--m-surface); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .mv2-trustblock__icon {
  background: rgba(244, 210, 122, 0.12); color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .empty-state-icon {
  background: rgba(244, 210, 122, 0.10); border-color: rgba(244, 210, 122, 0.22); color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-body {
  background: transparent; color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-features,
html[data-theme="dark"] body[data-portal="public"][data-page="home"] .property-card-features li {
  color: var(--m-muted);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .why-section {
  background: linear-gradient(180deg, #0a0806 0%, #181410 100%);
}

html[data-theme="dark"] body[data-portal="public"][data-page="home"] .section-eyebrow {
  background: rgba(0, 106, 255, 0.16); color: #4d9aff;
}

  /* ─────────────────────────────────────────────────────────────────────────────
     PART 3 — Same gap-fill rules under @media (prefers-color-scheme: dark) so
     visitors with OS-level dark mode see them too.
     ───────────────────────────────────────────────────────────────────────────── */
  @media (prefers-color-scheme: dark) {
    body[data-portal="public"][data-page="home"] .mv2-hero__search-field:focus-within {
    background: rgba(24, 20, 16, 0.96) !important; box-shadow: 0 0 0 3px rgba(244, 210, 122, 0.20);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-msearch-sheet__header {
    border-bottom-color: rgba(245, 241, 232, 0.10);
  }
  
  body[data-portal="public"][data-page="home"] .trust-strip {
    background: var(--m-surface); border-color: var(--m-border);
  }
  
  body[data-portal="public"][data-page="home"] .trust-strip__item {
    color: var(--m-muted); border-color: var(--m-border);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-cities {
    background: var(--m-bg);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-cities__pill:hover,
  body[data-portal="public"][data-page="home"] .mv2-cities__pill:focus-visible {
    background: var(--m-surface); border-color: var(--mv2-accent); color: var(--mv2-accent); box-shadow: 0 6px 18px rgba(0,0,0,.45);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-cities__pill:hover .mv2-cities__icon,
  body[data-portal="public"][data-page="home"] .mv2-cities__pill:focus-visible .mv2-cities__icon {
    background: rgba(244, 210, 122, 0.12); color: var(--mv2-accent);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-hiw {
    background: var(--m-bg);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-hiw__bubble {
    background: var(--m-surface); border-color: var(--m-border);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-hiw__bubble.is-active,
  body[data-portal="public"][data-page="home"] .mv2-hiw__step.is-active .mv2-hiw__bubble {
    background: var(--mv2-accent); border-color: var(--mv2-accent); color: #1a1610; box-shadow: 0 8px 24px rgba(244, 210, 122, 0.28);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-testimonials {
    background: var(--m-bg);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-testimonial {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-testimonial:hover {
    border-color: rgba(244, 210, 122, 0.30); box-shadow: 0 6px 24px rgba(0, 0, 0, 0.45);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-testimonial__quote {
    color: var(--m-ink);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-testimonial__name {
    color: var(--m-ink);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-testimonial__role {
    color: var(--m-muted);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-avatar {
    color: var(--mv2-accent); background: rgba(244, 210, 122, 0.16); border-color: rgba(244, 210, 122, 0.28);
  }
  
  body[data-portal="public"][data-page="home"] .stats-bar {
    background: linear-gradient(180deg, var(--m-surface) 0%, var(--m-surface-2) 100%); border-color: var(--m-border);
  }
  
  body[data-portal="public"][data-page="home"] .stats-bar .stat-value,
  body[data-portal="public"][data-page="home"] .stats-bar .stat-number {
    color: var(--m-ink);
  }
  
  body[data-portal="public"][data-page="home"] .stats-bar .stat-label {
    color: var(--m-muted);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-finalcta__bg {
    background: radial-gradient(ellipse at top, rgba(244, 210, 122, 0.12) 0%, transparent 55%), radial-gradient(ellipse at bottom right, rgba(0, 106, 255, 0.10) 0%, transparent 60%), linear-gradient(180deg, var(--m-bg) 0%, #1a1610 100%);
  }
  
  body[data-portal="public"][data-page="home"] .mobile-cta-bar {
    background: rgba(20, 16, 12, 0.92); border-top-color: rgba(245, 241, 232, 0.10); box-shadow: 0 -6px 18px rgba(0, 0, 0, 0.45);
  }
  
  body[data-portal="public"][data-page="home"] .mobile-cta-bar .mcta-ghost {
    background: var(--m-surface-2); color: var(--m-ink); border-color: var(--m-border);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-mcta {
    background: rgba(20, 16, 12, 0.92); border-top-color: rgba(245, 241, 232, 0.10); box-shadow: 0 -6px 24px rgba(0, 0, 0, 0.45);
  }
  
  body[data-portal="public"][data-page="home"] .footer {
    background: #0a0806; color: rgba(245, 241, 232, 0.72);
  }
  
  body[data-portal="public"][data-page="home"] .footer a,
  body[data-portal="public"][data-page="home"] .footer .footer-link,
  body[data-portal="public"][data-page="home"] .mv2-footer a,
  body[data-portal="public"][data-page="home"] .mv2-footer .mv2-footer-link {
    color: rgba(245, 241, 232, 0.72);
  }
  
  body[data-portal="public"][data-page="home"] .footer a:hover,
  body[data-portal="public"][data-page="home"] .footer .footer-link:hover,
  body[data-portal="public"][data-page="home"] .mv2-footer a:hover,
  body[data-portal="public"][data-page="home"] .mv2-footer .mv2-footer-link:hover {
    color: var(--mv2-accent);
  }
  
  body[data-portal="public"][data-page="home"] .footer .footer-col-title,
  body[data-portal="public"][data-page="home"] .mv2-footer .mv2-footer-col-title,
  body[data-portal="public"][data-page="home"] .footer-col-title,
  body[data-portal="public"][data-page="home"] .mv2-footer-col-title {
    color: var(--m-ink);
  }
  
  body[data-portal="public"][data-page="home"] .footer .footer-bottom,
  body[data-portal="public"][data-page="home"] .mv2-footer .mv2-footer-bottom {
    border-top-color: rgba(245, 241, 232, 0.10);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-btn--ghost:hover,
  body[data-portal="public"][data-page="home"] .mv2-btn--ghost:focus-visible {
    background: var(--m-surface); border-color: var(--mv2-accent); color: var(--mv2-accent);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-featured__cta a,
  body[data-portal="public"][data-page="home"] .mv2-featured__cta .btn-secondary {
    color: var(--mv2-accent); border-color: var(--mv2-accent);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-trustblock__item {
    background: var(--m-surface); border-color: var(--m-border);
  }
  
  body[data-portal="public"][data-page="home"] .mv2-trustblock__icon {
    background: rgba(244, 210, 122, 0.12); color: var(--mv2-accent);
  }
  
  body[data-portal="public"][data-page="home"] .empty-state-icon {
    background: rgba(244, 210, 122, 0.10); border-color: rgba(244, 210, 122, 0.22); color: var(--mv2-accent);
  }
  
  body[data-portal="public"][data-page="home"] .property-card-body {
    background: transparent; color: var(--m-text);
  }
  
  body[data-portal="public"][data-page="home"] .property-card-features,
  body[data-portal="public"][data-page="home"] .property-card-features li {
    color: var(--m-muted);
  }
  
  body[data-portal="public"][data-page="home"] .why-section {
    background: linear-gradient(180deg, #0a0806 0%, #181410 100%);
  }
  
  body[data-portal="public"][data-page="home"] .section-eyebrow {
    background: rgba(0, 106, 255, 0.16); color: #4d9aff;
  }
  }
  

  /* ════════════════════════════════════════════════════════════════════════════ *
   *  PHASE 9.6 — Dark theme rollout: listings.html + property.html
   * ────────────────────────────────────────────────────────────────────────────
   *  Same dual-trigger approach as Phase 9.5 (homepage):
   *    - @media (prefers-color-scheme: dark)  (OS-level)
   *    - html[data-theme="dark"]              (manual toggle)
   *
   *  Each page first redefines the --m-* / --mv2-* tokens to dark values, so
   *  every component already using those tokens (the majority of styles in
   *  cp-marketing.css scoped to these pages) auto-adapts. Then a focused set
   *  of element overrides patches the components that were authored with
   *  hardcoded light values (search field, filter bar, listings-section bg,
   *  detail-section, amenity-item, apply-card body, landlord avatar text, etc.).
   *
   *  Components that were *intentionally* dark in light mode (lightbox,
   *  mosaic gallery, apply-card-header navy gradient, mobile-apply-bar) are
   *  deliberately untouched — they already read correctly in either theme.
   * ════════════════════════════════════════════════════════════════════════════ */
  
  /* ─── Token redefinition: listings.html (explicit data-theme="dark") ─── */
  html[data-theme="dark"] body[data-portal="public"][data-page="listings"] {
    color-scheme: dark;
    /* legacy --m-* token system */
    --m-bg:             #0e0c08;
    --m-white:          #181410;
    --m-surface:        #1f1812;
    --m-surface-2:      #2a221b;
    --m-border:         #2e261c;
    --m-border-strong:  #3d3324;
    --m-ink:            #f5f1e8;
    --m-ink-2:          #e7e0d2;
    --m-text:           #e0d8c8;
    --m-muted:          #b8aea0;
    --m-muted-2:        #9b9183;
    --m-soft:           #6e6759;
    --m-brand-pale:     #102239;
    --m-gold-pale:      #2a221b;
    --m-shadow-sm:      0 1px 2px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.30);
    --m-shadow-md:      0 6px 16px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.30);
    --m-shadow-lg:      0 18px 40px rgba(0,0,0,.55), 0 6px 14px rgba(0,0,0,.32);
    /* modern --mv2-* token system */
    --mv2-bg-warm:        #0e0c08;
    --mv2-bg-warm-2:      #1a1610;
    --mv2-ink:            #f5f1e8;
    --mv2-ink-2:          #e7e0d2;
    --mv2-muted:          #b8aea0;
    --mv2-muted-2:        #9b9183;
    --mv2-hairline:       #2e261c;
    --mv2-hairline-strong:#3d3324;
    --mv2-accent:         #f4d27a;
    --mv2-accent-pale:    #2a221b;
    --mv2-accent-strong:  #f4d27a;
    --mv2-shadow-hairline:0 0 0 1px var(--mv2-hairline);
    --mv2-shadow-soft:    0 1px 2px rgba(0,0,0,.50), 0 8px 24px rgba(0,0,0,.45);
    --mv2-shadow-lift:    0 2px 4px rgba(0,0,0,.55), 0 18px 40px rgba(0,0,0,.55);
    --mv2-overlay-ink:    rgba(0, 0, 0, 0.62);
    /* page paint */
    background: #0e0c08;
    color: #e0d8c8;
  }

  /* ─── Token redefinition: listings.html (OS prefers-color-scheme: dark) ─── */
  @media (prefers-color-scheme: dark) {
    body[data-portal="public"][data-page="listings"] {
      color-scheme: dark;
      /* legacy --m-* token system */
      --m-bg:             #0e0c08;
      --m-white:          #181410;
      --m-surface:        #1f1812;
      --m-surface-2:      #2a221b;
      --m-border:         #2e261c;
      --m-border-strong:  #3d3324;
      --m-ink:            #f5f1e8;
      --m-ink-2:          #e7e0d2;
      --m-text:           #e0d8c8;
      --m-muted:          #b8aea0;
      --m-muted-2:        #9b9183;
      --m-soft:           #6e6759;
      --m-brand-pale:     #102239;
      --m-gold-pale:      #2a221b;
      --m-shadow-sm:      0 1px 2px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.30);
      --m-shadow-md:      0 6px 16px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.30);
      --m-shadow-lg:      0 18px 40px rgba(0,0,0,.55), 0 6px 14px rgba(0,0,0,.32);
      /* modern --mv2-* token system */
      --mv2-bg-warm:        #0e0c08;
      --mv2-bg-warm-2:      #1a1610;
      --mv2-ink:            #f5f1e8;
      --mv2-ink-2:          #e7e0d2;
      --mv2-muted:          #b8aea0;
      --mv2-muted-2:        #9b9183;
      --mv2-hairline:       #2e261c;
      --mv2-hairline-strong:#3d3324;
      --mv2-accent:         #f4d27a;
      --mv2-accent-pale:    #2a221b;
      --mv2-accent-strong:  #f4d27a;
      --mv2-shadow-hairline:0 0 0 1px var(--mv2-hairline);
      --mv2-shadow-soft:    0 1px 2px rgba(0,0,0,.50), 0 8px 24px rgba(0,0,0,.45);
      --mv2-shadow-lift:    0 2px 4px rgba(0,0,0,.55), 0 18px 40px rgba(0,0,0,.55);
      --mv2-overlay-ink:    rgba(0, 0, 0, 0.62);
      /* page paint */
      background: #0e0c08;
      color: #e0d8c8;
    }
  }

  /* ─── Element overrides: listings.html (explicit data-theme="dark") ─── */
  html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-listings-section {
  background: var(--m-bg);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-listings-header__bg {
  background:
        radial-gradient(ellipse at top left, rgba(244, 210, 122, 0.08) 0%, transparent 55%),
        linear-gradient(180deg, var(--mv2-bg-warm) 0%, var(--mv2-bg-warm-2) 100%);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-listings-header {
  border-bottom-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-search-field {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-search-field:focus-within {
  background: var(--m-surface-2); box-shadow: 0 0 0 3px rgba(244, 210, 122, 0.20); border-color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-search-field input,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-search-field select {
  background: transparent; color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-search-field input::placeholder {
  color: var(--m-muted-2);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-filter-bar,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-bar {
  background: var(--m-bg); border-bottom-color: var(--m-border); box-shadow: 0 1px 0 var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-chip,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-filter-chip {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-chip:hover,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-filter-chip:hover,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-chip.active,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .mv2-filter-chip.active {
  background: var(--m-surface-2); border-color: var(--mv2-accent); color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-dropdown,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-dropdown-wrap > .filter-dropdown {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text); box-shadow: 0 12px 32px rgba(0, 0, 0, 0.55);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-dropdown input,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-dropdown select,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-dropdown textarea {
  background: var(--m-bg); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .filter-count {
  background: var(--mv2-accent); color: #1a1610;
}

html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .toast-container .toast,
html[data-theme="dark"] body[data-portal="public"][data-page="listings"] .toast {
  background: var(--m-surface); color: var(--m-text); border-color: var(--m-border);
}

  /* ─── Element overrides: listings.html (OS prefers-color-scheme: dark) ─── */
  @media (prefers-color-scheme: dark) {
    body[data-portal="public"][data-page="listings"] .mv2-listings-section {
    background: var(--m-bg);
  }

  body[data-portal="public"][data-page="listings"] .mv2-listings-header__bg {
    background:
          radial-gradient(ellipse at top left, rgba(244, 210, 122, 0.08) 0%, transparent 55%),
          linear-gradient(180deg, var(--mv2-bg-warm) 0%, var(--mv2-bg-warm-2) 100%);
  }

  body[data-portal="public"][data-page="listings"] .mv2-listings-header {
    border-bottom-color: var(--m-border);
  }

  body[data-portal="public"][data-page="listings"] .mv2-search-field {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
  }

  body[data-portal="public"][data-page="listings"] .mv2-search-field:focus-within {
    background: var(--m-surface-2); box-shadow: 0 0 0 3px rgba(244, 210, 122, 0.20); border-color: var(--mv2-accent);
  }

  body[data-portal="public"][data-page="listings"] .mv2-search-field input,
  body[data-portal="public"][data-page="listings"] .mv2-search-field select {
    background: transparent; color: var(--m-text);
  }

  body[data-portal="public"][data-page="listings"] .mv2-search-field input::placeholder {
    color: var(--m-muted-2);
  }

  body[data-portal="public"][data-page="listings"] .mv2-filter-bar,
  body[data-portal="public"][data-page="listings"] .filter-bar {
    background: var(--m-bg); border-bottom-color: var(--m-border); box-shadow: 0 1px 0 var(--m-border);
  }

  body[data-portal="public"][data-page="listings"] .filter-chip,
  body[data-portal="public"][data-page="listings"] .mv2-filter-chip {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
  }

  body[data-portal="public"][data-page="listings"] .filter-chip:hover,
  body[data-portal="public"][data-page="listings"] .mv2-filter-chip:hover,
  body[data-portal="public"][data-page="listings"] .filter-chip.active,
  body[data-portal="public"][data-page="listings"] .mv2-filter-chip.active {
    background: var(--m-surface-2); border-color: var(--mv2-accent); color: var(--mv2-accent);
  }

  body[data-portal="public"][data-page="listings"] .filter-dropdown,
  body[data-portal="public"][data-page="listings"] .filter-dropdown-wrap > .filter-dropdown {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text); box-shadow: 0 12px 32px rgba(0, 0, 0, 0.55);
  }

  body[data-portal="public"][data-page="listings"] .filter-dropdown input,
  body[data-portal="public"][data-page="listings"] .filter-dropdown select,
  body[data-portal="public"][data-page="listings"] .filter-dropdown textarea {
    background: var(--m-bg); border-color: var(--m-border); color: var(--m-text);
  }

  body[data-portal="public"][data-page="listings"] .filter-count {
    background: var(--mv2-accent); color: #1a1610;
  }

  body[data-portal="public"][data-page="listings"] .toast-container .toast,
  body[data-portal="public"][data-page="listings"] .toast {
    background: var(--m-surface); color: var(--m-text); border-color: var(--m-border);
  }
  }
  
  
  /* ─── Token redefinition: property.html (explicit data-theme="dark") ─── */
  html[data-theme="dark"] body[data-portal="public"][data-page="property"] {
    color-scheme: dark;
    /* legacy --m-* token system */
    --m-bg:             #0e0c08;
    --m-white:          #181410;
    --m-surface:        #1f1812;
    --m-surface-2:      #2a221b;
    --m-border:         #2e261c;
    --m-border-strong:  #3d3324;
    --m-ink:            #f5f1e8;
    --m-ink-2:          #e7e0d2;
    --m-text:           #e0d8c8;
    --m-muted:          #b8aea0;
    --m-muted-2:        #9b9183;
    --m-soft:           #6e6759;
    --m-brand-pale:     #102239;
    --m-gold-pale:      #2a221b;
    --m-shadow-sm:      0 1px 2px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.30);
    --m-shadow-md:      0 6px 16px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.30);
    --m-shadow-lg:      0 18px 40px rgba(0,0,0,.55), 0 6px 14px rgba(0,0,0,.32);
    /* modern --mv2-* token system */
    --mv2-bg-warm:        #0e0c08;
    --mv2-bg-warm-2:      #1a1610;
    --mv2-ink:            #f5f1e8;
    --mv2-ink-2:          #e7e0d2;
    --mv2-muted:          #b8aea0;
    --mv2-muted-2:        #9b9183;
    --mv2-hairline:       #2e261c;
    --mv2-hairline-strong:#3d3324;
    --mv2-accent:         #f4d27a;
    --mv2-accent-pale:    #2a221b;
    --mv2-accent-strong:  #f4d27a;
    --mv2-shadow-hairline:0 0 0 1px var(--mv2-hairline);
    --mv2-shadow-soft:    0 1px 2px rgba(0,0,0,.50), 0 8px 24px rgba(0,0,0,.45);
    --mv2-shadow-lift:    0 2px 4px rgba(0,0,0,.55), 0 18px 40px rgba(0,0,0,.55);
    --mv2-overlay-ink:    rgba(0, 0, 0, 0.62);
    /* page paint */
    background: #0e0c08;
    color: #e0d8c8;
  }

  /* ─── Token redefinition: property.html (OS prefers-color-scheme: dark) ─── */
  @media (prefers-color-scheme: dark) {
    body[data-portal="public"][data-page="property"] {
      color-scheme: dark;
      /* legacy --m-* token system */
      --m-bg:             #0e0c08;
      --m-white:          #181410;
      --m-surface:        #1f1812;
      --m-surface-2:      #2a221b;
      --m-border:         #2e261c;
      --m-border-strong:  #3d3324;
      --m-ink:            #f5f1e8;
      --m-ink-2:          #e7e0d2;
      --m-text:           #e0d8c8;
      --m-muted:          #b8aea0;
      --m-muted-2:        #9b9183;
      --m-soft:           #6e6759;
      --m-brand-pale:     #102239;
      --m-gold-pale:      #2a221b;
      --m-shadow-sm:      0 1px 2px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.30);
      --m-shadow-md:      0 6px 16px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.30);
      --m-shadow-lg:      0 18px 40px rgba(0,0,0,.55), 0 6px 14px rgba(0,0,0,.32);
      /* modern --mv2-* token system */
      --mv2-bg-warm:        #0e0c08;
      --mv2-bg-warm-2:      #1a1610;
      --mv2-ink:            #f5f1e8;
      --mv2-ink-2:          #e7e0d2;
      --mv2-muted:          #b8aea0;
      --mv2-muted-2:        #9b9183;
      --mv2-hairline:       #2e261c;
      --mv2-hairline-strong:#3d3324;
      --mv2-accent:         #f4d27a;
      --mv2-accent-pale:    #2a221b;
      --mv2-accent-strong:  #f4d27a;
      --mv2-shadow-hairline:0 0 0 1px var(--mv2-hairline);
      --mv2-shadow-soft:    0 1px 2px rgba(0,0,0,.50), 0 8px 24px rgba(0,0,0,.45);
      --mv2-shadow-lift:    0 2px 4px rgba(0,0,0,.55), 0 18px 40px rgba(0,0,0,.55);
      --mv2-overlay-ink:    rgba(0, 0, 0, 0.62);
      /* page paint */
      background: #0e0c08;
      color: #e0d8c8;
    }
  }

  /* ─── Element overrides: property.html (explicit data-theme="dark") ─── */
  html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-main {
  color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-section {
  background: var(--m-surface); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-section-title,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-title,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-price {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-address,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-meta-row,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-desc {
  color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-meta-item {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-meta-item:hover {
  border-color: rgba(244, 210, 122, 0.30); box-shadow: 0 4px 16px rgba(244, 210, 122, 0.10);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-meta-icon {
  background: rgba(244, 210, 122, 0.10); border-color: rgba(244, 210, 122, 0.22); color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-tabs-wrap,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-tabs {
  background: var(--m-surface); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-tab {
  color: var(--m-muted); border-bottom-color: transparent;
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-tab.active,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-tab[aria-selected="true"] {
  color: var(--mv2-accent); border-bottom-color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-tab-panel {
  color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenities-grid,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenity-grid {
  color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenity-item {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenity-item:hover {
  border-color: rgba(244, 210, 122, 0.30); box-shadow: 0 2px 12px rgba(244, 210, 122, 0.08);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenity-item i.icon-green {
  color: #34d399;
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenity-item i.icon-sky {
  color: #38bdf8;
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenity-item i.icon-amber {
  color: #fbbf24;
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenity-item i.icon-purple {
  color: #a78bfa;
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenity-item i.icon-rose {
  color: #fb7185;
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .amenity-item i.icon-teal {
  color: #2dd4bf;
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .map-container {
  background: var(--m-surface); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .map-open-btn {
  background: var(--m-surface); color: var(--mv2-accent); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .map-open-btn:hover {
  background: var(--m-surface-2); border-color: var(--mv2-accent); box-shadow: 0 4px 14px rgba(244, 210, 122, 0.18);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .apply-card {
  background: var(--m-surface); border-color: var(--m-border); box-shadow: 0 8px 32px rgba(0, 0, 0, 0.45), 0 2px 6px rgba(0, 0, 0, 0.25);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .apply-card-body {
  background: var(--m-surface); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .apply-card-price,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .apply-card-avail {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .apply-cost-row,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .apply-cost-row__label,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .apply-cost-row__value {
  color: var(--m-text); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .apply-divider {
  background: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .share-btn {
  background: var(--m-surface); color: var(--m-text); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .share-btn:hover {
  background: var(--m-surface-2); border-color: var(--mv2-accent); color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .share-btn.saved {
  color: #f87171; border-color: rgba(248, 113, 113, 0.40); background: rgba(248, 113, 113, 0.10);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .mv2-landlord-card,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .landlord-card {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .mv2-landlord-card #landlordAvatar,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .landlord-card-avatar {
  background: rgba(244, 210, 122, 0.16); color: var(--mv2-accent); border-color: rgba(244, 210, 122, 0.28);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .mv2-landlord-card .landlord-name,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .mv2-landlord-card .landlord-title {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"][data-page="property"] .detail-section.skeleton,
html[data-theme="dark"] body[data-portal="public"][data-page="property"] .skeleton-line {
  background: linear-gradient(90deg, var(--m-surface) 25%, var(--m-surface-2) 50%, var(--m-surface) 75%);
}

  /* ─── Element overrides: property.html (OS prefers-color-scheme: dark) ─── */
  @media (prefers-color-scheme: dark) {
    body[data-portal="public"][data-page="property"] .detail-main {
    color: var(--m-text);
  }

  body[data-portal="public"][data-page="property"] .detail-section {
    background: var(--m-surface); border-color: var(--m-border);
  }

  body[data-portal="public"][data-page="property"] .detail-section-title,
  body[data-portal="public"][data-page="property"] .detail-title,
  body[data-portal="public"][data-page="property"] .detail-price {
    color: var(--m-ink);
  }

  body[data-portal="public"][data-page="property"] .detail-address,
  body[data-portal="public"][data-page="property"] .detail-meta-row,
  body[data-portal="public"][data-page="property"] .detail-desc {
    color: var(--m-text);
  }

  body[data-portal="public"][data-page="property"] .detail-meta-item {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
  }

  body[data-portal="public"][data-page="property"] .detail-meta-item:hover {
    border-color: rgba(244, 210, 122, 0.30); box-shadow: 0 4px 16px rgba(244, 210, 122, 0.10);
  }

  body[data-portal="public"][data-page="property"] .detail-meta-icon {
    background: rgba(244, 210, 122, 0.10); border-color: rgba(244, 210, 122, 0.22); color: var(--mv2-accent);
  }

  body[data-portal="public"][data-page="property"] .detail-tabs-wrap,
  body[data-portal="public"][data-page="property"] .detail-tabs {
    background: var(--m-surface); border-color: var(--m-border);
  }

  body[data-portal="public"][data-page="property"] .detail-tab {
    color: var(--m-muted); border-bottom-color: transparent;
  }

  body[data-portal="public"][data-page="property"] .detail-tab.active,
  body[data-portal="public"][data-page="property"] .detail-tab[aria-selected="true"] {
    color: var(--mv2-accent); border-bottom-color: var(--mv2-accent);
  }

  body[data-portal="public"][data-page="property"] .detail-tab-panel {
    color: var(--m-text);
  }

  body[data-portal="public"][data-page="property"] .amenities-grid,
  body[data-portal="public"][data-page="property"] .amenity-grid {
    color: var(--m-text);
  }

  body[data-portal="public"][data-page="property"] .amenity-item {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
  }

  body[data-portal="public"][data-page="property"] .amenity-item:hover {
    border-color: rgba(244, 210, 122, 0.30); box-shadow: 0 2px 12px rgba(244, 210, 122, 0.08);
  }

  body[data-portal="public"][data-page="property"] .amenity-item i.icon-green {
    color: #34d399;
  }

  body[data-portal="public"][data-page="property"] .amenity-item i.icon-sky {
    color: #38bdf8;
  }

  body[data-portal="public"][data-page="property"] .amenity-item i.icon-amber {
    color: #fbbf24;
  }

  body[data-portal="public"][data-page="property"] .amenity-item i.icon-purple {
    color: #a78bfa;
  }

  body[data-portal="public"][data-page="property"] .amenity-item i.icon-rose {
    color: #fb7185;
  }

  body[data-portal="public"][data-page="property"] .amenity-item i.icon-teal {
    color: #2dd4bf;
  }

  body[data-portal="public"][data-page="property"] .map-container {
    background: var(--m-surface); border-color: var(--m-border);
  }

  body[data-portal="public"][data-page="property"] .map-open-btn {
    background: var(--m-surface); color: var(--mv2-accent); border-color: var(--m-border);
  }

  body[data-portal="public"][data-page="property"] .map-open-btn:hover {
    background: var(--m-surface-2); border-color: var(--mv2-accent); box-shadow: 0 4px 14px rgba(244, 210, 122, 0.18);
  }

  body[data-portal="public"][data-page="property"] .apply-card {
    background: var(--m-surface); border-color: var(--m-border); box-shadow: 0 8px 32px rgba(0, 0, 0, 0.45), 0 2px 6px rgba(0, 0, 0, 0.25);
  }

  body[data-portal="public"][data-page="property"] .apply-card-body {
    background: var(--m-surface); color: var(--m-text);
  }

  body[data-portal="public"][data-page="property"] .apply-card-price,
  body[data-portal="public"][data-page="property"] .apply-card-avail {
    color: var(--m-ink);
  }

  body[data-portal="public"][data-page="property"] .apply-cost-row,
  body[data-portal="public"][data-page="property"] .apply-cost-row__label,
  body[data-portal="public"][data-page="property"] .apply-cost-row__value {
    color: var(--m-text); border-color: var(--m-border);
  }

  body[data-portal="public"][data-page="property"] .apply-divider {
    background: var(--m-border);
  }

  body[data-portal="public"][data-page="property"] .share-btn {
    background: var(--m-surface); color: var(--m-text); border-color: var(--m-border);
  }

  body[data-portal="public"][data-page="property"] .share-btn:hover {
    background: var(--m-surface-2); border-color: var(--mv2-accent); color: var(--mv2-accent);
  }

  body[data-portal="public"][data-page="property"] .share-btn.saved {
    color: #f87171; border-color: rgba(248, 113, 113, 0.40); background: rgba(248, 113, 113, 0.10);
  }

  body[data-portal="public"][data-page="property"] .mv2-landlord-card,
  body[data-portal="public"][data-page="property"] .landlord-card {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
  }

  body[data-portal="public"][data-page="property"] .mv2-landlord-card #landlordAvatar,
  body[data-portal="public"][data-page="property"] .landlord-card-avatar {
    background: rgba(244, 210, 122, 0.16); color: var(--mv2-accent); border-color: rgba(244, 210, 122, 0.28);
  }

  body[data-portal="public"][data-page="property"] .mv2-landlord-card .landlord-name,
  body[data-portal="public"][data-page="property"] .mv2-landlord-card .landlord-title {
    color: var(--m-ink);
  }

  body[data-portal="public"][data-page="property"] .detail-section.skeleton,
  body[data-portal="public"][data-page="property"] .skeleton-line {
    background: linear-gradient(90deg, var(--m-surface) 25%, var(--m-surface-2) 50%, var(--m-surface) 75%);
  }
  }
  
  

  /* ════════════════════════════════════════════════════════════════════════════ *
   *  PHASE 9.7 — Dark theme: all remaining public static content pages
   * ────────────────────────────────────────────────────────────────────────────
   *  Same dual-trigger approach (@media + html[data-theme="dark"]).
   *
   *  Uses ONE selector that catches every public page that doesn't already
   *  have its own per-page dark scope:
   *    body[data-portal="public"]:not([data-page="home"])
   *                              :not([data-page="listings"])
   *                              :not([data-page="property"])
   *
   *  This covers (verified at commit time):
   *    about, faq, policies, terms, privacy,
   *    application-credit-policy, fair-housing, holding-deposit-policy,
   *    how-it-works, how-to-apply, landlord-platform-agreement,
   *    policy-changelog, rental-application-policy,
   *    404 (after data-page="404" added to body),
   *    verify-lease (after data-portal="public" + data-page="verify-lease" added)
   *
   *  And any future public page that gets data-portal="public" plus a new
   *  data-page value will also dark-adapt automatically without further CSS.
   * ════════════════════════════════════════════════════════════════════════════ */
  
  /* ─── Token redef: all-other-public-pages (explicit data-theme="dark") ─── */
  html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) {
    color-scheme: dark;
    /* legacy --m-* token system */
    --m-bg:             #0e0c08;
    --m-white:          #181410;
    --m-surface:        #1f1812;
    --m-surface-2:      #2a221b;
    --m-border:         #2e261c;
    --m-border-strong:  #3d3324;
    --m-ink:            #f5f1e8;
    --m-ink-2:          #e7e0d2;
    --m-text:           #e0d8c8;
    --m-muted:          #b8aea0;
    --m-muted-2:        #9b9183;
    --m-soft:           #6e6759;
    --m-brand-pale:     #102239;
    --m-gold-pale:      #2a221b;
    --m-shadow-sm:      0 1px 2px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.30);
    --m-shadow-md:      0 6px 16px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.30);
    --m-shadow-lg:      0 18px 40px rgba(0,0,0,.55), 0 6px 14px rgba(0,0,0,.32);
    /* modern --mv2-* token system */
    --mv2-bg-warm:        #0e0c08;
    --mv2-bg-warm-2:      #1a1610;
    --mv2-ink:            #f5f1e8;
    --mv2-ink-2:          #e7e0d2;
    --mv2-muted:          #b8aea0;
    --mv2-muted-2:        #9b9183;
    --mv2-hairline:       #2e261c;
    --mv2-hairline-strong:#3d3324;
    --mv2-accent:         #f4d27a;
    --mv2-accent-pale:    #2a221b;
    --mv2-accent-strong:  #f4d27a;
    --mv2-shadow-hairline:0 0 0 1px var(--mv2-hairline);
    --mv2-shadow-soft:    0 1px 2px rgba(0,0,0,.50), 0 8px 24px rgba(0,0,0,.45);
    --mv2-shadow-lift:    0 2px 4px rgba(0,0,0,.55), 0 18px 40px rgba(0,0,0,.55);
    --mv2-overlay-ink:    rgba(0, 0, 0, 0.62);
    /* page paint */
    background: #0e0c08;
    color: #e0d8c8;
  }

  /* ─── Token redef: all-other-public-pages (OS @media prefers-color-scheme: dark) ─── */
  @media (prefers-color-scheme: dark) {
    body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) {
      color-scheme: dark;
      /* legacy --m-* token system */
      --m-bg:             #0e0c08;
      --m-white:          #181410;
      --m-surface:        #1f1812;
      --m-surface-2:      #2a221b;
      --m-border:         #2e261c;
      --m-border-strong:  #3d3324;
      --m-ink:            #f5f1e8;
      --m-ink-2:          #e7e0d2;
      --m-text:           #e0d8c8;
      --m-muted:          #b8aea0;
      --m-muted-2:        #9b9183;
      --m-soft:           #6e6759;
      --m-brand-pale:     #102239;
      --m-gold-pale:      #2a221b;
      --m-shadow-sm:      0 1px 2px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.30);
      --m-shadow-md:      0 6px 16px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.30);
      --m-shadow-lg:      0 18px 40px rgba(0,0,0,.55), 0 6px 14px rgba(0,0,0,.32);
      /* modern --mv2-* token system */
      --mv2-bg-warm:        #0e0c08;
      --mv2-bg-warm-2:      #1a1610;
      --mv2-ink:            #f5f1e8;
      --mv2-ink-2:          #e7e0d2;
      --mv2-muted:          #b8aea0;
      --mv2-muted-2:        #9b9183;
      --mv2-hairline:       #2e261c;
      --mv2-hairline-strong:#3d3324;
      --mv2-accent:         #f4d27a;
      --mv2-accent-pale:    #2a221b;
      --mv2-accent-strong:  #f4d27a;
      --mv2-shadow-hairline:0 0 0 1px var(--mv2-hairline);
      --mv2-shadow-soft:    0 1px 2px rgba(0,0,0,.50), 0 8px 24px rgba(0,0,0,.45);
      --mv2-shadow-lift:    0 2px 4px rgba(0,0,0,.55), 0 18px 40px rgba(0,0,0,.55);
      --mv2-overlay-ink:    rgba(0, 0, 0, 0.62);
      /* page paint */
      background: #0e0c08;
      color: #e0d8c8;
    }
  }

  /* ─── Element overrides: all-other-public-pages (explicit data-theme="dark") ─── */
  html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .info-hero,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .page-header,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-header,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-header {
  background: linear-gradient(180deg, var(--mv2-bg-warm) 0%, var(--mv2-bg-warm-2) 100%); color: var(--m-ink); border-bottom-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .info-hero h1,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .page-header h1,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-header h1,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-header h1 {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .info-hero p,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .page-header p,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-header p,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-header p {
  color: var(--m-muted);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .page-body,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) main.content,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .content-wrap {
  background: var(--m-bg); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body h2,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body h2,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body h2,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body h3,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body h3,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body h3 {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body a,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body a,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body a {
  color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body a:hover,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body a:hover,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body a:hover {
  color: #fbe49b;
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body hr,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body hr,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body hr {
  border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body code,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body code,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body code {
  background: var(--m-surface-2); color: var(--m-ink); border-color: var(--m-border);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body blockquote,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body blockquote,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body blockquote {
  border-left-color: var(--mv2-accent); background: var(--m-surface); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-item,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-card {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-question,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-item summary {
  color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-answer {
  color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-toc {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-toc h3 {
  color: var(--m-muted);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-toc a {
  color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-toc a:hover {
  color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-callout {
  background: rgba(245, 158, 11, 0.08); border-left-color: var(--mv2-accent); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-callout strong {
  color: var(--mv2-accent);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .arbitration-block {
  background: rgba(220, 38, 38, 0.10); border-color: rgba(248, 113, 113, 0.50); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .arbitration-block h3 {
  color: #fb7185;
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .version-block {
  background: var(--m-surface); border-left-color: var(--mv2-accent); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .version-meta {
  color: var(--m-muted-2);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .card,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .panel,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .info-card {
  background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .card-header {
  background: var(--m-surface-2); border-bottom-color: var(--m-border); color: var(--m-ink);
}

html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body ul li,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body ol li,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body ul li,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body ol li,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body ul li,
html[data-theme="dark"] body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body ol li {
  color: var(--m-text);
}

  /* ─── Element overrides: all-other-public-pages (OS @media prefers-color-scheme: dark) ─── */
  @media (prefers-color-scheme: dark) {
    body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .info-hero,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .page-header,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-header,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-header {
    background: linear-gradient(180deg, var(--mv2-bg-warm) 0%, var(--mv2-bg-warm-2) 100%); color: var(--m-ink); border-bottom-color: var(--m-border);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .info-hero h1,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .page-header h1,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-header h1,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-header h1 {
    color: var(--m-ink);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .info-hero p,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .page-header p,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-header p,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-header p {
    color: var(--m-muted);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .page-body,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) main.content,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .content-wrap {
    background: var(--m-bg); color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body h2,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body h2,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body h2,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body h3,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body h3,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body h3 {
    color: var(--m-ink);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body a,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body a,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body a {
    color: var(--mv2-accent);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body a:hover,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body a:hover,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body a:hover {
    color: #fbe49b;
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body hr,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body hr,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body hr {
    border-color: var(--m-border);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body code,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body code,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body code {
    background: var(--m-surface-2); color: var(--m-ink); border-color: var(--m-border);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body blockquote,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body blockquote,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body blockquote {
    border-left-color: var(--mv2-accent); background: var(--m-surface); color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-item,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-card {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-question,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-item summary {
    color: var(--m-ink);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .faq-answer {
    color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-toc {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-toc h3 {
    color: var(--m-muted);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-toc a {
    color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-toc a:hover {
    color: var(--mv2-accent);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-callout {
    background: rgba(245, 158, 11, 0.08); border-left-color: var(--mv2-accent); color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-callout strong {
    color: var(--mv2-accent);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .arbitration-block {
    background: rgba(220, 38, 38, 0.10); border-color: rgba(248, 113, 113, 0.50); color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .arbitration-block h3 {
    color: #fb7185;
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .version-block {
    background: var(--m-surface); border-left-color: var(--mv2-accent); color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .version-meta {
    color: var(--m-muted-2);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .card,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .panel,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .info-card {
    background: var(--m-surface); border-color: var(--m-border); color: var(--m-text);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .card-header {
    background: var(--m-surface-2); border-bottom-color: var(--m-border); color: var(--m-ink);
  }

  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body ul li,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .doc-body ol li,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body ul li,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .legal-body ol li,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body ul li,
  body[data-portal="public"]:not([data-page="home"]):not([data-page="listings"]):not([data-page="property"]) .policy-body ol li {
    color: var(--m-text);
  }
  }
  
  

  /* ════════════════════════════════════════════════════════════════════════════ *
   *  PHASE 9.8 — Theme toggle button (sun/moon)
   * ────────────────────────────────────────────────────────────────────────────
   *  Lives in the main nav (desktop) and mobile drawer body.
   *  Light icon set: shows MOON in light theme (= "switch to dark"),
   *                  shows SUN  in dark theme  (= "switch to light").
   *  Wired by js/components.js → wireThemeToggle().
   * ════════════════════════════════════════════════════════════════════════════ */

  .visually-hidden {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0,0,0,0); white-space: nowrap; border: 0;
  }

  /* ─── Desktop nav toggle: small circular icon button ─── */
  .theme-toggle.mv2-theme-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    margin-left: 12px;
    padding: 0;
    border-radius: 50%;
    border: 1px solid var(--mv2-hairline, rgba(26, 26, 26, 0.10));
    background: transparent;
    color: var(--mv2-ink, #1A1A1A);
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
    transition: background-color 220ms cubic-bezier(0.22, 1, 0.36, 1),
                border-color 220ms cubic-bezier(0.22, 1, 0.36, 1),
                transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
  }
  .theme-toggle.mv2-theme-toggle:hover,
  .theme-toggle.mv2-theme-toggle:focus-visible {
    background: rgba(212, 160, 23, 0.10);
    border-color: var(--mv2-accent, #d4a017);
    color: var(--mv2-accent, #d4a017);
    outline: none;
    transform: translateY(-1px);
  }
  .theme-toggle.mv2-theme-toggle:active { transform: translateY(0); }
  .theme-toggle.mv2-theme-toggle .theme-toggle__icon {
    position: absolute;
    font-size: 15px;
    transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1),
                transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
  }
  @media (prefers-reduced-motion: reduce) {
    .theme-toggle.mv2-theme-toggle,
    .theme-toggle.mv2-theme-toggle .theme-toggle__icon {
      transition: none;
    }
  }

  /* ─── Default (light): show moon, hide sun ─── */
  .theme-toggle__icon--sun  { opacity: 0; transform: rotate(90deg) scale(0.6); }
  .theme-toggle__icon--moon { opacity: 1; transform: rotate(0)     scale(1); }

  /* ─── Dark theme (either trigger): show sun, hide moon ─── */
  html[data-theme="dark"] .theme-toggle__icon--sun,
  html[data-theme="dark"] .nav-drawer-theme-toggle .theme-toggle__icon--sun {
    opacity: 1; transform: rotate(0) scale(1);
  }
  html[data-theme="dark"] .theme-toggle__icon--moon,
  html[data-theme="dark"] .nav-drawer-theme-toggle .theme-toggle__icon--moon {
    opacity: 0; transform: rotate(-90deg) scale(0.6);
  }
  @media (prefers-color-scheme: dark) {
    html:not([data-theme="light"]) .theme-toggle__icon--sun,
    html:not([data-theme="light"]) .nav-drawer-theme-toggle .theme-toggle__icon--sun {
      opacity: 1; transform: rotate(0) scale(1);
    }
    html:not([data-theme="light"]) .theme-toggle__icon--moon,
    html:not([data-theme="light"]) .nav-drawer-theme-toggle .theme-toggle__icon--moon {
      opacity: 0; transform: rotate(-90deg) scale(0.6);
    }
  }

  /* ─── Toggle button color in dark theme (both triggers) ─── */
  html[data-theme="dark"] .theme-toggle.mv2-theme-toggle {
    color: var(--mv2-accent, #f4d27a);
    border-color: rgba(245, 241, 232, 0.18);
  }
  html[data-theme="dark"] .theme-toggle.mv2-theme-toggle:hover,
  html[data-theme="dark"] .theme-toggle.mv2-theme-toggle:focus-visible {
    background: rgba(244, 210, 122, 0.14);
    border-color: var(--mv2-accent, #f4d27a);
  }
  @media (prefers-color-scheme: dark) {
    html:not([data-theme="light"]) .theme-toggle.mv2-theme-toggle {
      color: #f4d27a;
      border-color: rgba(245, 241, 232, 0.18);
    }
    html:not([data-theme="light"]) .theme-toggle.mv2-theme-toggle:hover,
    html:not([data-theme="light"]) .theme-toggle.mv2-theme-toggle:focus-visible {
      background: rgba(244, 210, 122, 0.14);
      border-color: #f4d27a;
    }
  }

  /* ─── Mobile drawer toggle entry: looks like a nav-drawer-link with icon swap ─── */
  .nav-drawer-theme-toggle {
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
  }
  .nav-drawer-theme-toggle .theme-toggle__icon {
    position: static;
    width: 18px;
    text-align: center;
    font-size: 16px;
    transition: opacity 200ms ease;
  }
  /* In light mode: drawer entry shows moon */
  .nav-drawer-theme-toggle .theme-toggle__icon--sun  { display: none; }
  .nav-drawer-theme-toggle .theme-toggle__icon--moon { display: inline-block; opacity: 1; transform: none; }
  html[data-theme="dark"] .nav-drawer-theme-toggle .theme-toggle__icon--moon { display: none; }
  html[data-theme="dark"] .nav-drawer-theme-toggle .theme-toggle__icon--sun  { display: inline-block; opacity: 1; transform: none; color: #f4d27a; }
  @media (prefers-color-scheme: dark) {
    html:not([data-theme="light"]) .nav-drawer-theme-toggle .theme-toggle__icon--moon { display: none; }
    html:not([data-theme="light"]) .nav-drawer-theme-toggle .theme-toggle__icon--sun  { display: inline-block; opacity: 1; transform: none; color: #f4d27a; }
  }

  /* ─── Hide desktop toggle on mobile (drawer entry takes over) ─── */
  @media (max-width: 767px) {
    .theme-toggle.mv2-theme-toggle { display: none; }
  }
  