:root {
  --gallery-control-bg: var(--surface-layer-3);
  --gallery-control-border: var(--surface-stroke-strong);
  --mini-pin-bg: rgba(255, 255, 255, 0.96);
  --mini-pin-text: #1a232d;
  --mini-pin-border: rgba(30, 107, 53, 0.22);
  --mini-pin-shadow: 0 12px 22px rgba(11, 19, 28, 0.28);
  --listing-wave-a: rgba(58, 170, 88, 0.12);
  --listing-wave-b: rgba(45, 140, 71, 0.10);
  --listing-wave-c: rgba(201, 168, 76, 0.10);
  --listing-wave-line: rgba(58, 170, 88, 0.28);
  --listing-wave-line-alt: rgba(45, 140, 71, 0.24);
  --accent-bright: #01A652;
}

:root:not([data-mode="light"]) {
  --gallery-control-bg: var(--surface-layer-3);
  --gallery-control-border: var(--surface-stroke-strong);
  --mini-pin-bg: rgba(31, 45, 58, 0.92);
  --mini-pin-text: #edf5fd;
  --mini-pin-border: rgba(224, 236, 249, 0.4);
  --mini-pin-shadow: 0 14px 24px rgba(4, 8, 12, 0.42);
  --listing-wave-a: rgba(99, 150, 183, 0.2);
  --listing-wave-b: rgba(96, 148, 131, 0.18);
  --listing-wave-c: rgba(170, 146, 95, 0.16);
  --listing-wave-line: rgba(142, 189, 220, 0.5);
  --listing-wave-line-alt: rgba(142, 192, 174, 0.42);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Outfit", sans-serif;
  line-height: 1.55;
  background: var(--page-bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: inherit; text-decoration: none; }

a:focus-visible,
button:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 3px;
  border-radius: 14px;
}

/* ── Page shell ── */

html {
  scrollbar-gutter: stable;
  overflow-x: hidden;
  overflow-y: scroll;
}

.page {
  min-height: 100vh;
  min-height: 100dvh;
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: clip;
}

.page::before,
.page::after {
  content: "";
  position: absolute;
  left: -18%;
  right: -18%;
  bottom: 32px;
  height: clamp(300px, 40vw, 520px);
  pointer-events: none;
  z-index: var(--z-base);
  transform: translate3d(0, 0, 0);
}

.page::before {
  background:
    radial-gradient(62% 90% at 14% 100%, var(--listing-wave-a) 0%, transparent 72%),
    radial-gradient(54% 84% at 52% 100%, var(--listing-wave-b) 0%, transparent 74%),
    radial-gradient(58% 88% at 88% 100%, var(--listing-wave-c) 0%, transparent 72%);
  opacity: 0.92;
  animation: listingWaveDriftA 14s ease-in-out infinite alternate;
}

.page::after {
  background:
    radial-gradient(58% 84% at 8% 100%, var(--listing-wave-b) 0%, transparent 74%),
    radial-gradient(52% 84% at 42% 100%, var(--listing-wave-c) 0%, transparent 72%),
    radial-gradient(64% 88% at 80% 100%, var(--listing-wave-a) 0%, transparent 74%);
  opacity: 0.82;
  animation: listingWaveDriftB 18s ease-in-out infinite alternate;
}

.page > * { position: relative; z-index: var(--z-content); }

/* ── Stage (full-bleed container) ── */

.stage {
  width: 100%;
  padding-top: 52px;
  flex: 1 0 auto;
  display: flex;
  flex-direction: column;
}

/* ── Gallery hero grid ── */

.gallery {
  position: relative;
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  height: clamp(300px, 42vw, 480px);
  gap: 3px;
  background: var(--surface-layer-1);
  overflow: hidden;
}

/* Main image: full left column */
.gallery-main {
  grid-column: 1;
  grid-row: 1 / span 2;
  position: relative;
  margin: 0;
  overflow: hidden;
  background: var(--surface-layer-2);
}

.gallery-main img { width: 100%; height: 100%; object-fit: cover; display: block; }

.gallery-main--empty {
  display: grid;
  place-items: center;
  background: var(--surface-layer-1);
}

.gallery-fallback {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  color: var(--muted);
  font-size: 0.96rem;
  background: linear-gradient(135deg, rgba(198,212,197,0.76), rgba(244,239,230,0.78));
}

/* Thumb grid: right 2 columns, 2×2 */
.gallery-thumbs {
  grid-column: 2 / span 2;
  grid-row: 1 / span 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 3px;
}

/* Hide image 0 (shown in main) and image 5+ */
.gallery-thumb:nth-child(1)    { display: none; }
.gallery-thumb:nth-child(n+6)  { display: none; }

.gallery-thumb {
  position: relative;
  border: none;
  padding: 0;
  background: var(--surface-layer-2);
  overflow: hidden;
  cursor: pointer;
  opacity: 0.88;
  transition: opacity 0.2s ease;
  display: block;
}

.gallery-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gallery-thumb:hover { opacity: 1; }
.gallery-thumb.is-active { opacity: 1; outline: 2px solid var(--accent-bright); outline-offset: -2px; }

/* "+N more" overlay on last visible thumb */
.gallery-thumb--has-more::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.46);
}

.gallery-thumb__more {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 0.88rem;
  font-weight: 600;
  pointer-events: none;
}

/* Gallery overlays */

.gallery-breadcrumb {
  position: absolute;
  top: 16px;
  inset-inline-start: 16px;
  z-index: var(--z-sticky);
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  color: rgba(255,255,255,0.82);
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
  pointer-events: auto;
}

.gallery-breadcrumb a {
  color: rgba(255,255,255,0.82);
  transition: color 0.15s ease;
  min-height: 32px;
  display: inline-flex;
  align-items: center;
}

.gallery-breadcrumb a:hover { color: #fff; }
.gallery-breadcrumb span { opacity: 0.5; font-size: 0.7rem; }

.gallery-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 8px;
  background: rgba(0,0,0,0.36);
  backdrop-filter: blur(8px);
  flex-shrink: 0;
  margin-inline-end: 4px;
}

.gallery-back svg {
  width: 18px; height: 18px;
  stroke: currentColor; stroke-width: 2; fill: none;
}

.gallery-hero-actions {
  position: absolute;
  bottom: 14px;
  right: 14px;
  z-index: var(--z-sticky);
  display: flex;
  gap: 6px;
}

.gallery-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 13px;
  border-radius: 999px;
  border: none;
  background: rgba(0,0,0,0.44);
  backdrop-filter: blur(10px);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: background-color 0.15s ease;
}

.gallery-action-btn:hover { background: rgba(0,0,0,0.62); }

.gallery-action-btn svg {
  width: 15px; height: 15px;
  stroke: currentColor; stroke-width: 2; fill: none;
  flex-shrink: 0;
}

/* Gallery nav arrows (inside gallery-main) */
.gallery-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border: 1px solid var(--gallery-control-border);
  background: var(--gallery-control-bg);
  color: var(--accent-quiet);
  border-radius: var(--control-radius-tight);
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: var(--z-sticky);
  font-size: 1.2rem;
  line-height: 1;
}

.gallery-nav--prev { left: 10px; }
.gallery-nav--next { right: 10px; }
.gallery-nav:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

.gallery-counter {
  position: absolute;
  right: 10px;
  bottom: 10px;
  z-index: var(--z-sticky);
  display: inline-flex;
  gap: 4px;
  align-items: center;
  padding: 3px 9px;
  border-radius: var(--control-radius-tight);
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--accent-quiet);
  background: var(--gallery-control-bg);
  border: 1px solid var(--gallery-control-border);
}

/* ── Content zone (overlaps gallery) ── */

.content-zone {
  max-width: 1240px;
  width: 100%;
  margin: -48px auto 0;
  padding: 0 clamp(16px, 3.5vw, 48px);
  position: relative;
  z-index: var(--z-raised);
}

/* ── Detail card (glass panel) ── */

.detail-card {
  background: var(--glass-bg, rgba(255,255,255,0.6));
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  border: 1px solid var(--surface-border);
  border-bottom: none;
  border-radius: 20px 20px 0 0;
  box-shadow: 0 -8px 40px rgba(0,0,0,0.07);
}

:root:not([data-mode="light"]) .detail-card {
  background: var(--glass-bg, rgba(18,22,26,0.6));
  box-shadow: 0 -8px 40px rgba(0,0,0,0.32);
}

/* ── Card head ── */

.detail-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  padding: 28px 32px 20px;
  border-bottom: 1px solid var(--surface-border);
  flex-wrap: wrap;
}

.detail-card__meta {
  flex: 1 1 auto;
  display: grid;
  gap: 6px;
  min-width: 0;
}

.detail-card__chips {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.type-chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 5px;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  background: var(--chip-bg);
  border: 1px solid var(--chip-border);
  color: var(--ink-soft);
}

.type-chip--purpose {
  background: rgba(1,166,82,0.12);
  border-color: rgba(1,166,82,0.22);
  color: var(--accent-bright);
}

.ref-chip {
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--muted);
  letter-spacing: 0.04em;
}

.listing-title {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: clamp(1.5rem, 3.5vw, 2.4rem);
  letter-spacing: -0.02em;
  line-height: 1.15;
  overflow-wrap: break-word;
}

.listing-location {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.85rem;
  color: var(--muted);
  min-height: 28px;
  transition: color 0.15s ease;
}

.listing-location:hover { color: var(--accent-bright); }

.listing-location svg {
  width: 13px; height: 13px;
  stroke: currentColor; stroke-width: 2; fill: none;
  flex-shrink: 0;
}

.detail-card__price-col {
  flex: 0 0 auto;
  text-align: end;
  display: grid;
  gap: 4px;
  align-content: start;
}

.price-main {
  font-size: clamp(1.3rem, 2.4vw, 1.8rem);
  font-weight: 700;
  color: var(--accent-bright);
  line-height: 1.1;
}

.price-sqm {
  font-size: 0.78rem;
  color: var(--muted);
}

.price-conversion {
  font-size: 0.85em;
  color: var(--text-muted);
  margin-top: 2px;
}

.price-managed { margin: 0; font-size: 0.78rem; color: var(--muted); }

.detail-inline-link {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.16em;
}

.detail-inline-link:hover { color: var(--accent-quiet); }

.pill-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  margin-top: 4px;
}

.purpose-pill,
.status-pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.purpose-pill {
  background: rgba(1,166,82,0.1);
  border: 1px solid rgba(1,166,82,0.22);
  color: var(--accent-bright);
}

.purpose-pill--sale {
  background: rgba(201,168,76,0.14);
  border-color: rgba(201,168,76,0.26);
  color: var(--badge-sale-text);
}

.status-pill {
  background: var(--chip-bg);
  border: 1px solid var(--chip-border);
  color: var(--ink-soft);
}

/* ── Stat rail ── */

.stat-rail {
  display: flex;
  border-bottom: 1px solid var(--surface-border);
  overflow: hidden;
}

.stat-rail__cell {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 16px 8px;
  text-align: center;
  border-inline-end: 1px solid var(--surface-border);
  background: rgba(0,0,0,0.012);
}

:root:not([data-mode="light"]) .stat-rail__cell {
  background: rgba(255,255,255,0.018);
}

.stat-rail__cell:last-child { border-inline-end: none; }

.stat-rail__icon {
  width: 28px; height: 28px;
  display: grid;
  place-items: center;
  color: var(--accent-bright);
  opacity: 0.75;
}

.stat-rail__icon svg {
  width: 16px; height: 16px;
  stroke: currentColor; stroke-width: 1.8; fill: none;
}

.stat-rail__val {
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1;
  color: var(--ink);
}

.stat-rail__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  line-height: 1.2;
}

/* ── Tab bar ── */

.detail-tabs-wrap { display: flex; flex-direction: column; }

.detail-tabs-bar {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--surface-border);
  padding: 0 32px;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
}

.detail-tabs-bar::-webkit-scrollbar { display: none; }

.detail-tab {
  padding: 12px 20px;
  border: none;
  border-bottom: 2px solid transparent;
  background: transparent;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
  text-transform: capitalize;
  margin-bottom: -1px;
  transition: color 0.15s ease, border-color 0.15s ease;
  min-height: 44px;
}

.detail-tab:hover { color: var(--ink-soft); }

.detail-tab.is-active {
  color: var(--accent-bright);
  border-bottom-color: var(--accent-bright);
  font-weight: 600;
}

/* ── Body grid ── */

.detail-body-grid {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 0;
  align-items: start;
}

.detail-panels {
  padding: 24px 32px 40px;
  border-inline-end: 1px solid var(--surface-border);
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.dtab-panel { display: flex; flex-direction: column; gap: 20px; }
.dtab-panel[hidden] { display: none; }

/* ── Overview tab ── */

.overview-copy { color: var(--muted); font-size: 0.9rem; margin: 0; line-height: 1.7; }

.overview-copy.is-collapsed {
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.text-toggle {
  border: 1px solid var(--chip-border);
  background: var(--surface-layer-1);
  color: var(--accent-quiet);
  border-radius: var(--control-radius-tight);
  padding: 6px 12px;
  font: inherit;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  width: fit-content;
}

.text-toggle[hidden] { display: none; }

/* Facts grid (2-col key/value pairs) */

.facts-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--surface-border);
}

.facts-grid__cell {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: rgba(0,0,0,0.013);
  font-size: 0.84rem;
}

:root:not([data-mode="light"]) .facts-grid__cell {
  background: rgba(255,255,255,0.015);
}

.facts-grid__cell span { color: var(--muted); }
.facts-grid__cell strong { font-weight: 600; text-align: end; }

/* Renter signals */
.renter-signals { border: 1px solid var(--surface-border); border-radius: 10px; overflow: hidden; }
.renter-signals .panel-header { margin: 0; }

.renter-details__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1px;
  background: var(--surface-border);
}

.renter-cell {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 12px 14px;
  background: var(--surface-layer-2);
}

.renter-cell__value { font-size: 0.84rem; font-weight: 600; line-height: 1.3; color: var(--ink-soft); }
.renter-cell__value.is-positive { color: var(--accent-bright); }
.renter-cell__value.is-negative { color: var(--muted); }
.renter-cell__label { font-size: 0.67rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); }

/* ── Amenities tab ── */

.amenities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
}

.amenity-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  border-radius: 9px;
  border: 1px solid var(--surface-border);
  background: rgba(0,0,0,0.013);
  font-size: 0.84rem;
}

:root:not([data-mode="light"]) .amenity-item {
  background: rgba(255,255,255,0.016);
}

.amenity-check {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: rgba(1,166,82,0.12);
  display: grid;
  place-items: center;
  color: var(--accent-bright);
  flex-shrink: 0;
}

.amenity-check svg {
  width: 12px; height: 12px;
  stroke: currentColor; stroke-width: 2.5; fill: none;
}

/* ── Location tab ── */

.listing-mini-map {
  height: clamp(220px, 28vw, 300px);
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--surface-border);
  background: #d8e0ea;
}

.listing-mini-map.leaflet-container { font: inherit; touch-action: pan-y; }

.listing-mini-map .leaflet-control-attribution {
  background: rgba(255,255,255,0.78);
  padding: 2px 6px;
  font-size: 0.62rem;
}

:root:not([data-mode="light"]) .listing-mini-map .leaflet-control-attribution {
  background: rgba(18,25,31,0.76);
}

.map-area-placeholder {
  padding: 32px 16px;
  text-align: center;
  font-size: 0.84rem;
  color: var(--muted);
  background: var(--surface-layer-1);
  border: 1px solid var(--surface-border);
  border-radius: 10px;
}

.commute-section { display: flex; flex-direction: column; gap: 10px; }

.commute-title {
  margin: 0;
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.commute-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }

.commute-item {
  background: var(--surface-layer-1);
  border: 1px solid var(--surface-border);
  border-radius: var(--control-radius-tight);
  padding: 10px 8px;
  display: grid;
  gap: 4px;
  text-align: center;
}

.commute-val   { font-size: 0.88rem; font-weight: 700; color: var(--ink); line-height: 1.2; }
.commute-label { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); }
.commute-empty { margin: 0; font-size: 0.84rem; color: var(--muted); }

.map-footer { display: flex; gap: 8px; }

.map-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 9px 16px;
  border-radius: var(--control-radius);
  font-size: 0.84rem;
  font-weight: 600;
  text-decoration: none;
  transition: background-color 0.15s ease, border-color 0.15s ease;
  border: 1px solid transparent;
  flex: 1;
  text-align: center;
  white-space: nowrap;
}

.map-btn--primary  { background: var(--accent); color: var(--white); border-color: var(--accent); }
.map-btn--primary:hover { background: var(--accent-soft); border-color: var(--accent-soft); }
.map-btn--outline  { background: var(--surface-layer-1); color: var(--ink-soft); border-color: var(--surface-border); }
.map-btn--outline:hover { border-color: var(--accent); color: var(--accent); }

/* ── Similar tab ── */

.similar-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.similar-card {
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--surface-border);
  background: rgba(0,0,0,0.013);
  display: flex;
  flex-direction: column;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

:root:not([data-mode="light"]) .similar-card { background: rgba(255,255,255,0.015); }

.similar-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }

.similar-card__media {
  display: block;
  aspect-ratio: 16 / 10;
  background: var(--surface-layer-1);
  overflow: hidden;
  flex-shrink: 0;
}

.similar-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; }

.similar-card__body {
  padding: 10px 12px;
  display: grid;
  gap: 4px;
}

.similar-card__title {
  font-size: 0.84rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--ink);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.similar-card__title:hover { color: var(--accent-bright); }

/* ── Sticky sidebar ── */

.detail-sidebar {
  position: sticky;
  top: 74px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 20px 20px 40px;
  align-self: start;
}

.sidebar-card {
  background: var(--surface-layer-2);
  border: 1px solid var(--surface-border);
  border-radius: var(--control-radius);
  box-shadow: var(--panel-shadow);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  overflow: hidden;
}

/* ── Panel headers (shared by agent/cost/market/invest) ── */

.panel-header {
  margin: 0;
  font-family: "Outfit", sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
  padding: 9px 14px;
  border-bottom: 1px solid var(--surface-border);
  background: var(--ink-faint);
}

/* ── Agent card ── */

.sidebar-agent { overflow: hidden; }

.agent-card-top {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 14px 12px;
  border-bottom: 1px solid var(--surface-border);
  background: linear-gradient(135deg, rgba(1,166,82,0.06) 0%, transparent 60%);
}

.agent-avatar {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 2px solid rgba(1,166,82,0.3);
  overflow: hidden;
  background: var(--surface-layer-1);
  display: grid;
  place-items: center;
  font-family: "Cormorant Garamond", serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--accent-bright);
}

.agent-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }

.agent-identity { display: grid; gap: 2px; min-width: 0; }

.agent-name {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1.2;
  display: inline-flex;
  align-items: center;
  color: var(--ink);
  transition: color 0.15s ease;
}

.agent-name:hover { color: var(--accent-bright); }
.agent-role-text  { margin: 0; font-size: 0.78rem; color: var(--muted); }

.agent-company {
  margin: 1px 0 0;
  font-size: 0.66rem;
  color: var(--accent-bright);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.agent-card-mid { border-bottom: 1px solid var(--surface-border); }

.agent-phone {
  display: flex;
  align-items: center;
  padding: 9px 14px;
  font-size: 0.84rem;
  font-weight: 600;
  color: inherit;
  border-bottom: 1px solid var(--surface-border);
  text-decoration: none;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.agent-phone:hover { background: var(--surface-layer-1); color: var(--accent-bright); }

.agent-listings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 14px;
  font-size: 0.82rem;
  color: var(--muted);
}

.agent-listings-badge {
  background: var(--chip-bg);
  border: 1px solid var(--chip-border);
  border-radius: 999px;
  min-height: 36px;
  padding: 6px 12px;
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--accent-bright);
  text-decoration: none;
  transition: background-color 0.15s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.agent-listings-badge:hover { background: rgba(1,166,82,0.1); }

.agent-card-btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7px;
  padding: 11px 12px;
}

.agent-card-btns > :first-child { grid-column: 1 / -1; text-decoration: none; }

.agent-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 9px 6px;
  border-radius: var(--control-radius);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid transparent;
  font-family: inherit;
  transition: background-color 0.15s ease, border-color 0.15s ease;
  white-space: nowrap;
}

.agent-btn--primary  { background: #25d366; color: #fff; border-color: #25d366; }
.agent-btn--primary:hover  { background: #1ebe57; border-color: #1ebe57; }
.agent-btn--outline  { background: var(--surface-layer-1); color: var(--ink-soft); border-color: var(--surface-border); }
.agent-btn--outline:hover  { border-color: var(--accent-bright); color: var(--accent-bright); }

/* ── Cost, Market, Investment cards ── */

.cost-rows,
.market-rows,
.invest-rows { list-style: none; margin: 0; padding: 0; }

.cost-rows li,
.market-rows li,
.invest-rows li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  font-size: 0.84rem;
  border-bottom: 1px solid var(--surface-border);
}

.cost-rows li:last-child,
.market-rows li:last-child,
.invest-rows li:last-child { border-bottom: none; }

.cost-rows li > span,
.market-rows li > span,
.invest-rows li > span { color: var(--muted); flex: 1 1 auto; }

.cost-rows li strong,
.market-rows li strong,
.invest-rows li strong { font-weight: 600; text-align: end; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }

.cost-highlight { color: var(--accent-bright); font-size: 1rem; }

.cost-note,
.invest-note {
  margin: 0;
  padding: 8px 14px;
  background: var(--surface-layer-1);
  border-top: 1px solid var(--surface-border);
  font-size: 0.72rem;
  color: var(--muted);
  font-style: italic;
  line-height: 1.5;
}

.invest-note a,
.market-rows li a {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-color: transparent;
  transition: text-decoration-color 0.15s ease;
}

.invest-note a:hover,
.market-rows li a:hover { text-decoration-color: var(--accent); }

.invest-yield { color: var(--accent-bright); font-size: 1.05rem; }

.diff-badge { font-size: 0.7rem; font-weight: 600; padding: 2px 7px; border-radius: 999px; white-space: nowrap; }
.diff-above { background: rgba(180,35,24,0.1); color: #b42318; }
.diff-below { background: var(--chip-bg); color: var(--accent-bright); }
.diff-same  { background: var(--surface-layer-1); color: var(--muted); }

/* ── Mobile sticky CTA bar ── */

.mobile-detail-cta {
  display: none;
  position: fixed;
  bottom: 0;
  inset-inline-start: 0;
  inset-inline-end: 0;
  z-index: var(--z-overlay);
  background: var(--glass-bg, rgba(255,255,255,0.88));
  backdrop-filter: blur(16px) saturate(1.6);
  -webkit-backdrop-filter: blur(16px) saturate(1.6);
  border-top: 1px solid var(--surface-border);
  padding: 6px 12px calc(6px + env(safe-area-inset-bottom));
  gap: 6px;
  transform: translateY(0);
  transition: transform var(--dur-instant, 0.2s) var(--ease-spring, ease);
  will-change: transform;
}

/* Scroll-direction-aware auto-hide: JS toggles `is-hidden` on scroll-down,
   removes it at rest / scroll-up. Respect reduced-motion users by never
   translating off-screen (.is-hidden below has a guard). */
.mobile-detail-cta.is-hidden {
  transform: translateY(calc(100% + env(safe-area-inset-bottom)));
}

@media (prefers-reduced-motion: reduce) {
  .mobile-detail-cta,
  .mobile-detail-cta.is-hidden {
    transform: none;
    transition: none;
  }
}

:root:not([data-mode="light"]) .mobile-detail-cta {
  background: rgba(13,18,21,0.9);
}

.mobile-cta-btn {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 40px;
  padding: 8px 10px;
  border-radius: 9px;
  font-size: 0.8rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  border: 1px solid transparent;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color 0.15s ease;
}

.mobile-cta-btn--primary { background: var(--accent-bright); color: #fff; border-color: var(--accent-bright); }
.mobile-cta-btn--primary:hover { background: rgba(1,166,82,0.85); }
.mobile-cta-btn--wa { background: transparent; color: #25d366; border-color: rgba(37,211,102,0.3); }
.mobile-cta-btn--wa:hover { background: rgba(37,211,102,0.08); }
.mobile-cta-btn--outline { background: var(--surface-layer-1); color: var(--ink-soft); border-color: var(--surface-border); }
.mobile-cta-btn--outline:hover { border-color: var(--accent-bright); color: var(--accent-bright); }

/* ── Leaflet price pin ── */

.leaflet-div-icon.mini-price-pin-icon {
  background: transparent;
  border: none;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.mini-price-pin {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 96px;
  padding: 9px 14px;
  border-radius: 999px;
  border: 1px solid var(--mini-pin-border);
  background: var(--mini-pin-bg);
  box-shadow: var(--mini-pin-shadow);
  color: var(--mini-pin-text);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.mini-price-pin::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -7px;
  width: 13px;
  height: 13px;
  background: var(--mini-pin-bg);
  border-right: 1px solid var(--mini-pin-border);
  border-bottom: 1px solid var(--mini-pin-border);
  transform: translateX(-50%) rotate(45deg);
}

.mini-price-pin__ring {
  position: absolute;
  inset: -8px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,0.62);
  opacity: 0.72;
}

:root:not([data-mode="light"]) .mini-price-pin__ring { border-color: rgba(224,236,249,0.44); }

.mini-map-popup { display: grid; gap: 2px; color: #1b2430; font-family: "Outfit", sans-serif; font-size: 0.76rem; }
.mini-map-popup strong { font-size: 0.8rem; }
.mini-map-popup span { color: rgba(27,36,48,0.78); }
:root:not([data-mode="light"]) .mini-map-popup { color: #edf5fd; }
:root:not([data-mode="light"]) .mini-map-popup span { color: rgba(237,245,253,0.76); }

/* ── Lightbox ── */

.lightbox {
  position: fixed;
  inset: 0;
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  margin: 0;
  padding: 0;
  background: rgba(4,8,5,0.94);
  border: none;
  display: none;
  place-items: center;
  z-index: var(--z-modal);
}

.lightbox[open] { display: grid; }

.lightbox__img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
  border-radius: calc(var(--control-radius) + 2px);
  display: block;
}

.lightbox__close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 40px;
  height: 40px;
  border-radius: var(--control-radius);
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.08);
  color: var(--white);
  display: grid;
  place-items: center;
  cursor: pointer;
}

.lightbox__close svg { width: 18px; height: 18px; stroke: currentColor; stroke-width: 2; fill: none; }

.lightbox__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: var(--control-radius-tight);
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.08);
  color: var(--white);
  font-size: 1.6rem;
  display: grid;
  place-items: center;
  cursor: pointer;
}

.lightbox__prev { inset-inline-start: 16px; }
.lightbox__next { inset-inline-end: 16px; }

.lightbox__nav:focus-visible,
.lightbox__close:focus-visible { outline: 2px solid rgba(255,255,255,0.9); outline-offset: 2px; }

.lightbox__counter {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,0.65);
  font-size: 0.82rem;
  margin: 0;
}

.lightbox::backdrop { background: transparent; }

/* ── Recommendations ── */

.recommendations {
  max-width: 1240px;
  margin: 0 auto;
  padding: 16px clamp(16px, 3.5vw, 48px) clamp(32px, 4vw, 56px);
  width: 100%;
  display: grid;
  gap: 14px;
}

.recommendations-head { display: grid; gap: 4px; }

.recommendations-head h2 {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(1.35rem, 2.4vw, 1.85rem);
}

.recommendations-head p { margin: 0; color: var(--muted); }

.recommendation-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
}

.recommendation-card {
  border-radius: calc(var(--control-radius) + 2px);
  overflow: hidden;
  border: 1px solid var(--surface-border);
  background: var(--surface-layer-2);
  box-shadow: var(--panel-shadow);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.recommendation-card:hover { transform: translateY(-2px); box-shadow: 0 16px 32px rgba(12,13,12,0.14); }

.recommendation-media {
  display: block;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, rgba(198,212,197,0.76), rgba(244,239,230,0.78));
}

.recommendation-media img { width: 100%; height: 100%; display: block; object-fit: cover; }

.recommendation-fallback {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  color: var(--muted);
  font-size: 0.9rem;
}

.recommendation-body { padding: 10px 11px 12px; display: grid; gap: 5px; }

.recommendation-tag {
  width: fit-content;
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 3px 7px;
  border-radius: 999px;
  background: var(--chip-bg);
  border: 1px solid var(--chip-border);
}

.recommendation-body h3 { margin: 0; font-size: 0.94rem; }
.recommendation-body h3 a { display: inline-flex; align-items: center; min-height: 44px; }
.recommendation-meta,
.recommendation-area,
.recommendation-agent { margin: 0; font-size: 0.8rem; color: var(--muted); }
.recommendation-price { margin: 0; font-size: 0.88rem; font-weight: 700; }

.recommendations-empty {
  margin: 0;
  padding: 16px;
  background: var(--surface-layer-1);
  border: 1px solid var(--surface-border);
  border-radius: var(--control-radius);
  color: var(--muted);
}

/* ── Modals ── */

.listing-modal {
  position: fixed;
  inset: 0;
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  margin: 0;
  padding: 0;
  background: transparent;
  border: none;
  display: none;
  place-items: center;
  z-index: var(--z-modal);
}

.listing-modal[open] { display: grid; }

.listing-modal::backdrop {
  background: rgba(4,8,12,0.72);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  animation: m-fade-in var(--dur-slow) ease-out both;
}

.listing-modal[open] {
  animation: m-fade-in var(--dur-normal) ease-out both;
}

.listing-modal[open] .listing-modal__inner {
  animation: m-fade-scale var(--dur-normal) var(--ease-out) both;
}

.listing-modal__inner {
  position: relative;
  width: min(480px, calc(100vw - 32px));
  max-height: min(92vh, 720px);
  overflow-y: auto;
  background: var(--surface-layer-2);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  border: 1px solid var(--surface-border);
  border-radius: calc(var(--control-radius) + 4px);
  box-shadow: var(--panel-shadow-strong);
  padding: 24px;
}

.listing-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 32px;
  height: 32px;
  border-radius: var(--control-radius-tight);
  border: 1px solid var(--surface-border);
  background: var(--surface-layer-1);
  color: var(--muted);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: color 0.15s ease;
}

.listing-modal__close:hover { color: var(--ink); }
.listing-modal__close svg { width: 16px; height: 16px; stroke: currentColor; stroke-width: 2; fill: none; }

.listing-modal__title {
  margin: 0 40px 18px 0;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.4rem;
  font-weight: 600;
}

.listing-modal__body { display: grid; gap: 0; }
.modal-field { display: grid; gap: 5px; margin-bottom: 14px; }

.modal-field label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.modal-field input,
.modal-field textarea {
  width: 100%;
  padding: 9px 12px;
  background: var(--surface-layer-1);
  border: 1px solid var(--surface-border);
  border-radius: var(--control-radius-tight);
  font-family: inherit;
  font-size: 0.9rem;
  color: var(--ink);
  outline: none;
  transition: border-color 0.15s ease;
}

.modal-field input:focus,
.modal-field textarea:focus { border-color: var(--accent); }

.modal-field textarea { resize: vertical; min-height: 80px; }

.modal-radio-group {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.modal-radio {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 44px;
  padding: 8px 10px;
  border: 1px solid rgba(21, 128, 61, 0.18);
  border-radius: var(--control-radius-tight);
  background: rgba(21, 128, 61, 0.06);
  color: var(--ink);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
}

.modal-radio input { margin: 0; accent-color: var(--accent); }
.modal-radio span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.modal-contact-note { margin: -6px 0 12px; font-size: 0.76rem; color: var(--muted); }
.modal-error { margin: 0 0 10px; font-size: 0.82rem; color: #b42318; min-height: 1.2em; }

.modal-submit {
  width: 100%;
  justify-content: center;
  background: var(--accent);
  color: var(--white);
  border: 1px solid var(--accent);
  border-radius: var(--control-radius);
  padding: 11px;
  font-weight: 600;
  font-size: 0.92rem;
  cursor: pointer;
  transition: background-color 0.15s ease;
  display: flex;
  align-items: center;
}

.modal-submit:hover    { background: var(--accent-soft); border-color: var(--accent-soft); }
.modal-submit:disabled { opacity: 0.6; cursor: not-allowed; }

.time-slot-group { display: flex; gap: 8px; flex-wrap: wrap; }

.time-slot {
  padding: 7px 16px;
  border-radius: 999px;
  border: 1px solid var(--surface-border);
  background: var(--surface-layer-1);
  font-size: 0.84rem;
  font-weight: 500;
  color: var(--ink-soft);
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.time-slot:hover { border-color: var(--accent); color: var(--accent); }

.time-slot.is-selected {
  background: var(--chip-bg);
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 600;
}

.modal-success { display: grid; place-items: center; text-align: center; gap: 10px; padding: 24px 8px; }

.modal-success__icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--chip-bg);
  display: grid;
  place-items: center;
}

.modal-success__icon svg { width: 24px; height: 24px; stroke: var(--accent); stroke-width: 2; fill: none; }
.modal-success h3 { margin: 0; font-family: "Cormorant Garamond", serif; font-size: 1.3rem; }
.modal-success p  { margin: 0; color: var(--muted); font-size: 0.88rem; }

/* ── Animations ── */

@keyframes listingWaveDriftA {
  0%   { transform: translate3d(-9%, 4%, 0) scale(1.02); }
  100% { transform: translate3d(8%, -3%, 0) scale(1.12); }
}

@keyframes listingWaveDriftB {
  0%   { transform: translate3d(8%, 3%, 0) scale(1.03); }
  100% { transform: translate3d(-7%, -4%, 0) scale(1.11); }
}

/* ── Responsive ── */

@media (max-width: 1060px) {
  .detail-body-grid { grid-template-columns: 1fr 270px; }
}

@media (max-width: 860px) {
  .detail-card__head { padding: 20px 20px 16px; }
  .detail-card__head { flex-direction: column; gap: 12px; }
  .detail-card__price-col { text-align: start; }
  .pill-row { justify-content: flex-start; }

  .detail-tabs-bar { padding: 0 16px; }
  .detail-panels { padding: 20px 16px 32px; }
  .detail-sidebar { padding: 16px 16px 32px; }

  .detail-body-grid { grid-template-columns: 1fr; }
  .detail-panels { border-inline-end: none; border-bottom: 1px solid var(--surface-border); }
  .detail-sidebar { position: static; }

  .similar-grid { grid-template-columns: 1fr; }

  .page::before,
  .page::after { inset: auto -24% 0; height: clamp(260px, 55vw, 420px); }

  .gallery {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    height: clamp(260px, 56vw, 380px);
  }

  .gallery-main {
    grid-column: 1;
    grid-row: 1;
    height: 100%;
  }

  /* Hide thumb grid on mobile (CTA bar covers contact, lightbox covers gallery) */
  .gallery-thumbs { display: none; }

  .content-zone { margin-top: -28px; }
}

@media (max-width: 640px) {
  .stat-rail { flex-wrap: wrap; }
  .stat-rail__cell { flex: 1 1 calc(25% - 1px); min-width: 64px; }

  .facts-grid { grid-template-columns: 1fr; }
  .similar-grid { grid-template-columns: 1fr; }
  .amenities-grid { grid-template-columns: 1fr 1fr; }

  .recommendation-grid { grid-template-columns: 1fr; }
  .listing-mini-map { height: 220px; }
  .map-footer { flex-direction: column; }
  .modal-radio-group { grid-template-columns: 1fr; }
}

/* Show mobile CTA bar on small screens */
@media (max-width: 860px) {
  .mobile-detail-cta { display: flex; }
}

@media (prefers-reduced-motion: reduce) {
  .page::before,
  .page::after { animation: none; }
}

/* Dark mode button contrast fix */
:root:not([data-mode="light"]) .map-btn--primary,
:root:not([data-mode="light"]) .modal-submit {
  color: rgba(13, 18, 21, 0.95);
}
