:root {
  --bg: #faf7f2;
  --surface: #ffffff;
  --surface2: #f3eee5;
  --border: #e3dccd;
  --text: #2a2620;
  --text-dim: #6b6357;
  --accent: #b97a3c;
  --accent-dark: #8c5826;
  --green: #4a7d4a;
}

* { margin:0; padding:0; box-sizing:border-box; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

a { color:var(--accent-dark); }

.wrap {
  max-width:1100px;
  margin:0 auto;
  padding:32px 22px 60px;
}

/* ── Hero ─────────────────────────────────────────────── */
.estate-hero {
  text-align:center;
  padding:8px 8px 26px;
  border-bottom:1px solid var(--border);
  margin-bottom:30px;
}
.estate-hero .eyebrow {
  font-size:12px;
  font-weight:700;
  color:var(--accent);
  letter-spacing:1.3px;
  text-transform:uppercase;
  margin-bottom:10px;
}
.estate-hero h1 {
  font-size:34px;
  font-weight:800;
  letter-spacing:-0.5px;
  margin-bottom:12px;
  line-height:1.15;
}
.estate-hero .blurb {
  color:var(--text-dim);
  font-size:15px;
  max-width:600px;
  margin:0 auto 18px;
  line-height:1.6;
}
.estate-hero .info-row {
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:8px;
}
.estate-hero .info-pill {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:24px;
  padding:9px 18px;
  font-size:13px;
  font-weight:600;
  color:var(--text);
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.estate-hero .info-pill .ic { color:var(--accent); }
.estate-hero .addr {
  font-size:14px;
  color:var(--text-dim);
  margin-top:18px;
}
.estate-hero .addr strong { color:var(--text); }

/* ── Section headings ────────────────────────────────────── */
.estate-section-h {
  font-size:13px;
  font-weight:700;
  color:var(--accent);
  letter-spacing:1.2px;
  text-transform:uppercase;
  margin-bottom:14px;
}

/* ── Feature highlight grid ────────────────────────────────── */
.feature-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
  gap:10px;
  margin-bottom:30px;
}
.feature-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:10px;
  padding:14px 14px 12px;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:stretch;
}
.feature-card .fhead { display:flex; gap:10px; align-items:center; }
.feature-card .fic { font-size:24px; line-height:1; }
.feature-card .ftxt { flex:1; min-width:0; }
.feature-card .ftitle { font-size:13.5px; font-weight:700; margin-bottom:2px; line-height:1.2; }
.feature-card .fsub { font-size:11.5px; color:var(--text-dim); line-height:1.35; }
.feature-card.clickable {
  cursor:pointer;
  transition:border-color 0.12s, box-shadow 0.12s, transform 0.12s;
}
.feature-card.clickable:hover {
  border-color:var(--accent);
  box-shadow:0 3px 10px rgba(0,0,0,0.05);
  transform:translateY(-1px);
}
.feature-card.clickable.active {
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent) inset;
}
.feature-card .fhint {
  display:flex;
  align-items:center;
  gap:5px;
  font-size:11.5px;
  font-weight:600;
  color:var(--accent-dark);
  margin-top:2px;
}
.feature-card .fhint .fchev { transition:transform 0.18s; }
.feature-card.clickable.active .fhint .fchev { transform:rotate(90deg); }
.feature-card .fhint.soon {
  color:var(--text-dim);
  font-weight:600;
  opacity:0.75;
}
.feature-card.no-photos { cursor:default; }

/* ── Curated showcase panel ─────────────────────────────────── */
.estate-showcase { margin-bottom:32px; }
.showcase-panel {
  border:1px solid var(--accent);
  border-radius:12px;
  overflow:hidden;
  background:linear-gradient(180deg, var(--surface), var(--surface2));
  animation:showcaseIn 0.22s ease;
}
@keyframes showcaseIn {
  from { opacity:0; transform:translateY(-6px); }
  to { opacity:1; transform:translateY(0); }
}
.showcase-head { display:flex; align-items:flex-start; gap:12px; padding:16px 18px 12px; }
.showcase-head .schic { font-size:30px; line-height:1; }
.showcase-head .schtxt { flex:1; min-width:0; }
.showcase-head .schtitle { font-size:17px; font-weight:800; letter-spacing:-0.2px; line-height:1.2; }
.showcase-head .schdesc { font-size:13px; color:var(--text-dim); line-height:1.55; margin-top:5px; }
.showcase-close {
  flex:0 0 auto;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:16px;
  padding:5px 12px;
  font-size:12px;
  font-weight:600;
  color:var(--text-dim);
  cursor:pointer;
  font-family:inherit;
}
.showcase-close:hover { color:var(--text); border-color:var(--accent); }
.showcase-gallery {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(150px, 1fr));
  gap:8px;
  padding:0 18px 18px;
}
.fgthumb {
  padding:0;
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  cursor:pointer;
  background:var(--surface);
  display:flex;
  flex-direction:column;
  text-align:left;
  font-family:inherit;
  transition:border-color 0.12s, box-shadow 0.12s, transform 0.12s;
}
.fgthumb .fgimg {
  display:block;
  aspect-ratio:1/1;
  overflow:hidden;
  background:var(--surface2);
}
.fgthumb .fgimg img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform 0.18s ease;
}
.fgthumb .fgcap {
  display:block;
  font-size:11px;
  line-height:1.3;
  font-weight:600;
  color:var(--text-dim);
  padding:6px 8px 8px;
}
.fgthumb:hover {
  border-color:var(--accent);
  box-shadow:0 3px 10px rgba(0,0,0,0.06);
  transform:translateY(-1px);
}
.fgthumb:hover .fgcap { color:var(--text); }
.fgthumb:hover .fgimg img { transform:scale(1.05); }

/* ── Feature lightbox ─────────────────────────────────────── */
.feat-lightbox {
  position:fixed;
  inset:0;
  background:rgba(20,18,15,0.85);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:400;
}
.feat-lightbox.open { display:flex; }
.feat-lightbox img {
  max-width:92vw;
  max-height:86vh;
  border-radius:8px;
  box-shadow:0 8px 40px rgba(0,0,0,0.5);
  object-fit:contain;
}
.feat-lb-close {
  position:absolute;
  top:16px;
  right:20px;
  background:rgba(0,0,0,0.4);
  border:none;
  color:#fff;
  font-size:26px;
  line-height:1;
  width:42px;
  height:42px;
  border-radius:50%;
  cursor:pointer;
}
.feat-lb-nav {
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(0,0,0,0.4);
  border:none;
  color:#fff;
  font-size:30px;
  line-height:1;
  width:50px;
  height:50px;
  border-radius:50%;
  cursor:pointer;
}
.feat-lb-nav.prev { left:16px; }
.feat-lb-nav.next { right:16px; }
.feat-lb-count {
  position:absolute;
  bottom:20px;
  left:50%;
  transform:translateX(-50%);
  color:#fff;
  font-size:13px;
  background:rgba(0,0,0,0.4);
  padding:5px 12px;
  border-radius:14px;
}
.feat-lb-cap {
  position:absolute;
  bottom:52px;
  left:50%;
  transform:translateX(-50%);
  max-width:90vw;
  text-align:center;
  color:#fff;
  font-size:13.5px;
  font-weight:600;
  line-height:1.4;
  background:rgba(0,0,0,0.45);
  padding:7px 14px;
  border-radius:8px;
}
.feat-lb-cap:empty { display:none; }

/* ── Browse items: filter + grid ─────────────────────────── */
.estate-filter {
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  align-items:center;
  margin-bottom:16px;
}
.estate-filter .label {
  font-size:11.5px;
  color:var(--text-dim);
  margin-right:4px;
  text-transform:uppercase;
  letter-spacing:0.6px;
}
.estate-chip {
  padding:6px 13px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--surface);
  font-size:12.5px;
  font-weight:600;
  color:var(--text-dim);
  cursor:pointer;
  font-family:inherit;
}
.estate-chip:hover { color:var(--text); }
.estate-chip.active {
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}

.estate-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(170px, 1fr));
  gap:11px;
}
.estate-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  cursor:pointer;
  transition:transform 0.12s, box-shadow 0.12s, border-color 0.12s;
  display:flex;
  flex-direction:column;
}
.estate-card:hover {
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(0,0,0,0.06);
  border-color:var(--accent);
}
.estate-card .ephoto {
  background:var(--surface2);
  aspect-ratio:1/1;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--text-dim);
  font-size:28px;
  overflow:hidden;
}
.estate-card .ephoto img { width:100%; height:100%; object-fit:cover; display:block; }
.estate-card .ebody {
  padding:9px 11px 11px;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:3px;
}
.estate-card .ename {
  font-weight:600;
  font-size:13px;
  line-height:1.3;
  color:var(--text);
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.estate-card .ecat {
  font-size:10.5px;
  color:var(--text-dim);
  text-transform:uppercase;
  letter-spacing:0.5px;
}

.estate-empty {
  grid-column:1/-1;
  text-align:center;
  padding:40px 20px;
  color:var(--text-dim);
}

/* ── Item modal ───────────────────────────────────────────── */
.estate-modal-bg {
  position:fixed;
  inset:0;
  background:rgba(20,18,15,0.55);
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
  z-index:300;
}
.estate-modal-bg.open { display:flex; }
.estate-modal {
  background:#fff;
  color:#2a2620;
  border-radius:12px;
  max-width:520px;
  width:100%;
  max-height:90vh;
  overflow-y:auto;
  border:1px solid #e3dccd;
}
.estate-modal .ehead {
  padding:18px 20px 12px;
  border-bottom:1px solid #e3dccd;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.estate-modal .ehead h3 { font-size:18px; line-height:1.3; font-weight:700; }
.estate-modal .eclose {
  background:none;
  border:none;
  font-size:24px;
  color:#6b6357;
  padding:0;
  line-height:1;
  cursor:pointer;
}
.estate-modal .embody { padding:14px 20px 22px; }
.estate-modal .emphoto {
  background:#f3eee5;
  aspect-ratio:4/3;
  border-radius:8px;
  margin-bottom:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#6b6357;
  font-size:44px;
  overflow:hidden;
}
.estate-modal .emphoto img { width:100%; height:100%; object-fit:contain; background:#0a0807; }
.estate-modal .emthumbs {
  display:flex;
  gap:6px;
  margin-bottom:12px;
  overflow-x:auto;
  padding-bottom:4px;
}
.estate-modal .emthumb {
  flex:0 0 auto;
  width:54px;
  height:54px;
  border-radius:6px;
  overflow:hidden;
  border:2px solid #e3dccd;
  cursor:pointer;
  padding:0;
  background:#f3eee5;
}
.estate-modal .emthumb img { width:100%; height:100%; object-fit:cover; display:block; }
.estate-modal .emthumb.active { border-color:#b97a3c; }
.estate-modal .emcat {
  font-size:11px;
  color:#6b6357;
  text-transform:uppercase;
  letter-spacing:0.6px;
  margin-bottom:6px;
  font-weight:700;
}
.estate-modal .emdesc { font-size:13.5px; line-height:1.55; color:#2a2620; }
.estate-modal .emnote {
  font-size:12px;
  color:#6b6357;
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid #e3dccd;
  font-style:italic;
}

/* ── Hero call-to-action / directions button ───────────────── */
.hero-cta {
  margin-top:18px;
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
}
.btn-directions {
  display:inline-flex;
  align-items:center;
  gap:7px;
  background:var(--accent);
  color:#fff;
  border:1px solid var(--accent);
  border-radius:24px;
  padding:11px 22px;
  font-size:14px;
  font-weight:700;
  text-decoration:none;
  box-shadow:0 2px 8px rgba(185,122,60,0.25);
  transition:background 0.14s, transform 0.12s, box-shadow 0.14s;
}
.btn-directions .ic { font-size:15px; }
.btn-directions:hover {
  background:var(--accent-dark);
  border-color:var(--accent-dark);
  color:#fff;
  transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(185,122,60,0.32);
}
.btn-directions.small {
  padding:8px 16px;
  font-size:12.5px;
  background:var(--surface);
  color:var(--accent-dark);
  border-color:var(--border);
  box-shadow:none;
}
.btn-directions.small:hover {
  background:var(--surface);
  border-color:var(--accent);
  color:var(--accent-dark);
  box-shadow:none;
  transform:none;
}

/* ── Share buttons ─────────────────────────────────────────── */
/* Prominent share call-to-action band (sits above "What You'll Find") */
.estate-share {
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:12px;
  padding:16px;
  margin-bottom:30px;
}
.share-section {
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:11px;
}
.share-heading {
  font-size:13px;
  font-weight:700;
  color:var(--text);
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.share-heading .ic { color:var(--accent); }
.share-bar {
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
}
.share-btn {
  display:inline-flex;
  align-items:center;
  gap:7px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  border-radius:22px;
  padding:8px 15px;
  font-size:12.5px;
  font-weight:600;
  font-family:inherit;
  text-decoration:none;
  cursor:pointer;
  transition:border-color 0.12s, background 0.12s, color 0.12s, transform 0.12s;
}
.share-btn svg { width:16px; height:16px; fill:currentColor; flex:0 0 auto; }
.share-btn:hover { transform:translateY(-1px); border-color:var(--accent); }
.share-btn.fb:hover { background:#1877F2; border-color:#1877F2; color:#fff; }
.share-btn.instagram:hover {
  background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  border-color:#dc2743;
  color:#fff;
}
.share-btn.whatsapp:hover { background:#25D366; border-color:#25D366; color:#fff; }
.share-btn.email:hover { background:var(--accent); border-color:var(--accent); color:#fff; }
.share-btn.copy:hover { background:var(--surface); border-color:var(--accent); }
.share-btn.native { color:var(--text-dim); }
.share-btn.native:hover { background:var(--surface2); border-color:var(--accent); color:var(--text); }
.share-section.flash .share-bar { animation:sharePulse 1.1s ease; }
@keyframes sharePulse { 0%,100%{transform:scale(1);} 30%{transform:scale(1.04);} }

.share-toast {
  position:fixed;
  left:50%;
  bottom:28px;
  transform:translateX(-50%) translateY(18px);
  background:var(--text);
  color:#fff;
  padding:10px 18px;
  border-radius:20px;
  font-size:13px;
  font-weight:600;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.2s, transform 0.2s;
  z-index:500;
}
.share-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ── Notices / announcements band ──────────────────────────── */
.estate-notes {
  display:grid;
  gap:10px;
  margin-bottom:32px;
}
.note-card {
  display:flex;
  gap:11px;
  align-items:flex-start;
  background:var(--surface);
  border:1px solid var(--border);
  border-left:3px solid var(--border);
  border-radius:10px;
  padding:13px 15px;
  font-size:13px;
  line-height:1.5;
  color:var(--text-dim);
}
.note-card strong { color:var(--text); font-weight:700; }
.note-card .note-ic { font-size:18px; line-height:1.4; flex:0 0 auto; }
.note-card .note-body { flex:1; min-width:0; }
.note-live {
  border-left-color:var(--accent);
  background:linear-gradient(180deg, #ffffff, var(--surface2));
}
.note-stamp {
  display:block;
  margin-top:7px;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.4px;
  text-transform:uppercase;
  color:var(--accent-dark);
}

/* ── Section subtitle ──────────────────────────────────────── */
.estate-section-sub {
  font-size:12.5px;
  color:var(--text-dim);
  margin:-8px 0 16px;
}
.inline-chev { color:var(--accent-dark); font-size:10px; }

/* ── Footer ────────────────────────────────────────────────── */
.estate-footer {
  margin-top:46px;
  padding-top:26px;
  border-top:1px solid var(--border);
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:13px;
}
.estate-footer .foot-addr { font-size:13px; color:var(--text-dim); line-height:1.5; }
.estate-footer .foot-addr strong { color:var(--text); }
.estate-footer .foot-note {
  font-size:11.5px;
  color:var(--text-dim);
  max-width:520px;
  line-height:1.5;
}

@media (max-width:600px) {
  .wrap { padding:22px 16px 40px; }
  .estate-hero h1 { font-size:26px; }
  .estate-grid { grid-template-columns:repeat(2, 1fr); }
  .feature-grid { grid-template-columns:1fr 1fr; }
  .showcase-gallery { grid-template-columns:repeat(2, 1fr); }
  .feat-lb-cap { font-size:12px; bottom:48px; }
}
