/*
 * SOMA9 Real Estate — Public Styles
 * All property page styles: listing, detail, map.
 *
 * Uses --s9p-* tokens from s9-tokens.css + intermediate --bg/--text vars
 * for dark/light theme support.
 *
 * Structure:
 *   1. Theme variables (intermediate)
 *   2. Section tag (reusable pattern)
 *   3. Hero (property detail)
 *   4. Stats bar
 *   5. Gallery (horizontal draggable)
 *   6. Description + sidebar
 *   7. Features grid
 *   8. Verticales (3-col cards)
 *   9. Floor plan
 *  10. Location
 *  11. CTA section
 *  12. Sticky bar
 *  13. Property cards (listing + map panel)
 *  14. Listing page (hero, filters, grid)
 *  15. Map page (search bar, split layout, markers, popups)
 *  16. Shared buttons
 *  17. Responsive
 */

/* ═══ 1. INTERMEDIATE THEME VARS ═══ */
:root {
  --bg: var(--s9p-bg-dark);
  --bg-surface: var(--s9p-dark-mid);
  --bg-raised: var(--s9p-dark-light);
  --text-primary: var(--s9p-text-on-dark);
  --text-secondary: var(--s9p-cream-60);
  --text-muted: var(--s9p-text-subtle);
  --border-color: var(--s9p-cream-15);
  --card-bg: var(--s9p-bg-surface);
  --nav-bg: rgba(26,23,20,0.97);
}
[data-theme="light"] {
  --bg: var(--s9p-bg-alt);
  --bg-surface: var(--s9p-white);
  --bg-raised: var(--s9p-beige-light);
  --text-primary: var(--s9p-text-dark);
  --text-secondary: var(--s9p-text-muted);
  --text-muted: var(--s9p-text-subtle);
  --border-color: var(--s9p-beige-light);
  --card-bg: var(--s9p-white);
  --nav-bg: rgba(248,246,243,0.97);
}

/* ═══ 1b. DETAIL PAGE BODY OVERRIDE ═══ */
body.s9-detail-page {
  background: var(--bg) !important;
  color: var(--text-primary);
  font-family: var(--s9p-font);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  transition: background .4s, color .4s;
}
body.s9-detail-page a { text-decoration:none; color:inherit; }

/* ═══ 1c. PRIMARY BUTTON (s9-btn-primary) ═══ */
.s9-btn-primary {
  display:inline-flex; align-items:center; gap:0;
  background:var(--s9p-btn-hover) !important; color:var(--s9p-bg-dark) !important;
  padding:5px; border-radius:var(--s9p-radius-pill) !important;
  font-size:15px; font-weight:300 !important; letter-spacing:0; text-transform:capitalize !important;
  border:none; cursor:pointer; font-family:var(--s9p-font);
  position:relative; overflow:hidden; transition:none; text-decoration:none;
}
.s9-btn-primary::before {
  content:''; position:absolute; top:50%; right:5px; width:38px; height:38px;
  transform:translateY(-50%); border-radius:50%; background:var(--s9p-dark-btn);
  transition:all 0.3s var(--s9p-ease); z-index:1;
}
.s9-btn-primary:hover::before { width:calc(100% - 10px); border-radius:26px; }
.s9-btn-primary .btn-text {
  position:relative; z-index:2; padding-left:16px; margin-right:12px;
  color:var(--s9p-dark-btn); transition:color 0.3s ease; white-space:nowrap;
  font-family:var(--s9p-font); font-size:15px; font-weight:300;
}
.s9-btn-primary:hover .btn-text { color:var(--s9p-btn-hover-text); }
.s9-btn-primary .btn-icon {
  position:relative; z-index:2; display:flex; align-items:center; justify-content:center;
  width:38px; height:38px; flex-shrink:0; color:var(--s9p-btn-hover-text);
}
.s9-btn-primary .btn-icon svg { width:14px; height:14px; }
.s9-btn-primary--inverted { background:var(--s9p-dark-btn) !important; }
.s9-btn-primary--inverted::before { background:var(--s9p-btn-hover); }
.s9-btn-primary--inverted .btn-text { color:var(--s9p-text-on-dark); }
.s9-btn-primary--inverted:hover .btn-text { color:var(--s9p-text-muted); }
.s9-btn-primary--inverted .btn-icon { color:var(--s9p-text-muted); }

/* ═══ 1d. VERTICALES HEADING ═══ */
.s9-vert-heading { font-size:clamp(22px,2.5vw,38px); font-weight:600; color:var(--text-primary); line-height:1.2; letter-spacing:-.02em; margin-bottom:6px; }
.s9-vert-intro { font-size:15px; color:var(--text-secondary); font-weight:300; max-width:580px; line-height:1.75; }

/* ═══ 2. SECTION TAG ═══ */
.s9-section-tag { display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.s9-section-tag-line { width:28px; height:1px; background:var(--s9p-text-subtle); flex-shrink:0; }
.s9-section-tag span { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); font-weight:500; }

/* ═══ 3. HERO (property detail) ═══ */
.s9-hero { position:relative; height:100vh; min-height:520px; overflow:hidden; display:flex; align-items:flex-end; padding:clamp(24px,3vw,48px) var(--s9p-gutter); background:var(--s9p-bg-dark); }
.s9-hero .hero-nav { opacity:0; transform:translateY(-20px); }
.s9-hero-bg { position:absolute; inset:-60px; background-size:cover; background-position:center; opacity:.38; transform:scale(1.05); will-change:transform; }
.s9-hero-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(26,23,20,.92) 0%,rgba(26,23,20,.1) 100%); }
[data-theme="light"] .s9-hero-overlay { background:linear-gradient(to top,rgba(248,246,243,.88) 0%,rgba(248,246,243,.05) 55%); }
.s9-hero-content { position:relative; z-index:2; max-width:720px; }
.s9-hero-breadcrumb { display:flex; gap:8px; align-items:center; margin-bottom:18px; opacity:0; transform:translateY(10px); }
.s9-hero-breadcrumb a,.s9-hero-breadcrumb span { font-size:12px; color:var(--s9p-cream-60); }
.s9-hero-breadcrumb a:hover { color:var(--s9p-text-on-dark); }
.s9-hero-breadcrumb .sep { color:var(--s9p-cream-40); }
[data-theme="light"] .s9-hero-breadcrumb a,[data-theme="light"] .s9-hero-breadcrumb span { color:var(--s9p-text-muted); }
.s9-hero h1 { font-family:var(--s9p-font); font-size:clamp(38px,5.5vw,72px); font-weight:600; color:var(--s9p-text-on-dark); line-height:1.05; margin-bottom:10px; letter-spacing:-.03em; opacity:0; transform:translateY(20px); }
[data-theme="light"] .s9-hero h1 { color:var(--s9p-text-dark); }
.s9-hero-sub { font-size:clamp(15px,1.6vw,20px); font-weight:300; color:var(--s9p-cream-60); margin-bottom:28px; opacity:0; transform:translateY(12px); }
[data-theme="light"] .s9-hero-sub { color:var(--s9p-text-muted); }
.s9-hero-actions { display:flex; gap:12px; opacity:0; transform:translateY(12px); }
.s9-hero-badge { display:inline-flex; align-items:center; gap:6px; background:var(--s9p-dark-light); border:1px solid var(--s9p-cream-15); color:var(--s9p-cream-60); font-size:9px; letter-spacing:2px; text-transform:uppercase; padding:4px 12px; border-radius:3px; margin-bottom:14px; font-weight:500; }
.s9-hero-price-wrap { position:absolute; right:var(--s9p-gutter); bottom:clamp(24px,3vw,48px); z-index:2; text-align:right; opacity:0; transform:translateY(12px); }
.s9-hero-price-label { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--s9p-cream-40); display:block; margin-bottom:4px; }
.s9-hero-price { font-family:var(--s9p-font); font-size:clamp(28px,3vw,44px); font-weight:600; color:var(--s9p-text-on-dark); letter-spacing:-.02em; }
[data-theme="light"] .s9-hero-price { color:var(--s9p-text-dark); }

/* ═══ 4. STATS BAR ═══ */
.s9-stats-bar { background:var(--bg-surface); border-bottom:1px solid var(--border-color); display:grid; grid-template-columns:repeat(5,1fr); }
.s9-stat-item { padding:clamp(18px,2.5vw,28px) 0; display:flex; flex-direction:column; align-items:center; gap:5px; border-right:1px solid var(--border-color); opacity:0; transform:translateY(10px); }
.s9-stat-item:last-child { border-right:none; }
.s9-stat-icon { color:var(--s9p-text-subtle); }
.s9-stat-value { font-family:var(--s9p-font); font-size:clamp(20px,2vw,28px); font-weight:600; color:var(--text-primary); line-height:1; }
.s9-stat-label { font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); }

/* ═══ 5. GALLERY ═══ */
.s9-gallery-section { padding:clamp(52px,6vw,84px) 0; overflow:hidden; }
.s9-gallery-header { padding:0 var(--s9p-gutter); display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:clamp(24px,3vw,40px); }
.s9-gallery-header h2 { font-size:clamp(22px,2.8vw,38px); font-weight:600; color:var(--text-primary); line-height:1.2; letter-spacing:-.02em; }
.s9-gallery-count { font-size:11px; color:var(--text-muted); letter-spacing:1px; padding-bottom:4px; }
.s9-gallery-wrap { position:relative; }
.s9-gallery-track { display:flex; gap:10px; padding:0 var(--s9p-gutter); overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; cursor:grab; }
.s9-gallery-track::-webkit-scrollbar { display:none; }
.s9-gallery-track.grabbing { cursor:grabbing; scroll-behavior:auto; }
.s9-gallery-item { flex-shrink:0; scroll-snap-align:start; border-radius:var(--s9p-radius-lg); overflow:hidden; position:relative; height:380px; }
.s9-gallery-item:nth-child(1) { width:540px; }
.s9-gallery-item:nth-child(2) { width:300px; }
.s9-gallery-item:nth-child(3) { width:420px; }
.s9-gallery-item:nth-child(4) { width:340px; }
.s9-gallery-item:nth-child(5) { width:480px; }
.s9-gallery-item:nth-child(n+6) { width:400px; }
.s9-gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--s9p-ease); display:block; }
.s9-gallery-item:hover img { transform:scale(1.04); }
.s9-gallery-caption { position:absolute; bottom:12px; left:12px; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:rgba(225,216,203,.9); opacity:0; transition:opacity .3s,transform .3s; transform:translateY(4px); background:rgba(26,23,20,.6); padding:4px 10px; border-radius:3px; }
.s9-gallery-item:hover .s9-gallery-caption { opacity:1; transform:translateY(0); }

/* Gallery arrows */
.s9-gallery-arrow {
  position:absolute; top:50%; z-index:5; transform:translateY(-50%);
  width:48px; height:48px; border-radius:50%;
  background:var(--bg-surface); border:1px solid var(--border-color);
  color:var(--text-primary); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .3s var(--s9p-ease),border-color .3s var(--s9p-ease),opacity .3s,transform .3s var(--s9p-ease);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  opacity:0;
}
.s9-gallery-wrap:hover .s9-gallery-arrow { opacity:1; }
.s9-gallery-arrow:hover { background:var(--bg-raised); border-color:var(--text-muted); }
.s9-gallery-arrow--prev { left:clamp(12px,2vw,28px); }
.s9-gallery-arrow--next { right:clamp(12px,2vw,28px); }
.s9-gallery-arrow:disabled { opacity:0.25 !important; cursor:default; }
.s9-gallery-arrow svg { flex-shrink:0; }

/* ═══ 6. DESCRIPTION + SIDEBAR ═══ */
.s9-desc-section { padding:clamp(52px,7vw,92px) var(--s9p-gutter); display:grid; grid-template-columns:1fr 360px; gap:clamp(40px,5vw,80px); border-top:1px solid var(--border-color); }
.s9-desc-text { font-size:clamp(15px,1.4vw,19px); font-weight:300; color:var(--text-secondary); line-height:1.9; margin-bottom:20px; }
.s9-desc-text strong { color:var(--text-primary); font-weight:500; }
.s9-sidebar-card { background:var(--card-bg); border:1px solid var(--border-color); border-radius:var(--s9p-radius-lg); padding:26px; margin-bottom:14px; }
.s9-sidebar-label { font-size:9px; letter-spacing:2.5px; text-transform:uppercase; color:var(--text-muted); display:block; margin-bottom:14px; font-weight:500; }
.s9-sidebar-row { display:flex; justify-content:space-between; align-items:baseline; padding:10px 0; border-bottom:1px solid var(--border-color); font-size:13px; }
.s9-sidebar-row:last-child { border-bottom:none; }
.s9-sidebar-key { color:var(--text-muted); }
.s9-sidebar-val { color:var(--text-primary); font-weight:500; }
.s9-agent-card { background:var(--bg-raised); border:1px solid var(--border-color); border-radius:var(--s9p-radius-lg); padding:18px 24px; display:flex; align-items:center; gap:14px; }
.s9-agent-avatar { width:44px; height:44px; border-radius:50%; background:var(--s9p-dark-btn); border:1px solid var(--border-color); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:600; color:var(--s9p-cream-60); flex-shrink:0; }
[data-theme="light"] .s9-agent-avatar { background:var(--s9p-beige-mid); }
.s9-agent-name { font-size:14px; font-weight:500; color:var(--text-primary); display:block; margin-bottom:2px; }
.s9-agent-role { font-size:11px; color:var(--text-muted); }

/* ═══ 7. FEATURES GRID ═══ */
.s9-features-section { padding:clamp(52px,6vw,84px) var(--s9p-gutter); border-top:1px solid var(--border-color); background:var(--bg-surface); }
.s9-features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:36px; }
.s9-feature-item { padding:26px 22px; display:flex; align-items:flex-start; gap:14px; background:var(--bg); border:1px solid transparent; transition:border-color .3s,background .3s; opacity:0; transform:translateY(12px); }
.s9-feature-item:hover { border-color:var(--border-color); background:var(--bg-raised); }
.s9-feature-icon { color:var(--s9p-text-subtle); flex-shrink:0; margin-top:2px; }
.s9-feature-name { font-size:14px; font-weight:500; color:var(--text-primary); display:block; margin-bottom:4px; }
.s9-feature-detail { font-size:12px; color:var(--text-muted); line-height:1.65; font-weight:300; }

/* ═══ 8. VERTICALES ═══ */
.s9-vert-section { padding:clamp(52px,7vw,92px) var(--s9p-gutter); border-top:1px solid var(--border-color); }
.s9-vert-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:44px; }
.s9-vert-card { padding:32px 28px; border:1px solid var(--border-color); background:var(--bg-surface); transition:border-color var(--s9p-transition),background var(--s9p-transition); }
.s9-vert-card:hover { border-color:var(--s9p-cream-30); background:var(--bg-raised); }
.s9-vert-num { font-size:10px; letter-spacing:2px; color:var(--text-muted); font-weight:500; display:block; margin-bottom:20px; }
.s9-vert-title { font-size:18px; font-weight:600; color:var(--text-primary); line-height:1.2; margin-bottom:4px; letter-spacing:-.01em; }
.s9-vert-sub { font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); margin-bottom:16px; display:block; }
.s9-vert-text { font-size:13px; color:var(--text-secondary); line-height:1.75; font-weight:300; }

/* ═══ 9. FLOOR PLAN ═══ */
.s9-floorplan-section { padding:clamp(52px,7vw,92px) var(--s9p-gutter); border-top:1px solid var(--border-color); display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,5vw,72px); align-items:center; }
.s9-floorplan-img { background:var(--bg-surface); border:1px solid var(--border-color); border-radius:var(--s9p-radius-lg); aspect-ratio:4/3; overflow:hidden; display:flex; align-items:center; justify-content:center; position:relative; }
.s9-floorplan-img img { width:78%; height:78%; object-fit:contain; opacity:.5; }
.s9-floorplan-img-label { position:absolute; top:14px; left:14px; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); }
.s9-floorplan-title { font-size:clamp(22px,2.5vw,36px); font-weight:600; color:var(--text-primary); line-height:1.2; letter-spacing:-.02em; margin-bottom:12px; }
.s9-floorplan-desc { font-size:14px; color:var(--text-secondary); line-height:1.8; margin-bottom:26px; font-weight:300; }
.s9-floorplan-row { display:flex; justify-content:space-between; padding:11px 0; border-bottom:1px solid var(--border-color); font-size:13px; }
.s9-floorplan-row-name { color:var(--text-secondary); }
.s9-floorplan-row-size { font-weight:500; color:var(--text-primary); }

/* ═══ 9b. VIRTUAL TOUR ═══ */
.s9-tour-section { padding:clamp(52px,7vw,92px) var(--s9p-gutter); border-top:1px solid var(--border-color); display:grid; grid-template-columns:1fr 1.5fr; gap:clamp(40px,5vw,72px); align-items:start; }
.s9-tour-info { display:flex; flex-direction:column; justify-content:center; }
.s9-tour-title { font-size:clamp(22px,2.5vw,36px); font-weight:600; color:var(--text-primary); line-height:1.2; letter-spacing:-.02em; margin-bottom:12px; }
.s9-tour-desc { font-size:14px; color:var(--text-secondary); line-height:1.8; margin-bottom:24px; font-weight:300; }
.s9-tour-item { display:flex; align-items:center; gap:10px; padding:10px 0; border-bottom:1px solid var(--border-color); }
.s9-tour-item:first-child { border-top:1px solid var(--border-color); }
.s9-tour-item__label { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-secondary); font-weight:400; }
.s9-tour-item__label svg { color:var(--s9p-text-subtle); flex-shrink:0; }
.s9-tour-embeds { display:flex; flex-direction:column; gap:16px; }
.s9-tour-embed { position:relative; width:100%; aspect-ratio:16/9; border-radius:var(--s9p-radius-lg); overflow:hidden; background:var(--bg-surface); border:1px solid var(--border-color); }
.s9-tour-placeholder { width:100%; height:100%; cursor:pointer; position:relative; background:var(--bg-raised); display:flex; align-items:center; justify-content:center; transition:background var(--s9p-transition); }
.s9-tour-placeholder:hover { background:var(--bg-surface); }
.s9-tour-placeholder__overlay { display:flex; flex-direction:column; align-items:center; gap:14px; }
.s9-tour-placeholder__icon { width:72px; height:72px; border-radius:50%; background:rgba(225,216,203,.08); border:1px solid var(--border-color); display:flex; align-items:center; justify-content:center; color:var(--text-primary); transition:border-color var(--s9p-transition),background var(--s9p-transition); }
.s9-tour-placeholder:hover .s9-tour-placeholder__icon { border-color:var(--s9p-cream-30); background:rgba(225,216,203,.15); }
.s9-tour-placeholder__label { font-size:13px; font-weight:500; color:var(--text-secondary); letter-spacing:.5px; text-transform:uppercase; }
.s9-tour-iframe { width:100%; height:100%; border:0; display:block; }
.s9-tour-fullscreen-btn { position:absolute; top:12px; right:12px; width:36px; height:36px; border-radius:8px; background:rgba(0,0,0,.6); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.15); color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; z-index:10; transition:background .2s,border-color .2s; }
.s9-tour-fullscreen-btn:hover { background:rgba(0,0,0,.8); border-color:rgba(255,255,255,.3); }
.s9-tour-embed--fullscreen { position:fixed!important; inset:0!important; z-index:9999!important; width:100vw!important; height:100vh!important; aspect-ratio:auto!important; border-radius:0!important; border:none!important; }
.s9-tour-embed--fullscreen .s9-tour-fullscreen-btn { top:16px; right:16px; width:40px; height:40px; }

/* ═══ 10. LOCATION ═══ */
.s9-location-section { border-top:1px solid var(--border-color); display:grid; grid-template-columns:1fr 1fr; min-height:500px; }
.s9-location-info { padding:clamp(52px,7vw,92px) var(--s9p-gutter); display:flex; flex-direction:column; justify-content:center; }
.s9-location-title { font-size:clamp(22px,2.5vw,36px); font-weight:600; color:var(--text-primary); line-height:1.2; letter-spacing:-.02em; margin-bottom:14px; }
.s9-location-desc { font-size:14px; color:var(--text-secondary); line-height:1.8; margin-bottom:28px; font-weight:300; }
.s9-dist-item { display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--border-color); font-size:13px; }
.s9-dist-item:first-child { border-top:1px solid var(--border-color); }
.s9-dist-icon { color:var(--s9p-text-subtle); flex-shrink:0; }
.s9-dist-place { color:var(--text-secondary); flex:1; }
.s9-dist-time { font-weight:500; color:var(--text-primary); }
.s9-location-map { position:relative; min-height:400px; border-radius:0; overflow:hidden; }
/* Leaflet popup override — dark theme matching Google Maps popup */
.s9-leaflet-popup .leaflet-popup-content-wrapper { background:var(--s9p-dark-mid, #201d18); border:1px solid var(--s9p-cream-15, rgba(225,216,203,0.15)); border-radius:var(--s9p-radius-lg, 16px); box-shadow:0 8px 28px rgba(0,0,0,.6); padding:0; overflow:hidden; }
.s9-leaflet-popup .leaflet-popup-content { margin:0; width:210px!important; }
.s9-leaflet-popup .leaflet-popup-tip { background:var(--s9p-dark-mid, #201d18); }
.s9-leaflet-popup .leaflet-popup-close-button { color:var(--s9p-cream-40)!important; font-size:18px!important; top:6px!important; right:8px!important; }

/* ═══ 11. CTA SECTION ═══ */
.s9-cta-section { padding:clamp(80px,10vw,130px) var(--s9p-gutter); background:var(--s9p-bg-dark); position:relative; overflow:hidden; border-top:1px solid var(--s9p-cream-08); }
[data-theme="light"] .s9-cta-section { background:var(--s9p-text-dark); }
.s9-cta-bg { position:absolute; inset:0; background:radial-gradient(ellipse at 50% 160%,rgba(225,216,203,.05) 0%,transparent 65%); pointer-events:none; }
.s9-cta-content { position:relative; z-index:2; max-width:640px; }
.s9-cta-content h2 { font-size:clamp(28px,3.5vw,50px); font-weight:600; color:var(--s9p-text-on-dark); line-height:1.1; letter-spacing:-.025em; margin-bottom:14px; }
.s9-cta-sub { font-size:15px; color:var(--s9p-cream-60); line-height:1.75; margin-bottom:36px; font-weight:300; }

/* ─── 11a. CONTACT FORM ─── */
.s9-contact-form {
  margin-top:32px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  max-width:560px;
}
/* Honeypot: hidden from humans, traps bots */
.s9-form-hp {
  position:absolute !important;
  left:-9999px !important;
  top:-9999px !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}
.s9-form-field { display:flex; flex-direction:column; }
.s9-form-field--full { grid-column:1/-1; }
.s9-form-input {
  width:100%;
  padding:12px 16px;
  background:transparent;
  border:1px solid var(--s9p-cream-20, rgba(225,216,203,.2));
  border-radius:8px;
  color:var(--s9p-text-on-dark, #e1d8cb);
  font-family:var(--s9p-font);
  font-size:14px;
  outline:none;
  transition:border-color .25s ease, box-shadow .25s ease;
}
.s9-form-input::placeholder { color:var(--s9p-cream-30, rgba(225,216,203,.3)); }
.s9-form-input:focus {
  border-color:var(--s9p-accent, #c4a96a);
  box-shadow:0 0 0 2px rgba(196,169,106,.15);
}
.s9-form-input.s9-form-input--error {
  border-color:#EF4444;
  box-shadow:0 0 0 2px rgba(239,68,68,.12);
}
.s9-form-input.s9-form-input--valid {
  border-color:#22C55E;
}
.s9-form-textarea { resize:vertical; min-height:70px; }
.s9-form-error {
  display:none;
  font-size:12px;
  color:#EF4444;
  margin-top:4px;
  line-height:1.3;
}
.s9-form-error.visible { display:block; }
/* GDPR checkbox row */
.s9-form-gdpr {
  display:flex;
  align-items:flex-start;
  gap:10px;
  cursor:pointer;
  font-size:13px;
  color:var(--s9p-cream-40, rgba(225,216,203,.4));
  line-height:1.4;
}
.s9-form-checkbox {
  margin-top:2px;
  accent-color:var(--s9p-accent, #c4a96a);
  flex-shrink:0;
  width:16px;
  height:16px;
  cursor:pointer;
}
.s9-form-link {
  color:var(--s9p-cream-60, #c4b8a5);
  text-decoration:underline;
  text-underline-offset:2px;
}
.s9-form-link:hover { color:var(--s9p-text-on-dark); }
/* Submit button */
.s9-form-submit {
  padding:12px 32px;
  cursor:pointer;
  position:relative;
  min-width:180px;
}
.s9-form-submit[disabled] { opacity:.6; cursor:not-allowed; }
.s9-form-spinner { display:none; }
.s9-form-submit.s9-form-submit--loading .s9-form-submit-text { visibility:hidden; }
.s9-form-submit.s9-form-submit--loading .s9-form-spinner {
  display:flex;
  position:absolute;
  inset:0;
  align-items:center;
  justify-content:center;
}
/* Result states */
.s9-form-result {
  grid-column:1/-1;
  display:flex;
  align-items:center;
  gap:10px;
  padding:14px 18px;
  border-radius:8px;
  font-size:14px;
  line-height:1.5;
  animation:s9FormFadeIn .35s ease;
}
.s9-form-result--success {
  background:rgba(34,197,94,.08);
  border:1px solid rgba(34,197,94,.25);
  color:#22C55E;
}
.s9-form-result--error {
  background:rgba(239,68,68,.08);
  border:1px solid rgba(239,68,68,.25);
  color:#EF4444;
}
@keyframes s9FormFadeIn {
  from { opacity:0; transform:translateY(6px); }
  to { opacity:1; transform:translateY(0); }
}

/* ─── 11b. CTA CHANNELS (WhatsApp + Phone) ─── */
.s9-cta-channels {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:24px;
}
.s9-cta-whatsapp {
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 24px;
  background:#25D366;
  color:#fff;
  border-radius:8px;
  font-family:var(--s9p-font);
  font-size:14px;
  font-weight:500;
  text-decoration:none;
  transition:background .2s ease, transform .2s ease;
}
.s9-cta-whatsapp:hover { background:#1da851; transform:translateY(-1px); }
.s9-cta-whatsapp svg { flex-shrink:0; }
.s9-cta-phone {
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 24px;
  background:transparent;
  border:1px solid var(--s9p-cream-20, rgba(225,216,203,.2));
  color:var(--s9p-text-on-dark, #e1d8cb);
  border-radius:8px;
  font-family:var(--s9p-font);
  font-size:14px;
  font-weight:500;
  text-decoration:none;
  transition:border-color .2s ease, transform .2s ease;
}
.s9-cta-phone:hover { border-color:var(--s9p-cream-40); transform:translateY(-1px); }
/* Phone CTA: only visible on mobile */
.s9-cta-phone { display:none; }
@media(max-width:768px) {
  .s9-cta-phone { display:inline-flex; }
  .s9-contact-form { grid-template-columns:1fr; }
}

/* ═══ 12. STICKY BAR ═══ */
.s9-sticky-bar { position:fixed; bottom:0; left:0; right:0; background:rgba(26,23,20,.96); backdrop-filter:blur(20px); border-top:1px solid var(--s9p-cream-15); padding:13px var(--s9p-gutter); display:flex; align-items:center; justify-content:space-between; gap:16px; z-index:500; transform:translateY(100%); transition:transform .5s var(--s9p-ease); }
[data-theme="light"] .s9-sticky-bar { background:rgba(248,246,243,.96); border-top-color:var(--s9p-beige-light); }
.s9-sticky-bar.visible { transform:translateY(0); }
.s9-sticky-name { font-size:18px; font-weight:600; color:var(--s9p-text-on-dark); letter-spacing:-.01em; display:block; }
.s9-sticky-loc { font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--s9p-cream-40); }
[data-theme="light"] .s9-sticky-name { color:var(--s9p-text-dark); }
[data-theme="light"] .s9-sticky-loc { color:var(--s9p-text-subtle); }
.s9-sticky-price { font-size:clamp(18px,2vw,26px); font-weight:600; color:var(--s9p-text-on-dark); letter-spacing:-.02em; }
[data-theme="light"] .s9-sticky-price { color:var(--s9p-text-dark); }
.s9-sticky-actions { display:flex; gap:10px; }
/* Mobile: show mobile actions, hide desktop */
.s9-sticky-actions--mobile { display:none; }
@media(max-width:768px) {
  .s9-sticky-actions--desktop { display:none; }
  .s9-sticky-actions--mobile { display:flex; gap:0; flex:1; }
  .s9-sticky-info { display:none; }
  .s9-sticky-price { display:none; }
  .s9-sticky-bar { padding:0; gap:0; }
  .s9-sticky-mobile-btn {
    flex:1;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:3px;
    padding:10px 8px;
    font-size:11px;
    font-family:var(--s9p-font);
    font-weight:500;
    color:var(--s9p-cream-60);
    text-decoration:none;
    border-right:1px solid var(--s9p-cream-08);
    transition:background .2s ease;
  }
  .s9-sticky-mobile-btn:last-child { border-right:none; }
  .s9-sticky-mobile-btn:active { background:rgba(225,216,203,.06); }
  .s9-sticky-mobile-btn--wa { color:#25D366; }
  .s9-sticky-mobile-btn--call { color:var(--s9p-accent, #c4a96a); }
}

/* ═══ 13. PROPERTY CARDS ═══ */
.s9-property-card { background:var(--card-bg); border:1px solid var(--border-color); border-radius:var(--s9p-radius-lg); overflow:hidden; cursor:pointer; transition:transform var(--s9p-transition),border-color var(--s9p-transition),box-shadow var(--s9p-transition); text-decoration:none; color:inherit; display:block; }
.s9-property-card:hover { transform:translateY(-2px); border-color:var(--s9p-cream-30); box-shadow:0 8px 24px rgba(0,0,0,.35); }
[data-theme="light"] .s9-property-card:hover { box-shadow:0 8px 24px rgba(0,0,0,.1); }
.s9-property-card.highlighted { border-color:var(--s9p-cream-60); }
.s9-card-image-wrap { width:100%; position:relative; overflow:hidden; }
.s9-card-image-wrap.tall { height:190px; }
.s9-card-image-wrap.short { height:130px; }
.s9-card-image-wrap img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s var(--s9p-ease); }
.s9-property-card:hover .s9-card-image-wrap img { transform:scale(1.04); }
.s9-card-img-fallback { width:100%; height:100%; background:var(--bg-raised); display:flex; align-items:center; justify-content:center; font-family:var(--s9p-font-display); font-size:10px; letter-spacing:3px; color:var(--text-muted); text-transform:uppercase; }
.s9-card-badge { position:absolute; top:9px; left:9px; background:var(--s9p-bg-dark); color:var(--s9p-text-on-dark); padding:3px 9px; border-radius:var(--s9p-radius); font-size:9px; font-weight:500; letter-spacing:1.5px; text-transform:uppercase; }
.s9-card-badge.exclusiva { background:#2d4a2d; color:#90c490; }
.s9-card-badge.off-market { background:var(--s9p-dark-btn); color:var(--s9p-cream-60); }
.s9-card-fav { position:absolute; top:9px; right:9px; width:26px; height:26px; border-radius:50%; background:rgba(26,23,20,.7); border:1px solid var(--s9p-cream-15); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all var(--s9p-transition); backdrop-filter:blur(4px); }
.s9-card-fav:hover { border-color:var(--s9p-cream-40); }
.s9-card-fav svg { width:11px; height:11px; color:var(--s9p-cream-60); }
.s9-card-meta-strip { position:absolute; bottom:0; left:0; right:0; padding:26px 11px 9px; background:linear-gradient(to top,rgba(26,23,20,.65),transparent); display:flex; gap:9px; }
.s9-card-meta-item { display:flex; align-items:center; gap:3px; color:var(--s9p-cream-80); font-size:11px; }
.s9-card-meta-item svg { width:10px; height:10px; color:var(--s9p-text-on-dark); }
.s9-card-body { padding:11px 13px 13px; }
.s9-card-price { font-size:clamp(16px,1.5vw,19px); font-weight:600; color:var(--text-primary); line-height:1; margin-bottom:4px; letter-spacing:-.01em; }
.s9-card-address { font-size:12px; color:var(--text-muted); line-height:1.5; }
.s9-card-address strong { display:block; font-weight:500; color:var(--text-secondary); font-size:13px; }
.s9-card-view-btn { display:block; margin-top:10px; padding:7px 0; text-align:center; font-family:var(--s9p-font); font-size:11px; font-weight:500; letter-spacing:.5px; color:var(--text-primary); background:var(--bg-raised); border:1px solid var(--border-color); border-radius:var(--s9p-radius); transition:all .2s ease; text-decoration:none; }
.s9-card-view-btn:hover { background:var(--s9p-bg-dark); color:var(--s9p-text-on-dark); border-color:var(--s9p-bg-dark); }
.s9-card-agent { display:flex; align-items:center; gap:7px; padding-top:9px; margin-top:9px; border-top:1px solid var(--border-color); }
.s9-ca-avatar { width:24px; height:24px; border-radius:50%; background:var(--bg-raised); border:1px solid var(--border-color); display:flex; align-items:center; justify-content:center; font-size:9px; font-weight:600; color:var(--text-muted); flex-shrink:0; }
.s9-ca-name { font-size:11px; font-weight:500; color:var(--text-secondary); }
.s9-ca-tag { font-size:10px; color:var(--text-muted); }
.s9-cards-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }

/* ═══ 14. LISTING PAGE ═══ */
.s9-listing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px); padding:clamp(24px,3vw,40px) var(--s9p-gutter) clamp(40px,5vw,72px); }
.s9-filters-section { padding:0; background:var(--s9p-white); position:relative; z-index:100; border-bottom:1px solid var(--s9p-beige-light); }
.s9-filters-top-bar { display:flex; justify-content:space-between; align-items:center; padding:16px var(--s9p-gutter) 0; }
.s9-filters-title { font-size:16px; font-weight:600; color:var(--s9p-text-dark); }
.s9-filters-count { font-size:11px; color:var(--s9p-text-subtle); letter-spacing:.5px; }
.s9-filters-bar { display:flex; align-items:center; gap:0; padding:12px var(--s9p-gutter) 14px; overflow-x:auto; scrollbar-width:none; }
.s9-filters-bar::-webkit-scrollbar { display:none; }
.s9-filter-chip { display:flex; align-items:center; gap:6px; padding:8px 16px; font-size:12px; font-weight:400; color:var(--s9p-text-muted); background:transparent; border:1px solid var(--s9p-beige-light); transition:all var(--s9p-transition); white-space:nowrap; cursor:pointer; position:relative; font-family:var(--s9p-font); }
.s9-filter-chip:first-child { border-radius:4px 0 0 4px; }
.s9-filter-chip:last-child { border-radius:0 4px 4px 0; }
.s9-filter-chip + .s9-filter-chip { border-left:none; }
.s9-filter-chip:hover,.s9-filter-chip.active { background:var(--s9p-bg-dark); color:var(--s9p-text-on-dark); border-color:var(--s9p-bg-dark); z-index:2; }
.s9-filter-chip svg { width:14px; height:14px; opacity:.5; flex-shrink:0; }
.s9-filter-chip:hover svg,.s9-filter-chip.active svg { opacity:.9; }
.s9-filter-divider { width:1px; height:20px; background:var(--s9p-beige-light); margin:0 16px; flex-shrink:0; }
.s9-filter-search-wrap { position:relative; flex:1; min-width:200px; }
.s9-filter-search-icon { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--s9p-text-subtle); width:13px; height:13px; pointer-events:none; }
.s9-filter-search { width:100%; padding:8px 14px 8px 34px; border:1px solid var(--s9p-beige-light); border-radius:4px; font-size:12px; font-family:var(--s9p-font); color:var(--s9p-text-dark); outline:none; transition:border-color var(--s9p-transition); background:transparent; }
.s9-filter-search::placeholder { color:var(--s9p-text-subtle); }
.s9-filter-search:focus { border-color:var(--s9p-bg-dark); }

/* ═══ 15. MAP PAGE ═══ */
/* Map fullpage: theme navbar stays, footer hidden */
body.s9-map-fullpage { overflow:hidden !important; }
body.s9-map-fullpage .footer,
body.s9-map-fullpage footer.footer { display:none !important; }
body.s9-map-fullpage .navbar { background:rgba(26,23,20,0.97) !important; }
body.s9-map-fullpage .navbar .nav-logo {
  background:linear-gradient(to bottom,rgba(225,216,203,1) 30%,rgba(225,216,203,0.5) 100%) !important;
  -webkit-background-clip:text !important; background-clip:text !important;
  -webkit-text-fill-color:transparent !important;
}
body.s9-map-fullpage .navbar .nav-right button,
body.s9-map-fullpage .navbar .nav-right .nav-lang { color:var(--ok-cream-60, rgba(225,216,203,0.6)) !important; }

/* Map page: fixed below navbar, fills remaining viewport */
.s9-map-page {
  position:fixed; top:var(--ok-navbar-h, 64px); left:0; right:0; bottom:0;
  display:flex; flex-direction:column;
  background:var(--bg); font-family:var(--s9p-font); z-index:1;
}
.s9-map-layout { flex:1; display:flex; overflow:hidden; min-height:0; }
.s9-map-search-bar { height:50px; background:var(--bg-surface); border-bottom:1px solid var(--border-color); display:flex; align-items:center; padding:0 var(--s9p-gutter); gap:10px; flex-shrink:0; transition:background .4s; }
.s9-map-search-input-wrap { display:flex; align-items:center; gap:8px; flex:0 0 300px; background:var(--bg-raised); border:1px solid var(--border-color); border-radius:var(--s9p-radius); padding:0 12px; height:33px; transition:border-color var(--s9p-transition); }
.s9-map-search-input-wrap:focus-within { border-color:var(--s9p-cream-30); }
.s9-map-search-input-wrap svg { color:var(--text-muted); flex-shrink:0; }
.s9-map-search-input-wrap input { background:transparent; border:none; outline:none; color:var(--text-primary); font-family:var(--s9p-font); font-size:12px; font-weight:300; width:100%; }
.s9-map-search-input-wrap input::placeholder { color:var(--text-muted); }
.s9-map-filter-chips { display:flex; gap:0; }
.s9-map-filter-chip { display:flex; align-items:center; gap:5px; padding:6px 13px; font-size:11px; font-weight:400; color:var(--text-muted); background:transparent; border:1px solid var(--border-color); border-left:none; cursor:pointer; font-family:var(--s9p-font); transition:all var(--s9p-transition); white-space:nowrap; }
.s9-map-filter-chip:first-child { border-left:1px solid var(--border-color); border-radius:var(--s9p-radius) 0 0 var(--s9p-radius); }
.s9-map-filter-chip:last-child { border-radius:0 var(--s9p-radius) var(--s9p-radius) 0; }
.s9-map-filter-chip:hover,.s9-map-filter-chip.active { background:var(--s9p-bg-dark); color:var(--s9p-text-on-dark); border-color:var(--s9p-bg-dark); z-index:1; }
[data-theme="light"] .s9-map-filter-chip:hover,[data-theme="light"] .s9-map-filter-chip.active { background:var(--s9p-text-dark); color:var(--s9p-text-on-dark); border-color:var(--s9p-text-dark); }
.s9-map-filter-chip svg { width:10px; height:10px; opacity:.6; }
.s9-map-filter-chip:hover svg,.s9-map-filter-chip.active svg { opacity:1; }
.s9-map-results-count { font-size:11px; color:var(--text-muted); margin-left:auto; white-space:nowrap; letter-spacing:.3px; }
.s9-map-results-count span { color:var(--text-primary); font-weight:500; }
.s9-map-view-toggle { display:flex; border:1px solid var(--border-color); border-radius:var(--s9p-radius); overflow:hidden; }
.s9-map-view-btn { padding:5px 11px; background:transparent; color:var(--text-muted); font-family:var(--s9p-font); font-size:9px; font-weight:500; letter-spacing:1.5px; text-transform:uppercase; border:none; cursor:pointer; display:flex; align-items:center; gap:4px; transition:all var(--s9p-transition); }
.s9-map-view-btn.active { background:var(--s9p-bg-dark); color:var(--s9p-text-on-dark); }
[data-theme="light"] .s9-map-view-btn.active { background:var(--s9p-text-dark); color:var(--s9p-text-on-dark); }
.s9-map-container { flex:1; position:relative; background:var(--bg); }
.s9-map-container #s9-map { width:100%; height:100%; }
.s9-map-type-toggle { position:absolute; top:12px; left:12px; z-index:50; display:flex; border:1px solid var(--border-color); border-radius:var(--s9p-radius); overflow:hidden; background:var(--bg-surface); }
.s9-map-type-btn { padding:6px 13px; font-family:var(--s9p-font); font-size:9px; font-weight:500; letter-spacing:1.5px; text-transform:uppercase; background:transparent; color:var(--text-muted); border:none; cursor:pointer; transition:all var(--s9p-transition); }
.s9-map-type-btn.active { background:var(--s9p-bg-dark); color:var(--s9p-text-on-dark); }
[data-theme="light"] .s9-map-type-btn.active { background:var(--s9p-text-dark); color:var(--s9p-text-on-dark); }
.s9-map-zoom-controls { position:absolute; right:12px; top:12px; z-index:50; display:flex; flex-direction:column; gap:2px; }
.s9-map-zoom-btn { width:32px; height:32px; background:var(--bg-surface); border:1px solid var(--border-color); color:var(--text-primary); font-size:16px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all var(--s9p-transition); border-radius:var(--s9p-radius); }
.s9-map-zoom-btn:hover { background:var(--bg-raised); border-color:var(--s9p-cream-30); }
.s9-map-loading { position:absolute; inset:0; background:var(--bg); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; z-index:200; transition:opacity .5s; }
.s9-map-loading.hidden { opacity:0; pointer-events:none; }
.s9-map-loading-logo { font-family:var(--s9p-font-display); font-size:26px; font-weight:600; text-transform:uppercase; letter-spacing:-.02em; transform:scaleX(1.15); background:linear-gradient(to bottom,rgba(225,216,203,1) 30%,rgba(225,216,203,0.4) 100%); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
[data-theme="light"] .s9-map-loading-logo { background:linear-gradient(to bottom,#1a1714 40%,rgba(26,23,20,0.4) 100%); -webkit-background-clip:text; background-clip:text; }
.s9-map-loading-bar { width:160px; height:1px; background:var(--border-color); position:relative; overflow:hidden; }
.s9-map-loading-bar::after { content:''; position:absolute; left:-100%; width:100%; height:100%; background:var(--text-muted); animation:s9mlbar 1.5s ease infinite; }
@keyframes s9mlbar { to{left:100%;} }
.s9-listings-panel { width:460px; flex-shrink:0; background:var(--bg-surface); border-left:1px solid var(--border-color); display:flex; flex-direction:column; min-height:0; transition:background .4s; }
.s9-listings-header { padding:14px var(--s9p-gutter) 12px; border-bottom:1px solid var(--border-color); display:flex; align-items:center; justify-content:space-between; }
.s9-listings-title { font-family:var(--s9p-font); font-size:11px; font-weight:500; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); }
.s9-sort-select { font-family:var(--s9p-font); font-size:11px; font-weight:400; background:var(--bg-raised); color:var(--text-primary); border:1px solid var(--border-color); border-radius:var(--s9p-radius); padding:5px 10px; cursor:pointer; outline:none; transition:border-color var(--s9p-transition); }
.s9-listings-scroll { flex:1; overflow-y:auto; padding:14px; display:flex; flex-direction:column; gap:8px; scrollbar-width:thin; scrollbar-color:var(--border-color) transparent; }
.s9-listings-scroll::-webkit-scrollbar { width:3px; }
.s9-listings-scroll::-webkit-scrollbar-thumb { background:var(--border-color); border-radius:2px; }

/* ── Map pin markers ── */
.s9-gm-marker { cursor:pointer; transition:transform .2s ease; transform-origin:center bottom; filter:drop-shadow(0 2px 4px rgba(0,0,0,.25)); }
.s9-gm-marker:hover,.s9-gm-marker.active { transform:scale(1.18); filter:drop-shadow(0 4px 8px rgba(0,0,0,.35)); z-index:10; }
.s9-pin-drop { fill:#fff; stroke:#1a1714; stroke-width:1.2; }
.s9-pin-house { fill:none; stroke:#1a1714; stroke-width:1.3; stroke-linecap:round; stroke-linejoin:round; }
.s9-gm-marker:hover .s9-pin-drop,.s9-gm-marker.active .s9-pin-drop { fill:#1a1714; }
.s9-gm-marker:hover .s9-pin-house,.s9-gm-marker.active .s9-pin-house { stroke:#e1d8cb; }
.s9-gm-marker.exclusiva .s9-pin-drop { fill:#1a1714; stroke:#90c490; }
.s9-gm-marker.exclusiva .s9-pin-house { stroke:#90c490; }
.s9-gm-marker.exclusiva:hover .s9-pin-drop,.s9-gm-marker.exclusiva.active .s9-pin-drop { fill:#90c490; stroke:#1a1714; }
.s9-gm-marker.exclusiva:hover .s9-pin-house,.s9-gm-marker.exclusiva.active .s9-pin-house { stroke:#1a1714; }
/* Hide Google Maps branding */
.gm-style .gmnoprint, .gm-style .gm-style-cc, .gm-style a[href*="maps.google"] { display:none!important; }
.gm-style div[draggable="false"] > a { display:none!important; }
/* Popup — exact replica of PRIVADA standalone */
.gm-style .gm-style-iw-c { background:var(--s9p-dark-mid, #201d18)!important; border:1px solid var(--s9p-cream-15, rgba(225,216,203,0.15))!important; border-radius:var(--s9p-radius-lg, 16px)!important; box-shadow:0 8px 28px rgba(0,0,0,.6)!important; padding:0!important; overflow:hidden!important; }
.gm-style .gm-style-iw-d { overflow:hidden!important; }
.gm-style .gm-style-iw-t::after { background:var(--s9p-dark-mid, #201d18)!important; }
.gm-style-iw-chr { display:none!important; }
.s9-popup-wrap { width:210px; background:var(--s9p-dark-mid, #201d18); font-family:var(--s9p-font); }
.s9-popup-img { width:210px; height:115px; object-fit:cover; display:block; }
.s9-popup-inner { padding:11px 13px 13px; }
.s9-popup-price { font-size:18px; font-weight:600; color:var(--s9p-text-on-dark, #e1d8cb); margin-bottom:2px; letter-spacing:-.01em; }
.s9-popup-addr { font-size:11px; color:var(--s9p-text-subtle, #9a9088); margin-bottom:8px; line-height:1.5; }
.s9-popup-addr strong { display:block; color:var(--s9p-cream-80, rgba(225,216,203,0.8)); font-weight:500; font-size:12px; }
.s9-popup-specs { display:flex; gap:7px; font-size:10px; color:var(--s9p-text-subtle, #9a9088); }
/* Popup CTA — pill button with expanding circle animation (matches theme) */
.s9-popup-cta { display:inline-flex!important; align-items:center!important; gap:0!important; background:#F4EFE7!important; padding:4px!important; border-radius:30px!important; font-size:12px!important; font-weight:300!important; border:none!important; cursor:pointer!important; font-family:var(--s9p-font)!important; position:relative!important; overflow:hidden!important; text-decoration:none!important; margin:10px 13px 13px!important; }
.s9-popup-cta::before { content:''!important; position:absolute!important; top:50%!important; right:4px!important; width:30px!important; height:30px!important; transform:translateY(-50%)!important; border-radius:50%!important; background:#2A2725!important; transition:all 0.3s cubic-bezier(0.4,0,0.2,1)!important; z-index:1!important; }
.s9-popup-cta:hover::before { width:calc(100% - 8px)!important; border-radius:22px!important; }
.s9-popup-cta .btn-text { position:relative!important; z-index:2!important; padding-left:12px!important; margin-right:8px!important; color:#2A2725!important; transition:color 0.3s ease!important; white-space:nowrap!important; font-family:var(--s9p-font)!important; font-size:12px!important; font-weight:300!important; }
.s9-popup-cta:hover .btn-text { color:#A79D8E!important; }
.s9-popup-cta .btn-icon { position:relative!important; z-index:2!important; display:flex!important; align-items:center!important; justify-content:center!important; width:30px!important; height:30px!important; flex-shrink:0!important; color:#A79D8E!important; }
.s9-popup-cta .btn-icon svg { width:12px!important; height:12px!important; }

/* ═══ 16. SHARED BUTTONS ═══ */
.s9-btn-outline { display:inline-flex; align-items:center; gap:8px; padding:10px 20px; border:1px solid var(--border-color); color:var(--text-primary); font-family:var(--s9p-font); font-size:13px; font-weight:300; border-radius:var(--s9p-radius-pill); background:transparent; cursor:pointer; transition:border-color var(--s9p-transition); text-decoration:none; }
.s9-btn-outline:hover { border-color:var(--s9p-cream-40); }
.s9-btn-outline-dark { display:inline-flex; align-items:center; gap:8px; padding:10px 20px; border:1px solid var(--s9p-cream-30); color:var(--s9p-text-on-dark); font-family:var(--s9p-font); font-size:13px; font-weight:300; border-radius:var(--s9p-radius-pill); background:transparent; cursor:pointer; transition:border-color var(--s9p-transition); text-decoration:none; }
.s9-btn-outline-dark:hover { border-color:var(--s9p-cream-60); }

/* Reveal animation helper */
.s9-reveal { opacity:0; transform:translateY(20px); }

/* ═══ 17. SHORTCODE LISTING [s9_listing] ═══ */

/* -- Listing container -- */
.s9-listing { width:100%; }

/* -- Counter -- */
.s9-listing__counter { display:flex; justify-content:space-between; align-items:center; padding:16px var(--s9p-gutter, clamp(20px,4vw,64px)) 0; }
.s9-listing__count-text { font-size:11px; color:var(--s9p-text-subtle, #9a9088); letter-spacing:.5px; }
.s9-listing__count-text strong { color:var(--s9p-text-dark, #1a1714); font-weight:500; }

/* -- Filters bar -- */
.s9-filters { padding:0; background:var(--s9p-white, #fff); position:relative; z-index:100; border-bottom:1px solid var(--s9p-beige-light, #e8e0d4); }
.s9-filters__bar { display:flex; align-items:center; gap:0; padding:12px var(--s9p-gutter, clamp(20px,4vw,64px)) 14px; overflow-x:auto; scrollbar-width:none; }
.s9-filters__bar::-webkit-scrollbar { display:none; }

.s9-filters__select { display:flex; align-items:center; gap:6px; padding:8px 16px; font-size:12px; font-weight:400; color:var(--s9p-text-muted, #6b635b); background:transparent; border:1px solid var(--s9p-beige-light, #e8e0d4); transition:all .25s ease; white-space:nowrap; cursor:pointer; font-family:var(--s9p-font, 'Host Grotesk', sans-serif); appearance:none; -webkit-appearance:none; outline:none; }
.s9-filters__select:first-child { border-radius:4px 0 0 4px; }
.s9-filters__select:last-of-type { border-radius:0 4px 4px 0; }
.s9-filters__select + .s9-filters__select { border-left:none; }
.s9-filters__select:hover, .s9-filters__select:focus { background:var(--s9p-bg-dark, #1a1714); color:var(--s9p-text-on-dark, #e1d8cb); border-color:var(--s9p-bg-dark, #1a1714); z-index:2; }

.s9-filters__divider { width:1px; height:20px; background:var(--s9p-beige-light, #e8e0d4); margin:0 16px; flex-shrink:0; }

.s9-filters__search-wrap { position:relative; flex:1; min-width:200px; }
.s9-filters__search-icon { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--s9p-text-subtle, #9a9088); width:13px; height:13px; pointer-events:none; }
.s9-filters__search { width:100%; padding:8px 14px 8px 34px; border:1px solid var(--s9p-beige-light, #e8e0d4); border-radius:4px; font-size:12px; font-family:var(--s9p-font, 'Host Grotesk', sans-serif); color:var(--s9p-text-dark, #1a1714); outline:none; transition:border-color .25s; background:transparent; }
.s9-filters__search::placeholder { color:var(--s9p-text-subtle, #9a9088); }
.s9-filters__search:focus { border-color:var(--s9p-bg-dark, #1a1714); }

/* ═══ 17b. FILTER BAR (property listing page) ═══ */

.s9-filterbar {
  position:sticky; top:var(--s9p-navbar-h, 64px); z-index:120;
  background:rgba(26,23,20,.96);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(225,216,203,.1);
}
.s9-filterbar__inner {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
  padding:12px var(--s9p-gutter, clamp(20px,4vw,64px));
}
.s9-filterbar__group { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.s9-filterbar__group--ops { margin-right:4px; }
.s9-filterbar__group--price { gap:4px; }
.s9-filterbar__group--beds { gap:4px; }
.s9-filterbar__group--search { flex:1; min-width:140px; }
.s9-filterbar__label {
  font-size:10px; letter-spacing:1.5px; text-transform:uppercase;
  color:rgba(225,216,203,.5); font-weight:500; white-space:nowrap;
}

/* Pills */
.s9-filterbar__pills { display:flex; gap:0; }
.s9-filterbar__pill {
  padding:7px 14px; border:1px solid rgba(225,216,203,.15);
  background:transparent; color:rgba(225,216,203,.7);
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  font-size:12px; font-weight:400; cursor:pointer;
  transition:all .2s ease; white-space:nowrap; outline:none;
}
.s9-filterbar__pill:first-child { border-radius:var(--s9p-radius-pill, 30px) 0 0 var(--s9p-radius-pill, 30px); }
.s9-filterbar__pill:last-child { border-radius:0 var(--s9p-radius-pill, 30px) var(--s9p-radius-pill, 30px) 0; }
.s9-filterbar__pill + .s9-filterbar__pill { border-left:none; }
.s9-filterbar__pill:hover { background:rgba(225,216,203,.08); color:rgba(225,216,203,.9); }
.s9-filterbar__pill--active {
  background:rgba(225,216,203,.15) !important;
  color:#e1d8cb !important;
  border-color:rgba(225,216,203,.3) !important;
  font-weight:500;
}
.s9-filterbar__pill--sm { padding:6px 10px; font-size:11px; min-width:28px; text-align:center; }

/* Selects */
.s9-filterbar__select {
  padding:7px 28px 7px 12px; border:1px solid rgba(225,216,203,.15);
  border-radius:var(--s9p-radius, 6px);
  background:transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239a9088' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;
  background-size:10px;
  color:rgba(225,216,203,.7); font-size:12px; font-weight:400;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  cursor:pointer; outline:none; transition:all .2s ease;
  appearance:none; -webkit-appearance:none;
}
.s9-filterbar__select:hover,
.s9-filterbar__select:focus { border-color:rgba(225,216,203,.4); color:#e1d8cb; }
.s9-filterbar__select option { background:#1a1714; color:#e1d8cb; }

/* Price inputs */
.s9-filterbar__input {
  padding:7px 12px; border:1px solid rgba(225,216,203,.15);
  border-radius:var(--s9p-radius, 6px); background:transparent;
  color:rgba(225,216,203,.8); font-size:12px;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  outline:none; transition:border-color .2s;
}
.s9-filterbar__input--price { width:110px; }
.s9-filterbar__input::placeholder { color:rgba(225,216,203,.4); }
.s9-filterbar__input:focus { border-color:rgba(225,216,203,.4); }
.s9-filterbar__price-sep { color:rgba(225,216,203,.3); font-size:12px; }

/* Search */
.s9-filterbar__search-wrap { position:relative; width:100%; }
.s9-filterbar__search-icon { position:absolute; left:10px; top:50%; transform:translateY(-50%); color:rgba(225,216,203,.4); pointer-events:none; }
.s9-filterbar__search {
  width:100%; padding:7px 12px 7px 32px;
  border:1px solid rgba(225,216,203,.15); border-radius:var(--s9p-radius, 6px);
  background:transparent; color:rgba(225,216,203,.8); font-size:12px;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  outline:none; transition:border-color .2s;
}
.s9-filterbar__search::placeholder { color:rgba(225,216,203,.4); }
.s9-filterbar__search:focus { border-color:rgba(225,216,203,.4); }

/* Clear button */
.s9-filterbar__clear {
  display:inline-flex; align-items:center; gap:5px;
  padding:6px 12px; border:1px solid rgba(225,216,203,.15);
  border-radius:var(--s9p-radius-pill, 30px); background:transparent;
  color:rgba(225,216,203,.6); font-size:11px; font-weight:400;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  cursor:pointer; transition:all .2s; white-space:nowrap;
}
.s9-filterbar__clear:hover { background:rgba(239,68,68,.15); color:#ef4444; border-color:rgba(239,68,68,.3); }

/* Mobile toggle (hidden on desktop) */
.s9-filterbar__mobile-toggle {
  display:none; /* shown via media query */
  align-items:center; gap:8px; width:100%;
  padding:14px var(--s9p-gutter, clamp(20px,4vw,64px));
  background:rgba(26,23,20,.96); border:none; border-bottom:1px solid rgba(225,216,203,.1);
  color:rgba(225,216,203,.8); font-size:13px; font-weight:500;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  cursor:pointer; backdrop-filter:blur(16px);
}
.s9-filterbar__mobile-count {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:18px; height:18px; padding:0 5px;
  background:rgba(225,216,203,.2); border-radius:9px;
  font-size:10px; font-weight:600; color:#e1d8cb;
}

/* Mobile drawer */
.s9-filterbar__drawer-overlay {
  position:fixed; inset:0; z-index:999;
  background:rgba(0,0,0,.5); transition:opacity .3s;
}
.s9-filterbar__drawer {
  position:fixed; bottom:0; left:0; right:0; z-index:1000;
  max-height:85vh; background:#1a1714;
  border-radius:16px 16px 0 0;
  transform:translateY(100%); transition:transform .35s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column;
}
.s9-filterbar__drawer--open { transform:translateY(0); }
.s9-filterbar__drawer-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid rgba(225,216,203,.1);
}
.s9-filterbar__drawer-title {
  font-size:16px; font-weight:600; color:#e1d8cb;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
}
.s9-filterbar__drawer-close {
  width:32px; height:32px; border-radius:50%;
  background:rgba(225,216,203,.08); border:none;
  color:rgba(225,216,203,.6); display:flex;
  align-items:center; justify-content:center; cursor:pointer;
}
.s9-filterbar__drawer-body {
  flex:1; overflow-y:auto; padding:16px 20px;
}
.s9-filterbar__drawer-body .s9-filterbar__inner {
  flex-direction:column; align-items:stretch; gap:16px; padding:0;
}
.s9-filterbar__drawer-body .s9-filterbar__group { flex-wrap:wrap; }
.s9-filterbar__drawer-body .s9-filterbar__group--search { min-width:100%; }
.s9-filterbar__drawer-body .s9-filterbar__input--price { width:100%; flex:1; }
.s9-filterbar__drawer-body .s9-filterbar__pills { flex-wrap:wrap; gap:6px; }
.s9-filterbar__drawer-body .s9-filterbar__pill { border-radius:var(--s9p-radius-pill, 30px) !important; border:1px solid rgba(225,216,203,.15) !important; }
.s9-filterbar__drawer-body .s9-filterbar__select { width:100%; }
.s9-filterbar__drawer-footer {
  padding:12px 20px 20px; border-top:1px solid rgba(225,216,203,.1);
}
.s9-filterbar__drawer-apply {
  width:100%; padding:14px; border:none;
  border-radius:var(--s9p-radius-pill, 30px);
  background:var(--s9p-btn-hover, #F4EFE7);
  color:var(--s9p-bg-dark, #1a1714);
  font-size:14px; font-weight:500; cursor:pointer;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  transition:background .2s;
}
.s9-filterbar__drawer-apply:hover { background:var(--s9p-beige-light, #ece6dd); }

/* ═══ 17c. SKELETON LOADING CARDS ═══ */

@keyframes s9-skeleton-pulse {
  0%   { opacity:.06; }
  50%  { opacity:.12; }
  100% { opacity:.06; }
}
.s9-skeleton-pulse { animation:s9-skeleton-pulse 1.5s ease-in-out infinite; }
.s9-skeleton-card {
  border-radius:var(--s9p-radius, 6px); overflow:hidden;
  background:var(--s9p-white, #fff);
}
.s9-skeleton-card__image {
  height:clamp(200px,18vw,280px);
  background:var(--s9p-beige-light, #e8e0d4);
}
.s9-skeleton-card__body { padding:14px 4px 8px; }
.s9-skeleton-card__line {
  border-radius:4px;
  background:var(--s9p-beige-light, #e8e0d4);
}
.s9-skeleton-card__line--title { height:16px; width:70%; margin-bottom:8px; }
.s9-skeleton-card__line--sub { height:12px; width:50%; margin-bottom:10px; }
.s9-skeleton-card__line--price { height:14px; width:35%; }

/* ═══ 17d. LISTING HEADER ═══ */

.s9-listing__header {
  display:flex; justify-content:space-between; align-items:center;
  padding:clamp(20px,3vw,36px) var(--s9p-gutter, clamp(20px,4vw,64px)) 0;
}
.s9-listing__title {
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  font-size:clamp(22px,2.5vw,38px); font-weight:600;
  color:var(--s9p-text-dark, #1a1714); line-height:1.2;
  letter-spacing:-.02em;
}
.s9-listing__count {
  font-size:13px; color:var(--s9p-text-subtle, #9a9088);
  margin-top:4px; font-weight:300;
}

/* Image count badge */
.s9-card__images-count {
  position:absolute; bottom:12px; right:12px; z-index:2;
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 8px; border-radius:3px;
  background:rgba(26,23,20,.7); backdrop-filter:blur(4px);
  color:rgba(225,216,203,.85); font-size:10px; font-weight:500;
  letter-spacing:.5px;
}

/* Load more showing text */
.s9-listing__showing {
  font-size:12px; color:var(--s9p-text-subtle, #9a9088);
  text-align:center; margin-top:8px; font-weight:300;
}

/* Load more spinner rotation */
@keyframes s9-spin { to { transform:rotate(360deg); } }
.s9-btn-loadmore__spinner { animation:s9-spin 1s linear infinite; }

/* Card enter transition */
.s9-card--enter { opacity:0; transform:translateY(16px); transition:opacity .4s ease, transform .4s ease; }

/* -- Grid -- */
.s9-listing__grid { display:grid; gap:clamp(16px,2vw,24px); padding:clamp(24px,3vw,40px) var(--s9p-gutter, clamp(20px,4vw,64px)) clamp(40px,5vw,72px); transition:opacity .3s; }
.s9-listing__grid--cols-2 { grid-template-columns:repeat(2,1fr); }
.s9-listing__grid--cols-3 { grid-template-columns:repeat(3,1fr); }
.s9-listing__grid--cols-4 { grid-template-columns:repeat(4,1fr); }
.s9-listing__grid--loading { opacity:.4; pointer-events:none; }

/* -- Cards (Okane style replica) -- */
.s9-card { display:block; border-radius:var(--s9p-radius, 6px); overflow:hidden; transition:transform .35s cubic-bezier(.4,0,.2,1); text-decoration:none; color:inherit; background:var(--s9p-white, #fff); }
.s9-card:hover { transform:translateY(-3px); }

.s9-card__image-wrap { position:relative; height:clamp(200px,18vw,280px); overflow:hidden; border-radius:var(--s9p-radius, 6px); }
.s9-card__image { width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.4,0,.2,1); display:block; }
.s9-card:hover .s9-card__image { transform:scale(1.05); }
.s9-card__image-fallback { width:100%; height:100%; background:var(--s9p-beige-light, #e8e0d4); display:flex; align-items:center; justify-content:center; font-family:var(--s9p-font-display, 'Montserrat', sans-serif); font-size:10px; letter-spacing:3px; color:var(--s9p-text-subtle, #9a9088); text-transform:uppercase; }

.s9-card__badge { position:absolute; top:12px; left:12px; background:var(--s9p-bg-dark, #1a1714); color:var(--s9p-text-on-dark, #e1d8cb); padding:4px 10px; border-radius:3px; font-size:9px; font-weight:500; letter-spacing:1.5px; text-transform:uppercase; z-index:2; }
.s9-card__badge--exclusiva { background:#2d4a2d; color:#90c490; }
.s9-card__badge--off-market { background:var(--s9p-text-on-dark, #e1d8cb); color:var(--s9p-bg-dark, #1a1714); }

.s9-card__meta { position:absolute; bottom:0; left:0; right:0; padding:36px 14px 12px; background:linear-gradient(to top,rgba(26,23,20,.6),transparent); display:flex; gap:10px; z-index:1; }
.s9-card__meta-item { display:flex; align-items:center; gap:4px; color:rgba(225,216,203,.9); font-size:11px; font-weight:400; }
.s9-card__meta-item svg { width:13px; height:13px; opacity:.75; flex-shrink:0; }

.s9-card__info { padding:14px 4px 8px; display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
.s9-card__name { font-family:var(--s9p-font, 'Host Grotesk', sans-serif); font-size:clamp(16px,1.4vw,20px); font-weight:600; color:var(--s9p-text-dark, #1a1714); line-height:1.3; }
.s9-card__location { font-size:12px; color:var(--s9p-text-subtle, #9a9088); margin-top:2px; }
.s9-card__price { text-align:right; white-space:nowrap; }
.s9-card__price-value { font-size:clamp(14px,1.2vw,16px); font-weight:600; color:var(--s9p-bg-dark, #1a1714); }

/* -- Card enter animation -- */
.s9-card--enter { opacity:0; transform:translateY(16px); }

/* -- Load More -- */
.s9-listing__loadmore { display:flex; justify-content:center; padding:0 var(--s9p-gutter, clamp(20px,4vw,64px)) clamp(40px,5vw,72px); }
.s9-btn-loadmore { display:inline-flex; align-items:center; gap:8px; padding:14px 36px; border:1px solid var(--s9p-beige-light, #e8e0d4); color:var(--s9p-text-dark, #1a1714); font-family:var(--s9p-font, 'Host Grotesk', sans-serif); font-size:12px; font-weight:500; letter-spacing:1px; text-transform:uppercase; border-radius:var(--s9p-radius-pill, 30px); background:transparent; cursor:pointer; transition:all .25s; }
.s9-btn-loadmore:hover { background:var(--s9p-bg-dark, #1a1714); color:var(--s9p-text-on-dark, #e1d8cb); border-color:var(--s9p-bg-dark, #1a1714); }
.s9-btn-loadmore:disabled { opacity:.5; cursor:not-allowed; }

/* -- Empty state -- */
.s9-listing__empty { padding:clamp(40px,5vw,80px) var(--s9p-gutter, clamp(20px,4vw,64px)); text-align:center; }
.s9-listing__empty p { font-size:15px; color:var(--s9p-text-subtle, #9a9088); }

/* ═══ 18. MORTGAGE CALCULATOR ═══ */
.s9-mortgage-section {
  border-top:1px solid var(--border-color);
  padding:clamp(52px,7vw,92px) var(--s9p-gutter);
  display:flex;
  justify-content:center;
}
.s9-mortgage-calc-card {
  width:100%;
  max-width:560px;
  background:var(--card-bg);
  border:1px solid var(--border-color);
  border-radius:var(--s9p-radius-lg);
  overflow:hidden;
}

/* Toggle header */
.s9-mortgage-calc__toggle {
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:100%;
  padding:22px 26px;
  background:transparent;
  border:none;
  cursor:pointer;
  font-family:var(--s9p-font);
  color:var(--text-primary);
}
.s9-mortgage-calc__title {
  display:flex;
  align-items:center;
  gap:10px;
  font-size:16px;
  font-weight:600;
  letter-spacing:-.01em;
}
.s9-mortgage-calc__title svg { color:var(--text-muted); flex-shrink:0; }
.s9-mortgage-calc__chevron {
  color:var(--text-muted);
  transition:transform .3s var(--s9p-ease);
  flex-shrink:0;
}
.s9-mortgage-calc--open .s9-mortgage-calc__chevron { transform:rotate(180deg); }

/* Collapsible body */
.s9-mortgage-calc__body {
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  padding:0 26px 26px;
  max-height:0;
  overflow:hidden;
  opacity:0;
  transition:max-height .4s var(--s9p-ease), opacity .3s var(--s9p-ease), padding .3s var(--s9p-ease);
}
.s9-mortgage-calc--open .s9-mortgage-calc__body {
  max-height:600px;
  opacity:1;
  padding:0 26px 26px;
}

/* Fields */
.s9-mortgage-calc__field { margin-bottom:14px; }
.s9-mortgage-calc__field label {
  display:block;
  font-size:11px;
  font-weight:500;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:6px;
}
.s9-mortgage-calc__input-wrap {
  display:flex;
  align-items:center;
  background:var(--bg);
  border:1px solid var(--border-color);
  border-radius:var(--s9p-radius);
  overflow:hidden;
  transition:border-color .2s ease;
}
.s9-mortgage-calc__input-wrap:focus-within {
  border-color:var(--s9p-cream-40);
}
.s9-mortgage-calc__input-wrap input {
  flex:1;
  min-width:0;
  padding:10px 12px;
  background:transparent;
  border:none;
  outline:none;
  font-family:var(--s9p-font);
  font-size:14px;
  font-weight:500;
  color:var(--text-primary);
  -moz-appearance:textfield;
}
.s9-mortgage-calc__input-wrap input::-webkit-outer-spin-button,
.s9-mortgage-calc__input-wrap input::-webkit-inner-spin-button {
  -webkit-appearance:none;
  margin:0;
}
.s9-mortgage-calc__suffix {
  padding:0 12px 0 0;
  font-size:12px;
  color:var(--text-muted);
  font-weight:400;
  white-space:nowrap;
  user-select:none;
}

/* Row layout (side by side fields) */
.s9-mortgage-calc__row {
  display:flex;
  gap:10px;
}
.s9-mortgage-calc__row .s9-mortgage-calc__field { flex:1; }
.s9-mortgage-calc__field--grow { flex:2 !important; }
.s9-mortgage-calc__field--small { flex:0 0 80px !important; }

/* Results */
.s9-mortgage-calc__results {
  margin-top:8px;
  padding-top:18px;
  border-top:1px solid var(--border-color);
  display:grid;
  gap:12px;
}
.s9-mortgage-calc__result {
  display:flex;
  justify-content:space-between;
  align-items:baseline;
}
.s9-mortgage-calc__label {
  font-size:13px;
  color:var(--text-muted);
  font-weight:400;
}
.s9-mortgage-calc__value {
  font-family:var(--s9p-font);
  font-size:14px;
  font-weight:600;
  color:var(--text-primary);
}

/* Main result (cuota mensual) — prominent */
.s9-mortgage-calc__result--main {
  padding-bottom:12px;
  border-bottom:1px solid var(--border-color);
}
.s9-mortgage-calc__result--main .s9-mortgage-calc__label {
  font-size:14px;
  font-weight:500;
  color:var(--text-secondary);
}
.s9-mortgage-calc__result--main .s9-mortgage-calc__value {
  font-size:clamp(22px,2.5vw,28px);
  font-weight:700;
  color:var(--s9p-text-on-dark);
  letter-spacing:-.02em;
}
[data-theme="light"] .s9-mortgage-calc__result--main .s9-mortgage-calc__value {
  color:var(--s9p-text-dark);
}

/* Disclaimer */
.s9-mortgage-calc__disclaimer {
  margin-top:14px;
  font-size:11px;
  color:var(--text-muted);
  font-style:italic;
  text-align:center;
  line-height:1.5;
}

/* ═══ 19. SHARE / QR CODE ═══ */
.s9-share-section {
  border-top:1px solid var(--border-color, rgba(225,216,203,.1));
  padding:clamp(20px,3vw,40px) var(--s9p-gutter);
  display:flex;
  justify-content:center;
}
.s9-share-wrap { width:100%; max-width:560px; }
.s9-share-toggle {
  display:flex;
  align-items:center;
  gap:8px;
  width:100%;
  padding:14px 20px;
  background:var(--card-bg, rgba(255,255,255,.03));
  border:1px solid var(--border-color, rgba(225,216,203,.1));
  border-radius:var(--s9p-radius-lg, 12px);
  color:var(--s9p-cream-60, #b3a99a);
  font-family:var(--s9p-font, inherit);
  font-size:14px;
  font-weight:500;
  cursor:pointer;
  transition:border-color .2s, background .2s;
}
.s9-share-toggle:hover {
  border-color:var(--s9p-cream-20, rgba(225,216,203,.2));
  background:var(--s9p-cream-05, rgba(225,216,203,.05));
}
.s9-share-toggle svg { flex-shrink:0; }
.s9-share-toggle span { flex:1; text-align:left; }
.s9-share-chevron { transition:transform .25s ease; }
.s9-share-qr {
  display:flex;
  gap:24px;
  align-items:center;
  padding:20px;
  margin-top:-1px;
  border:1px solid var(--border-color, rgba(225,216,203,.1));
  border-top:none;
  border-radius:0 0 var(--s9p-radius-lg, 12px) var(--s9p-radius-lg, 12px);
  background:var(--card-bg, rgba(255,255,255,.03));
}
.s9-share-qr__preview {
  flex-shrink:0;
  background:#fff;
  padding:10px;
  border-radius:8px;
  line-height:0;
}
.s9-share-qr__info {
  font-size:13px;
  color:var(--s9p-cream-40, #8a7f73);
  line-height:1.6;
}
.s9-share-qr__info p { margin:0 0 12px; }
[data-theme="light"] .s9-share-toggle { color:var(--s9p-text-dark); }
[data-theme="light"] .s9-share-qr__info { color:var(--s9p-text-subtle, #6a6259); }
@media(max-width:480px) {
  .s9-share-qr { flex-direction:column; text-align:center; }
}

/* ═══ 20. RESPONSIVE ═══ */

/* --- Laptop: 1024px-1439px --- */
@media(max-width:1439px) {
  .s9-listings-panel { width:380px; }
}

/* --- Tablet: 768px-1023px --- */
@media(max-width:1024px) {
  .s9-desc-section { grid-template-columns:1fr; }
  .s9-floorplan-section { grid-template-columns:1fr; }
  .s9-tour-section { grid-template-columns:1fr; }
  .s9-location-section { grid-template-columns:1fr; }
  .s9-location-map { min-height:320px; }
  .s9-features-grid { grid-template-columns:1fr 1fr; }
  .s9-vert-grid { grid-template-columns:1fr; }
  .s9-listing-grid { grid-template-columns:repeat(2,1fr); }
  /* Shortcode grid */
  .s9-listing__grid--cols-3,
  .s9-listing__grid--cols-4 { grid-template-columns:repeat(2,1fr); }
  /* Map page: panel narrower */
  .s9-listings-panel { width:340px; }
  /* Filter bar: wrap */
  .s9-filterbar__inner { gap:8px; }
  .s9-filterbar__input--price { width:90px; }
  /* Stats bar: 5 cols too wide on tablet, go to 3+2 wrap */
  .s9-stats-bar { grid-template-columns:repeat(3,1fr); }
  .s9-stat-item:nth-child(4),
  .s9-stat-item:nth-child(5) { border-top:1px solid var(--border-color); }
  /* Gallery: slightly smaller items on tablet */
  .s9-gallery-item { height:320px; }
  /* Sticky bar: ensure touch targets */
  .s9-sticky-actions .s9-btn-primary { padding:5px; }
  .s9-sticky-actions .s9-btn-outline,
  .s9-sticky-actions .s9-btn-outline-dark { padding:8px 14px; }
  /* Hero price: left-align under content on tablet */
  .s9-hero-price-wrap { position:relative; right:auto; bottom:auto; text-align:left; margin-top:20px; }
}

/* --- Mobile: 375px-767px --- */
@media(max-width:768px) {
  /* Filter bar: hide desktop, show mobile toggle */
  .s9-filterbar__inner { display:none !important; }
  .s9-filterbar__mobile-toggle { display:flex !important; }
  .s9-filterbar { position:sticky; top:var(--s9p-navbar-h, 64px); }
  /* Map page: stack vertically */
  .s9-map-layout { flex-direction:column; }
  .s9-map-container { flex:none; height:50vh; min-height:280px; }
  .s9-listings-panel { width:100%; flex:1; border-left:none; border-top:1px solid var(--border-color); }
  .s9-map-search-bar { flex-wrap:wrap; height:auto; padding:10px var(--s9p-gutter); gap:8px; }
  .s9-map-search-input-wrap { flex:1 1 100%; }
  .s9-map-filter-chips { flex-wrap:wrap; }
  .s9-cards-grid { grid-template-columns:1fr; }
  .s9-map-page { position:fixed; top:var(--ok-navbar-h, 60px); left:0; right:0; bottom:0; }
  /* Map view toggle & results count: hide on mobile */
  .s9-map-results-count { display:none; }
  /* Hero: stack content, price below */
  .s9-hero { min-height:auto; height:auto; padding-top:100px; padding-bottom:clamp(24px,4vw,40px); }
  .s9-hero-content { max-width:100%; }
  .s9-hero-price-wrap { position:relative; right:auto; bottom:auto; text-align:left; margin-top:16px; }
  /* Stats bar: 2 cols on mobile for better readability */
  .s9-stats-bar { grid-template-columns:repeat(2,1fr); }
  .s9-stat-item { border-right:none; border-bottom:1px solid var(--border-color); }
  .s9-stat-item:nth-child(odd) { border-right:1px solid var(--border-color); }
  .s9-stat-item:last-child { border-bottom:none; }
  /* Listing grid: 2 cols on tablet-ish mobile */
  .s9-listing-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .s9-listing__grid--cols-2,
  .s9-listing__grid--cols-3,
  .s9-listing__grid--cols-4 { grid-template-columns:repeat(2,1fr); gap:12px; }
  /* Description section */
  .s9-desc-text { font-size:15px; }
  /* Features grid */
  .s9-features-grid { grid-template-columns:1fr 1fr; gap:1px; }
  .s9-feature-item { padding:20px 16px; gap:10px; }
  /* Sticky bar: compact for mobile */
  .s9-sticky-bar { padding:10px var(--s9p-gutter); gap:10px; }
  .s9-sticky-name { font-size:14px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:40vw; }
  .s9-sticky-loc { display:none; }
  .s9-sticky-price { font-size:16px; }
  .s9-sticky-actions { gap:6px; }
  /* CTA section */
  .s9-cta-content { max-width:100%; }
  .s9-cta-actions { flex-direction:column; }
  .s9-cta-actions .s9-btn-primary,
  .s9-cta-actions .s9-btn-outline-dark { width:100%; justify-content:center; }
  /* Compare tray: account for sticky bar z-index */
  .s9-compare-tray { z-index:9999; }
  .s9-sticky-bar { z-index:500; }
  /* Gallery arrows always visible on touch */
  .s9-gallery-arrow { opacity:1; }
}

/* --- Small mobile: <640px --- */
@media(max-width:640px) {
  .s9-mortgage-calc__row { flex-direction:column; gap:0; }
  .s9-mortgage-calc__field--small { flex:1 !important; }
  .s9-mortgage-calc-card { border-radius:var(--s9p-radius); }
  .s9-features-grid,.s9-vert-grid { grid-template-columns:1fr; }
  .s9-sticky-price { display:none; }
  .s9-gallery-item { width:80vw!important; height:280px; }
  .s9-gallery-arrow { opacity:1; width:40px; height:40px; }
  .s9-gallery-arrow svg { width:16px; height:16px; }
  .s9-listing-grid { grid-template-columns:1fr; }
  .s9-filter-chip { border-radius:4px; }
  /* Shortcode grid */
  .s9-listing__grid--cols-2,
  .s9-listing__grid--cols-3,
  .s9-listing__grid--cols-4 { grid-template-columns:1fr; }
  /* Filters */
  .s9-filters__bar { flex-wrap:wrap; gap:8px; }
  .s9-filters__select { border-radius:4px!important; border:1px solid var(--s9p-beige-light, #e8e0d4)!important; }
  .s9-filters__select + .s9-filters__select { border-left:1px solid var(--s9p-beige-light, #e8e0d4)!important; }
  .s9-filters__divider { display:none; }
  .s9-filters__search-wrap { min-width:100%; order:-1; }
  /* Hero: further compact */
  .s9-hero h1 { font-size:clamp(28px,7vw,38px); }
  .s9-hero-sub { font-size:14px; margin-bottom:16px; }
  .s9-hero-actions { flex-direction:column; gap:8px; }
  .s9-hero-actions .s9-btn-primary,
  .s9-hero-actions .s9-btn-outline { width:100%; justify-content:center; }
  /* Location section: taller map on mobile */
  .s9-location-map { min-height:280px; }
  /* Agent card: stack if needed */
  .s9-agent-card { padding:14px 16px; gap:10px; }
  /* Card body: ensure readable font */
  .s9-card-body { padding:10px 12px 12px; }
  .s9-card-price { font-size:15px; }
  /* Section padding tighter on small screens */
  .s9-gallery-section { padding:clamp(32px,5vw,52px) 0; }
  .s9-features-section,
  .s9-vert-section,
  .s9-desc-section,
  .s9-floorplan-section,
  .s9-tour-section { padding-top:clamp(32px,5vw,52px); padding-bottom:clamp(32px,5vw,52px); }
  /* Mortgage calculator */
  .s9-mortgage-calc__toggle { padding:16px 18px; }
  .s9-mortgage-calc__title { font-size:14px; }
  /* Listing header */
  .s9-listing__header { flex-direction:column; align-items:flex-start; gap:4px; }
}

/* --- iPhone SE and very small: <375px --- */
@media(max-width:375px) {
  .s9-hero h1 { font-size:26px; }
  .s9-hero-sub { font-size:13px; }
  .s9-hero-price { font-size:22px; }
  .s9-stats-bar { grid-template-columns:1fr; }
  .s9-stat-item { border-right:none; flex-direction:row; justify-content:space-between; padding:12px 16px; }
  .s9-stat-item:nth-child(odd) { border-right:none; }
  .s9-gallery-item { width:85vw!important; height:220px; }
  .s9-feature-item { padding:16px 14px; }
  .s9-feature-name { font-size:13px; }
  .s9-feature-detail { font-size:11px; }
  .s9-card__compare-btn { padding:5px; font-size:0; }
  .s9-card__compare-btn .s9-card__compare-icon { margin:0; }
  .s9-sticky-bar { flex-wrap:wrap; }
  .s9-sticky-name { max-width:50vw; font-size:13px; }
  .s9-sticky-actions .s9-btn-primary { font-size:12px; }
  .s9-compare-tray__item { width:44px; height:33px; }
  .s9-compare-tray__count { font-size:10px; }
  .s9-btn-primary .btn-text { font-size:13px; padding-left:12px; margin-right:8px; }
  .s9-btn-primary .btn-icon { width:32px; height:32px; }
  .s9-btn-primary::before { width:32px; height:32px; }
  /* Touch targets: minimum 44px */
  .s9-filter-chip { min-height:44px; }
  .s9-btn-outline,
  .s9-btn-outline-dark { min-height:44px; }
  .s9-card-fav { width:32px; height:32px; }
}

/* ═══ 21. COMPARE BUTTON ON CARDS ═══ */
.s9-card { position:relative; }
.s9-card__link { display:block; text-decoration:none; color:inherit; border-radius:var(--s9p-radius, 6px); overflow:hidden; }
.s9-card__compare-btn {
  position:absolute; top:12px; right:12px; z-index:3;
  display:flex; align-items:center; gap:5px;
  padding:5px 10px; border:1px solid rgba(225,216,203,.3);
  border-radius:var(--s9p-radius-pill, 30px);
  background:rgba(26,23,20,.7); backdrop-filter:blur(6px);
  color:var(--s9p-cream-80, rgba(225,216,203,.8));
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  font-size:11px; font-weight:500; letter-spacing:.3px;
  cursor:pointer; transition:all .25s ease;
  white-space:nowrap;
}
.s9-card__compare-btn:hover { background:rgba(26,23,20,.9); border-color:rgba(225,216,203,.5); color:var(--s9p-text-on-dark, #e1d8cb); }
.s9-card__compare-btn.s9-card__compare-btn--active {
  background:var(--s9p-btn-hover, #F4EFE7); color:var(--s9p-bg-dark, #1a1714);
  border-color:var(--s9p-btn-hover, #F4EFE7);
}
.s9-card__compare-btn.s9-card__compare-btn--active:hover { background:var(--s9p-beige-light, #ece6dd); }
.s9-card__compare-icon { width:14px; height:14px; flex-shrink:0; }

/* ═══ 22. FLOATING COMPARISON TRAY ═══ */
.s9-compare-tray {
  position:fixed; bottom:0; left:0; right:0; z-index:9999;
  background:var(--s9p-bg-dark, #1a1714);
  border-top:1px solid var(--s9p-cream-15, rgba(225,216,203,.15));
  box-shadow:0 -4px 24px rgba(0,0,0,.3);
  transform:translateY(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.s9-compare-tray[hidden] { display:block!important; pointer-events:none; }
@keyframes s9-tray-shake {
  0%,100% { transform:translateY(0); }
  20%     { transform:translateY(-4px); }
  40%     { transform:translateY(3px); }
  60%     { transform:translateY(-2px); }
  80%     { transform:translateY(1px); }
}
.s9-compare-tray--shake { animation:s9-tray-shake .4s ease; }
.s9-compare-tray.s9-compare-tray--visible {
  transform:translateY(0); pointer-events:auto;
}
.s9-compare-tray__inner {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; gap:16px;
  padding:12px var(--s9p-gutter, clamp(20px,4vw,64px));
}
.s9-compare-tray__items {
  display:flex; gap:10px; flex:1; overflow-x:auto;
  scrollbar-width:none; -ms-overflow-style:none;
}
.s9-compare-tray__items::-webkit-scrollbar { display:none; }

.s9-compare-tray__item {
  position:relative; flex-shrink:0;
  width:72px; height:54px; border-radius:var(--s9p-radius, 6px);
  overflow:hidden; border:2px solid var(--s9p-cream-15, rgba(225,216,203,.15));
  transition:border-color .2s;
}
.s9-compare-tray__item:hover { border-color:var(--s9p-cream-40, rgba(225,216,203,.4)); }
.s9-compare-tray__item img {
  width:100%; height:100%; object-fit:cover; display:block;
}
.s9-compare-tray__item-fallback {
  width:100%; height:100%; background:var(--s9p-dark-surface, #262220);
  display:flex; align-items:center; justify-content:center;
  font-size:8px; color:var(--s9p-cream-40); letter-spacing:2px; text-transform:uppercase;
}
.s9-compare-tray__item-remove {
  position:absolute; top:2px; right:2px;
  width:18px; height:18px; border-radius:50%;
  background:rgba(26,23,20,.8); border:none;
  color:var(--s9p-cream-60, rgba(225,216,203,.6));
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .2s; padding:0;
}
.s9-compare-tray__item-remove:hover { background:var(--s9p-error, #ef4444); color:#fff; }
.s9-compare-tray__item-remove svg { width:10px; height:10px; }

.s9-compare-tray__actions {
  display:flex; align-items:center; gap:12px; flex-shrink:0;
}
.s9-compare-tray__count {
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  font-size:13px; font-weight:500; color:var(--s9p-cream-60, rgba(225,216,203,.6));
  white-space:nowrap;
}
.s9-compare-tray__clear-btn {
  width:32px; height:32px; border-radius:50%;
  background:var(--s9p-dark-surface, #262220);
  border:1px solid var(--s9p-cream-15, rgba(225,216,203,.15));
  color:var(--s9p-cream-60); display:flex; align-items:center;
  justify-content:center; cursor:pointer; transition:all .2s;
  flex-shrink:0; padding:0;
}
.s9-compare-tray__clear-btn:hover { background:var(--s9p-error, #ef4444); color:#fff; border-color:var(--s9p-error, #ef4444); }

/* ═══ 23. COMPARISON PAGE ═══ */
.s9-compare { padding:0 0 clamp(40px,5vw,80px); }
.s9-compare__header {
  padding:clamp(32px,4vw,64px) var(--s9p-gutter, clamp(20px,4vw,64px)) clamp(16px,2vw,32px);
  text-align:center;
}
.s9-compare__title {
  font-family:var(--s9p-font-display, 'Montserrat', sans-serif);
  font-size:clamp(24px,3vw,42px); font-weight:600; letter-spacing:-.02em;
  color:var(--s9p-text-dark, #1a1714); margin:0 0 8px;
}
.s9-compare__subtitle {
  font-size:14px; color:var(--s9p-text-subtle, #9a9088); margin:0;
}

/* Empty state */
.s9-compare__empty {
  text-align:center; padding:clamp(48px,6vw,96px) var(--s9p-gutter);
  color:var(--s9p-text-subtle, #9a9088);
}
.s9-compare__empty svg { margin-bottom:20px; opacity:.4; }
.s9-compare__empty p { font-size:16px; margin:0 0 8px; color:var(--s9p-text-dark, #1a1714); }
.s9-compare__empty-hint { font-size:13px; color:var(--s9p-text-subtle, #9a9088); margin-bottom:28px; }
.s9-compare__back-btn { margin-top:8px; }

/* Table wrapper — horizontal scroll on mobile */
.s9-compare__table-wrap {
  overflow-x:auto; padding:0 var(--s9p-gutter, clamp(20px,4vw,64px));
  -webkit-overflow-scrolling:touch;
}
.s9-compare__table {
  width:100%; min-width:600px; border-collapse:collapse;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
}
.s9-compare__table th,
.s9-compare__table td {
  padding:14px 16px; text-align:left; vertical-align:top;
  border-bottom:1px solid var(--s9p-beige-light, #e8e0d4);
  font-size:13px; color:var(--s9p-text-dark, #1a1714);
}
.s9-compare__table thead th { border-bottom:2px solid var(--s9p-beige-mid, #d4c9b8); }

/* Label column */
.s9-compare__label-col,
.s9-compare__label-cell {
  width:160px; min-width:140px;
  font-weight:600; font-size:12px; letter-spacing:.3px;
  color:var(--s9p-text-subtle, #9a9088); text-transform:uppercase;
  background:var(--s9p-bg-alt, #f8f6f3);
  position:sticky; left:0; z-index:2;
}
.s9-compare__label-cell { font-weight:500; text-transform:none; font-size:13px; }

/* Property column */
.s9-compare__prop-col { min-width:180px; position:relative; }
.s9-compare__prop-card { display:flex; flex-direction:column; gap:8px; position:relative; }
.s9-compare__prop-image {
  width:100%; height:120px; border-radius:var(--s9p-radius, 6px);
  overflow:hidden; background:var(--s9p-beige-light, #e8e0d4);
}
.s9-compare__prop-image img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s ease; }
.s9-compare__prop-image:hover img { transform:scale(1.04); }
.s9-compare__prop-image-fallback {
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  font-size:9px; letter-spacing:3px; color:var(--s9p-text-subtle); text-transform:uppercase;
}
.s9-compare__prop-name {
  font-size:14px; font-weight:600; color:var(--s9p-text-dark, #1a1714);
  text-decoration:none; line-height:1.3; transition:color .2s;
}
.s9-compare__prop-name:hover { color:var(--s9p-text-muted, #6b635b); }
.s9-compare__remove-btn {
  position:absolute; top:4px; right:4px;
  width:24px; height:24px; border-radius:50%;
  background:rgba(26,23,20,.7); backdrop-filter:blur(4px);
  border:1px solid rgba(225,216,203,.2);
  color:var(--s9p-cream-60); display:flex; align-items:center;
  justify-content:center; cursor:pointer; transition:all .2s; padding:0;
}
.s9-compare__remove-btn:hover { background:var(--s9p-error, #ef4444); color:#fff; border-color:var(--s9p-error); }

/* Value cells */
.s9-compare__value-cell { font-weight:400; }
.s9-compare__value-cell strong { font-weight:600; font-size:15px; }
.s9-compare__value-cell--best {
  background:rgba(34,197,94,.06);
  position:relative;
}
.s9-compare__value-cell--best::before {
  content:''; position:absolute; left:0; top:8px; bottom:8px;
  width:3px; background:var(--s9p-success, #22c55e);
  border-radius:0 3px 3px 0;
}

/* Energy badge */
.s9-compare__energy-badge {
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; border-radius:4px;
  color:#fff; font-weight:700; font-size:14px;
}

/* Features list */
.s9-compare__features-list {
  list-style:none; margin:0; padding:0;
  display:flex; flex-wrap:wrap; gap:4px;
}
.s9-compare__features-list li {
  display:inline-block; padding:3px 8px;
  background:var(--s9p-beige-light, #e8e0d4);
  border-radius:3px; font-size:11px;
  color:var(--s9p-text-muted, #6b635b);
}
.s9-compare__features-more { font-style:italic; }

/* Action row */
.s9-compare__action-row td { border-bottom:none; padding-top:20px; }

/* Share */
.s9-compare__share {
  display:flex; justify-content:center; padding:24px var(--s9p-gutter) 0;
}
.s9-compare__share-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 20px; border:1px solid var(--s9p-beige-light, #e8e0d4);
  border-radius:var(--s9p-radius-pill, 30px);
  background:transparent; color:var(--s9p-text-dark, #1a1714);
  font-family:var(--s9p-font); font-size:12px; font-weight:500;
  cursor:pointer; transition:all .25s;
}
.s9-compare__share-btn:hover { background:var(--s9p-bg-dark, #1a1714); color:var(--s9p-text-on-dark, #e1d8cb); border-color:var(--s9p-bg-dark); }
.s9-compare__share-btn.s9-compare__share-btn--copied {
  background:var(--s9p-success, #22c55e); color:#fff; border-color:var(--s9p-success);
}

/* ═══ 24. COMPARE RESPONSIVE ═══ */
@media(max-width:768px) {
  .s9-compare-tray__inner { padding:10px 16px; gap:10px; }
  .s9-compare-tray__item { width:56px; height:42px; }
  .s9-compare-tray__count { font-size:11px; }
  .s9-compare__label-col,
  .s9-compare__label-cell { width:120px; min-width:110px; font-size:11px; padding:10px 12px; }
  .s9-compare__table th,
  .s9-compare__table td { padding:10px 12px; font-size:12px; }
  .s9-compare__prop-image { height:90px; }
  .s9-card__compare-label { display:none; }
  .s9-card__compare-btn { padding:6px; border-radius:50%; }
}
@media(max-width:480px) {
  .s9-compare-tray__item { width:48px; height:36px; }
  .s9-compare-tray__go-btn .btn-text { font-size:12px; }
  .s9-compare__prop-col { min-width:140px; }
}

/* ═══ 25. ZONE PAGES ═══ */

/* -- Zone Detail: Hero -- */
.s9-zone-detail { font-family:var(--s9p-font); }
.s9-zone-hero {
  position:relative; min-height:420px; display:flex; align-items:flex-end;
  padding:clamp(32px,4vw,64px) var(--s9p-gutter); background:var(--s9p-bg-dark);
  overflow:hidden;
}
.s9-zone-hero__bg {
  position:absolute; inset:-40px; background-size:cover; background-position:center;
  opacity:.3; transform:scale(1.03);
}
.s9-zone-hero__overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(26,23,20,.92) 0%, rgba(26,23,20,.2) 100%);
}
.s9-zone-hero__content { position:relative; z-index:2; max-width:720px; }

/* Breadcrumb */
.s9-zone-breadcrumb { display:flex; gap:8px; align-items:center; margin-bottom:18px; flex-wrap:wrap; }
.s9-zone-breadcrumb a,
.s9-zone-breadcrumb span { font-size:12px; color:var(--s9p-cream-60); text-decoration:none; }
.s9-zone-breadcrumb a:hover { color:var(--s9p-text-on-dark); }
.s9-zone-breadcrumb__sep { color:var(--s9p-cream-40); }

.s9-zone-hero__type {
  display:inline-block; font-size:9px; letter-spacing:2px; text-transform:uppercase;
  color:var(--s9p-cream-40); font-weight:500; margin-bottom:8px;
}
.s9-zone-hero__title {
  font-family:var(--s9p-font); font-size:clamp(32px,4.5vw,60px); font-weight:600;
  color:var(--s9p-text-on-dark); line-height:1.1; margin-bottom:12px;
  letter-spacing:-.03em;
}
.s9-zone-hero__desc {
  font-size:clamp(14px,1.4vw,18px); font-weight:300; color:var(--s9p-cream-60);
  line-height:1.7; margin-bottom:16px; max-width:600px;
}
.s9-zone-hero__count {
  font-size:12px; letter-spacing:1px; text-transform:uppercase;
  color:var(--s9p-cream-40); font-weight:500;
}

/* -- Zone Detail: Market Data Cards -- */
.s9-zone-market {
  background:var(--s9p-bg-dark); border-bottom:1px solid var(--s9p-cream-15);
  padding:0 var(--s9p-gutter);
}
.s9-zone-market__grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));
  border-top:1px solid var(--s9p-cream-15);
}
.s9-zone-market__card {
  padding:clamp(20px,2.5vw,32px) 0; display:flex; flex-direction:column;
  align-items:center; gap:6px; border-right:1px solid var(--s9p-cream-15);
  text-align:center;
}
.s9-zone-market__card:last-child { border-right:none; }
.s9-zone-market__label {
  font-size:10px; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--s9p-cream-40); font-weight:500;
}
.s9-zone-market__value {
  font-family:var(--s9p-font); font-size:clamp(20px,2vw,28px); font-weight:600;
  color:var(--s9p-text-on-dark); line-height:1; letter-spacing:-.01em;
}
.s9-zone-market__value--up { color:var(--s9p-success, #22c55e); }
.s9-zone-market__value--down { color:var(--s9p-error, #ef4444); }

/* -- Zone Detail: Description -- */
.s9-zone-description {
  padding:clamp(52px,6vw,84px) var(--s9p-gutter);
  background:var(--s9p-bg-alt, #f8f6f3);
}
.s9-zone-description__inner { max-width:800px; }
.s9-zone-description__text {
  font-size:clamp(15px,1.4vw,18px); font-weight:300;
  color:var(--s9p-text-muted, #6b635b); line-height:1.85;
}
.s9-zone-description__text p { margin:0 0 16px; }
.s9-zone-description__text strong { color:var(--s9p-text-dark); font-weight:500; }

/* -- Zone Cards (shared: sub-zones, related, listing) -- */
.s9-zone-subzones,
.s9-zone-related {
  padding:clamp(52px,6vw,84px) var(--s9p-gutter);
  background:var(--s9p-white, #fff);
  border-top:1px solid var(--s9p-beige-light, #ece6dd);
}
.s9-zone-subzones__inner,
.s9-zone-related__inner { max-width:1200px; }
.s9-zone-subzones__grid {
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:clamp(16px,2vw,24px); margin-top:32px;
}
.s9-zone-card {
  display:block; border-radius:var(--s9p-radius, 6px); overflow:hidden;
  transition:transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s;
  text-decoration:none; color:inherit;
  background:var(--s9p-white, #fff);
  border:1px solid var(--s9p-beige-light, #ece6dd);
}
.s9-zone-card:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.08); }
.s9-zone-card__image {
  position:relative; height:clamp(160px,14vw,220px); overflow:hidden;
}
.s9-zone-card__image img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.s9-zone-card:hover .s9-zone-card__image img { transform:scale(1.05); }
.s9-zone-card__placeholder {
  width:100%; height:100%;
  background:var(--s9p-beige-light, #ece6dd);
  display:flex; align-items:center; justify-content:center;
}
.s9-zone-card__placeholder span {
  font-family:var(--s9p-font-display, 'Montserrat', sans-serif);
  font-size:28px; font-weight:700; letter-spacing:2px;
  color:var(--s9p-text-subtle, #9a9088); text-transform:uppercase;
}
.s9-zone-card__type-badge {
  position:absolute; top:10px; left:10px;
  background:var(--s9p-bg-dark, #1a1714); color:var(--s9p-text-on-dark, #e1d8cb);
  padding:3px 9px; border-radius:3px; font-size:9px; font-weight:500;
  letter-spacing:1.5px; text-transform:uppercase; z-index:2;
}
.s9-zone-card__body { padding:14px 16px 16px; }
.s9-zone-card__name {
  font-family:var(--s9p-font); font-size:clamp(16px,1.4vw,20px);
  font-weight:600; color:var(--s9p-text-dark, #1a1714);
  line-height:1.3; margin:0 0 6px;
}
.s9-zone-card__stats { display:flex; flex-wrap:wrap; gap:8px 16px; }
.s9-zone-card__count,
.s9-zone-card__price,
.s9-zone-card__avg {
  font-size:12px; color:var(--s9p-text-subtle, #9a9088);
}
.s9-zone-card__price { font-weight:500; color:var(--s9p-text-muted, #6b635b); }

/* -- Zone Detail: Properties section -- */
.s9-zone-properties {
  padding:clamp(52px,6vw,84px) var(--s9p-gutter);
  background:var(--s9p-bg-alt, #f8f6f3);
  border-top:1px solid var(--s9p-beige-light, #ece6dd);
}
.s9-zone-properties__inner { max-width:1200px; }
.s9-zone-properties__header {
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; margin-bottom:32px; flex-wrap:wrap;
}

/* -- Zone Listing Page -- */
.s9-zone-listing-page { background:var(--s9p-bg-alt, #f8f6f3); }
.s9-zone-listing__header {
  padding:clamp(32px,4vw,64px) var(--s9p-gutter) clamp(16px,2vw,24px);
  background:var(--s9p-white, #fff);
  border-bottom:1px solid var(--s9p-beige-light, #ece6dd);
}
.s9-zone-listing__header-inner { max-width:1200px; }
.s9-zone-listing__title {
  font-family:var(--s9p-font); font-size:clamp(24px,3vw,38px);
  font-weight:600; color:var(--s9p-text-dark, #1a1714);
  letter-spacing:-.02em; margin-bottom:4px;
}
.s9-zone-listing__count {
  font-size:13px; color:var(--s9p-text-subtle, #9a9088);
}
.s9-zone-listing__grid {
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:clamp(16px,2vw,24px);
  padding:clamp(24px,3vw,40px) var(--s9p-gutter) clamp(40px,5vw,72px);
  max-width:1200px;
}

/* -- Zone Page Body class -- */
body.s9-zone-page { font-family:var(--s9p-font); }

/* ═══ 26. ZONE PAGES RESPONSIVE ═══ */
@media(max-width:1024px) {
  .s9-zone-subzones__grid,
  .s9-zone-listing__grid { grid-template-columns:repeat(2, 1fr); }
}
@media(max-width:768px) {
  .s9-zone-hero { min-height:auto; padding-top:80px; }
  .s9-zone-hero__title { font-size:clamp(28px,6vw,42px); }
  .s9-zone-properties__header { flex-direction:column; align-items:flex-start; gap:12px; }
  .s9-zone-card__body { padding:12px 14px 14px; }
  .s9-zone-card__name { font-size:15px; }
}
@media(max-width:640px) {
  .s9-zone-hero { min-height:280px; }
  .s9-zone-market__grid { grid-template-columns:repeat(2, 1fr); }
  .s9-zone-market__card { border-right:none; border-bottom:1px solid var(--s9p-cream-15); }
  .s9-zone-subzones__grid,
  .s9-zone-listing__grid { grid-template-columns:1fr; }
}
@media(max-width:375px) {
  .s9-zone-hero { padding-top:60px; }
  .s9-zone-hero__title { font-size:24px; }
  .s9-zone-hero__desc { font-size:13px; }
  .s9-zone-market__grid { grid-template-columns:1fr; }
}

/* ═══ 27. GALLERY LIGHTBOX ═══ */

/* Gallery items: clickable cursor */
.s9-gallery-item[data-s9-lightbox] { cursor:pointer; }

/* Hero gallery CTA */
.s9-hero-gallery-cta {
  position:absolute; bottom:clamp(24px,3vw,48px); left:50%; transform:translateX(-50%); z-index:3;
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 22px; border-radius:var(--s9p-radius-pill);
  background:rgba(26,23,20,.7); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--s9p-cream-15);
  color:var(--s9p-cream-80); font-family:var(--s9p-font); font-size:13px; font-weight:400;
  letter-spacing:.3px; cursor:pointer; transition:all .3s var(--s9p-ease);
  white-space:nowrap;
}
.s9-hero-gallery-cta:hover { background:rgba(26,23,20,.9); border-color:var(--s9p-cream-40); color:var(--s9p-text-on-dark); }
.s9-hero-gallery-cta svg { flex-shrink:0; opacity:.7; transition:opacity .3s; }
.s9-hero-gallery-cta:hover svg { opacity:1; }

/* Overlay */
.s9-lightbox-overlay {
  position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,.95);
  opacity:0; transition:opacity .25s ease;
  display:flex; flex-direction:column;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.s9-lightbox-overlay.s9-lightbox--visible { opacity:1; }

/* Top bar: counter + close */
.s9-lightbox-topbar {
  position:absolute; top:0; left:0; right:0; z-index:10;
  display:flex; justify-content:space-between; align-items:center;
  padding:20px clamp(16px,3vw,32px);
  pointer-events:none;
}
.s9-lightbox-counter {
  font-size:13px; font-weight:400; color:rgba(225,216,203,.6);
  letter-spacing:.5px; pointer-events:auto; user-select:none;
}
.s9-lightbox-close {
  width:44px; height:44px; border-radius:50%;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  color:rgba(225,216,203,.8); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s, color .2s;
  pointer-events:auto; flex-shrink:0;
}
.s9-lightbox-close:hover { background:rgba(255,255,255,.15); border-color:rgba(255,255,255,.25); color:#fff; }

/* Main stage (image area) */
.s9-lightbox-stage {
  flex:1; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden; min-height:0;
  padding:70px 64px 120px;
  user-select:none; -webkit-user-select:none;
}

/* Image wrapper — holds the current image */
.s9-lightbox-img-wrap {
  position:relative; display:flex; align-items:center; justify-content:center;
  max-width:100%; max-height:100%; width:100%; height:100%;
}
.s9-lightbox-img {
  max-width:100%; max-height:100%; object-fit:contain;
  opacity:0; transition:opacity .2s ease;
  will-change:transform;
  cursor:zoom-in;
  user-select:none; -webkit-user-select:none;
  -webkit-user-drag:none;
}
.s9-lightbox-img.s9-lightbox--loaded { opacity:1; }
.s9-lightbox-img.s9-lightbox--zoomed { cursor:grab; }
.s9-lightbox-img.s9-lightbox--zoomed.s9-lightbox--panning { cursor:grabbing; }

/* Caption */
.s9-lightbox-caption {
  position:absolute; bottom:120px; left:0; right:0;
  text-align:center; padding:0 20px;
  font-size:13px; font-weight:300; color:rgba(225,216,203,.5);
  letter-spacing:.3px; line-height:1.5;
  pointer-events:none; user-select:none;
  opacity:0; transition:opacity .2s ease;
}
.s9-lightbox-caption.s9-lightbox--has-text { opacity:1; }

/* Navigation arrows */
.s9-lightbox-nav {
  position:absolute; top:50%; z-index:5;
  transform:translateY(-50%);
  width:52px; height:52px; border-radius:50%;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  color:rgba(225,216,203,.7); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s, color .2s, opacity .2s;
  opacity:.7;
}
.s9-lightbox-nav:hover { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.2); color:#fff; opacity:1; }
.s9-lightbox-nav:disabled { opacity:.15; cursor:default; pointer-events:none; }
.s9-lightbox-nav--prev { left:clamp(12px,2vw,28px); }
.s9-lightbox-nav--next { right:clamp(12px,2vw,28px); }

/* Thumbnail strip */
.s9-lightbox-thumbs {
  position:absolute; bottom:0; left:0; right:0; z-index:10;
  background:linear-gradient(to top, rgba(0,0,0,.8) 0%, rgba(0,0,0,.4) 60%, transparent 100%);
  padding:16px clamp(16px,3vw,40px) 18px;
  display:flex; align-items:center; justify-content:center; gap:6px;
  overflow-x:auto; scrollbar-width:none; -ms-overflow-style:none;
}
.s9-lightbox-thumbs::-webkit-scrollbar { display:none; }

.s9-lightbox-thumb {
  flex-shrink:0; width:56px; height:40px; border-radius:4px;
  overflow:hidden; cursor:pointer;
  border:2px solid transparent;
  opacity:.45; transition:opacity .2s, border-color .2s;
}
.s9-lightbox-thumb:hover { opacity:.75; }
.s9-lightbox-thumb.s9-lightbox-thumb--active {
  opacity:1; border-color:var(--s9p-btn-hover, #F4EFE7);
}
.s9-lightbox-thumb img {
  width:100%; height:100%; object-fit:cover; display:block;
  pointer-events:none;
}

/* Loading spinner */
.s9-lightbox-spinner {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:32px; height:32px; border:2px solid rgba(225,216,203,.15);
  border-top-color:rgba(225,216,203,.6); border-radius:50%;
  animation:s9-lb-spin .8s linear infinite;
  pointer-events:none;
}
@keyframes s9-lb-spin { to { transform:translate(-50%,-50%) rotate(360deg); } }

/* Responsive: Lightbox */
@media(max-width:768px) {
  .s9-lightbox-stage { padding:60px 12px 100px; }
  .s9-lightbox-nav { width:40px; height:40px; }
  .s9-lightbox-nav svg { width:18px; height:18px; }
  .s9-lightbox-thumb { width:44px; height:32px; }
  .s9-lightbox-caption { bottom:100px; font-size:12px; }
}
@media(max-width:480px) {
  .s9-lightbox-stage { padding:56px 8px 60px; }
  .s9-lightbox-nav { width:36px; height:36px; }
  .s9-lightbox-nav--prev { left:6px; }
  .s9-lightbox-nav--next { right:6px; }
  .s9-lightbox-thumbs { display:none; }
  .s9-lightbox-caption { bottom:14px; font-size:11px; }
  .s9-lightbox-topbar { padding:14px 14px; }
  .s9-lightbox-close { width:38px; height:38px; }
  .s9-hero-gallery-cta { font-size:12px; padding:8px 18px; }
}

/* ── TOAST NOTIFICATIONS (PUBLIC) ── */

.s9-toast-container {
  position: fixed;
  bottom: 16px;
  right: 16px;
  z-index: 9990;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
  max-width: 420px;
  width: 100%;
}

.s9-toast {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  background: var(--s9p-card-bg, #fff);
  color: var(--s9p-text, #1a1714);
  border: 1px solid var(--s9p-border, #d4c9b8);
  border-left: 4px solid var(--s9p-text-subtle, #9a9088);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.12), 0 2px 8px rgba(0,0,0,.08);
  font-family: var(--s9p-font, 'Host Grotesk', sans-serif);
  font-size: 13px;
  line-height: 1.45;
  pointer-events: auto;
  position: relative;
  overflow: hidden;
  transform: translateX(100%);
  opacity: 0;
  transition: none;
}

.s9-toast--enter {
  animation: s9-toast-slideIn 0.3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.s9-toast--dismiss {
  animation: s9-toast-slideOut 0.3s cubic-bezier(0.55, 0, 1, 0.45) forwards;
}

@keyframes s9-toast-slideIn {
  from { transform: translateX(100%); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

@keyframes s9-toast-slideOut {
  from { transform: translateX(0);    opacity: 1; }
  to   { transform: translateX(100%); opacity: 0; }
}

.s9-toast--success { border-left-color: var(--s9p-success, #22c55e); }
.s9-toast--error   { border-left-color: var(--s9p-error, #ef4444); }
.s9-toast--warning { border-left-color: var(--s9p-warning, #f59e0b); }
.s9-toast--info    { border-left-color: var(--s9p-info, #3b82f6); }

.s9-toast--success .s9-toast__icon { color: var(--s9p-success, #22c55e); }
.s9-toast--error   .s9-toast__icon { color: var(--s9p-error, #ef4444); }
.s9-toast--warning .s9-toast__icon { color: var(--s9p-warning, #f59e0b); }
.s9-toast--info    .s9-toast__icon { color: var(--s9p-info, #3b82f6); }

.s9-toast__icon-wrap {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  padding-top: 1px;
}

.s9-toast__icon {
  width: 18px;
  height: 18px;
}

.s9-toast__message {
  flex: 1;
  min-width: 0;
  word-break: break-word;
}

.s9-toast__close {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  margin: -4px -4px -4px 0;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--s9p-text-subtle, #9a9088);
  cursor: pointer;
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
}

.s9-toast__close:hover {
  color: var(--s9p-text, #1a1714);
  background: var(--s9p-beige-light, #ece6dd);
}

.s9-toast__progress {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: transparent;
}

.s9-toast__progress-bar {
  height: 100%;
  width: 100%;
  transform-origin: left;
  animation: s9-toast-progress linear forwards;
  border-radius: 0 0 0 8px;
}

.s9-toast--success .s9-toast__progress-bar { background: var(--s9p-success, #22c55e); }
.s9-toast--error   .s9-toast__progress-bar { background: var(--s9p-error, #ef4444); }
.s9-toast--warning .s9-toast__progress-bar { background: var(--s9p-warning, #f59e0b); }
.s9-toast--info    .s9-toast__progress-bar { background: var(--s9p-info, #3b82f6); }

@keyframes s9-toast-progress {
  from { transform: scaleX(1); }
  to   { transform: scaleX(0); }
}

@media (max-width: 767px) {
  .s9-toast-container {
    right: 0;
    left: 0;
    bottom: 0;
    max-width: 100%;
    padding: 8px;
    gap: 6px;
  }
  .s9-toast {
    border-radius: 8px;
  }
  .s9-toast--enter {
    animation-name: s9-toast-slideUp;
  }
  .s9-toast--dismiss {
    animation-name: s9-toast-fadeOut;
  }
  @keyframes s9-toast-slideUp {
    from { transform: translateY(100%); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
  }
  @keyframes s9-toast-fadeOut {
    from { opacity: 1; }
    to   { opacity: 0; }
  }
}

/* ═══ 28. SHARE BAR (property detail) ═══ */
.s9-share-bar {
  background:var(--bg-surface);
  border-bottom:1px solid var(--border-color);
  padding:0 var(--s9p-gutter);
}
.s9-share-bar__inner {
  display:flex;
  align-items:center;
  gap:2px;
  padding:10px 0;
  overflow-x:auto;
  scrollbar-width:none;
}
.s9-share-bar__inner::-webkit-scrollbar { display:none; }
.s9-share-bar__btn {
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:8px 16px;
  font-family:var(--s9p-font);
  font-size:12px;
  font-weight:400;
  color:var(--text-muted);
  background:transparent;
  border:1px solid var(--border-color);
  border-radius:var(--s9p-radius-pill, 30px);
  cursor:pointer;
  transition:all .25s ease;
  white-space:nowrap;
  text-decoration:none;
}
.s9-share-bar__btn:hover {
  background:var(--bg-raised);
  border-color:var(--s9p-cream-30);
  color:var(--text-primary);
}
.s9-share-bar__btn svg { flex-shrink:0; }
.s9-share-bar__btn--whatsapp { color:#25D366; border-color:rgba(37,211,102,.3); }
.s9-share-bar__btn--whatsapp:hover { background:rgba(37,211,102,.1); border-color:#25D366; color:#25D366; }
.s9-share-bar__btn--copied {
  background:var(--s9p-success, #22c55e) !important;
  color:#fff !important;
  border-color:var(--s9p-success, #22c55e) !important;
}
.s9-share-bar__btn--optional { opacity:.6; }
.s9-share-bar__btn--optional:hover { opacity:1; }

@media(max-width:640px) {
  .s9-share-bar__btn span { display:none; }
  .s9-share-bar__btn { padding:8px 10px; }
  .s9-share-bar__btn--optional { display:none; }
}

/* ═══ 29. FAVORITE BUTTON (cards) ═══ */
.s9-card__fav-btn {
  position:absolute;
  top:12px;
  left:12px;
  z-index:3;
  width:32px;
  height:32px;
  border-radius:50%;
  background:rgba(26,23,20,.6);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  border:1px solid rgba(225,216,203,.2);
  color:var(--s9p-cream-80, rgba(225,216,203,.8));
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .25s ease;
  padding:0;
}
.s9-card__fav-btn:hover {
  background:rgba(26,23,20,.85);
  border-color:rgba(225,216,203,.4);
  transform:scale(1.1);
}
.s9-card__fav-btn.s9-card__fav-btn--active {
  background:rgba(239,68,68,.9);
  border-color:rgba(239,68,68,.9);
  color:#fff;
}
.s9-card__fav-btn.s9-card__fav-btn--active svg {
  fill:#fff;
  stroke:#fff;
}
.s9-card__fav-btn.s9-card__fav-btn--active:hover {
  background:rgba(239,68,68,1);
}
@keyframes s9-fav-pop {
  0%   { transform:scale(1); }
  40%  { transform:scale(1.3); }
  100% { transform:scale(1); }
}
.s9-card__fav-btn--pop {
  animation:s9-fav-pop .35s cubic-bezier(.4,0,.2,1);
}

/* ═══ 30. SHARE BUTTON (cards) ═══ */
.s9-card__share-btn {
  position:absolute;
  bottom:12px;
  right:12px;
  z-index:3;
  width:30px;
  height:30px;
  border-radius:50%;
  background:rgba(26,23,20,.6);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  border:1px solid rgba(225,216,203,.2);
  color:var(--s9p-cream-80, rgba(225,216,203,.8));
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .25s ease;
  padding:0;
}
.s9-card__share-btn:hover {
  background:rgba(26,23,20,.85);
  border-color:rgba(225,216,203,.4);
}

/* Share popover */
.s9-card-share-popover {
  position:absolute;
  bottom:48px;
  right:8px;
  z-index:20;
  background:var(--s9p-bg-dark, #1a1714);
  border:1px solid var(--s9p-cream-15, rgba(225,216,203,.15));
  border-radius:10px;
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:170px;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  animation:s9-popover-in .2s ease;
}
@keyframes s9-popover-in {
  from { opacity:0; transform:translateY(6px) scale(.96); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
.s9-card-share-popover::after {
  content:'';
  position:absolute;
  bottom:-6px;
  right:14px;
  width:12px;
  height:12px;
  background:var(--s9p-bg-dark, #1a1714);
  border-right:1px solid var(--s9p-cream-15, rgba(225,216,203,.15));
  border-bottom:1px solid var(--s9p-cream-15, rgba(225,216,203,.15));
  transform:rotate(45deg);
}
.s9-card-share-popover__btn {
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  font-family:var(--s9p-font);
  font-size:12px;
  font-weight:400;
  color:var(--s9p-cream-60, rgba(225,216,203,.6));
  background:transparent;
  border:none;
  border-radius:6px;
  cursor:pointer;
  transition:all .15s ease;
  white-space:nowrap;
  text-decoration:none;
}
.s9-card-share-popover__btn:hover {
  background:var(--s9p-dark-light, #2c2824);
  color:var(--s9p-text-on-dark, #e1d8cb);
}
.s9-card-share-popover__btn--wa { color:#25D366; }
.s9-card-share-popover__btn--wa:hover { color:#25D366; }
.s9-card-share-popover__btn svg { flex-shrink:0; }
.s9-card-share-popover__btn--copied {
  color:var(--s9p-success, #22c55e) !important;
}

/* ═══ 31. DETAIL PAGE FAVORITE BUTTON ═══ */
.s9-detail-fav-btn.s9-detail-fav-btn--active {
  border-color:rgba(239,68,68,.5);
  color:#EF4444;
}
.s9-detail-fav-btn.s9-detail-fav-btn--active .s9-detail-fav-icon {
  fill:#EF4444;
  stroke:#EF4444;
}

/* ═══ 32. STICKY BAR FAVORITES ═══ */
.s9-sticky-fav-btn {
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--s9p-dark-light, #2c2824);
  border:1px solid var(--s9p-cream-15, rgba(225,216,203,.15));
  color:var(--s9p-cream-60);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .25s ease;
  padding:0;
}
.s9-sticky-fav-btn:hover {
  border-color:var(--s9p-cream-30);
}
.s9-sticky-fav-btn.s9-sticky-fav-btn--active {
  background:rgba(239,68,68,.15);
  border-color:rgba(239,68,68,.5);
  color:#EF4444;
}
.s9-sticky-fav-btn.s9-sticky-fav-btn--active .s9-sticky-fav-icon {
  fill:#EF4444;
  stroke:#EF4444;
}
.s9-sticky-favs-counter {
  display:flex;
  align-items:center;
  gap:4px;
  padding:6px 12px;
  background:var(--s9p-dark-light, #2c2824);
  border:1px solid var(--s9p-cream-15, rgba(225,216,203,.15));
  border-radius:var(--s9p-radius-pill, 30px);
  color:var(--s9p-cream-60);
  font-family:var(--s9p-font);
  font-size:12px;
  font-weight:500;
  text-decoration:none;
  transition:all .25s ease;
}
.s9-sticky-favs-counter:hover {
  border-color:var(--s9p-cream-30);
  color:var(--s9p-text-on-dark);
}
.s9-sticky-favs-badge {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:18px;
  height:18px;
  padding:0 5px;
  background:#EF4444;
  color:#fff;
  border-radius:10px;
  font-size:10px;
  font-weight:700;
  line-height:1;
}

/* ═══ 33. FAVORITES FILTER (listing) ═══ */
.s9-listing__header {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:clamp(16px,2vw,28px) var(--s9p-gutter, clamp(20px,4vw,64px)) 0;
}
.s9-listing__actions {
  display:flex;
  gap:8px;
  align-items:center;
}
.s9-favorites-filter {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 16px;
  font-family:var(--s9p-font);
  font-size:12px;
  font-weight:500;
  color:var(--s9p-text-muted, #6b635b);
  background:transparent;
  border:1px solid var(--s9p-beige-light, #e8e0d4);
  border-radius:var(--s9p-radius-pill, 30px);
  cursor:pointer;
  transition:all .25s ease;
  white-space:nowrap;
}
.s9-favorites-filter:hover {
  border-color:var(--s9p-text-muted);
  color:var(--s9p-text-dark);
}
.s9-favorites-filter[aria-pressed="true"] {
  background:#EF4444;
  color:#fff;
  border-color:#EF4444;
}
.s9-favorites-filter[aria-pressed="true"] svg {
  fill:#fff;
  stroke:#fff;
}
.s9-favorites-filter__count {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:18px;
  height:18px;
  padding:0 5px;
  background:var(--s9p-bg-dark, #1a1714);
  color:var(--s9p-text-on-dark, #e1d8cb);
  border-radius:10px;
  font-size:10px;
  font-weight:700;
  line-height:1;
}
.s9-favorites-filter[aria-pressed="true"] .s9-favorites-filter__count {
  background:rgba(255,255,255,.25);
  color:#fff;
}

/* Hide non-favorite cards when filter is active */
.s9-listing__grid--favs-only .s9-card:not(.s9-card--favorited) {
  display:none;
}

/* ═══ 34b. SAVE SEARCH (listing page) ═══ */

.s9-save-search-btn {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 16px;
  font-family:var(--s9p-font);
  font-size:12px;
  font-weight:500;
  color:var(--s9p-text-muted, #6b635b);
  background:transparent;
  border:1px solid var(--s9p-beige-light, #e8e0d4);
  border-radius:var(--s9p-radius-pill, 30px);
  cursor:pointer;
  transition:all .25s ease;
  white-space:nowrap;
}
.s9-save-search-btn:hover {
  border-color:var(--s9p-text-muted);
  color:var(--s9p-text-dark);
  background:rgba(225,216,203,.08);
}
.s9-save-search-btn svg {
  flex-shrink:0;
}

/* Modal overlay */
.s9-save-search-overlay {
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  z-index:9000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
}

.s9-save-search-modal {
  background:var(--bg-surface, #fff);
  border-radius:12px;
  box-shadow:0 8px 32px rgba(0,0,0,.18);
  width:100%;
  max-width:420px;
  overflow:hidden;
  animation:s9-modal-in .25s ease;
}

@keyframes s9-modal-in {
  from { opacity:0; transform:scale(.96) translateY(8px); }
  to { opacity:1; transform:scale(1) translateY(0); }
}

.s9-save-search-modal__header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 20px;
  border-bottom:1px solid var(--border-color, rgba(225,216,203,.15));
}

.s9-save-search-modal__title {
  font-family:var(--s9p-font);
  font-size:16px;
  font-weight:600;
  color:var(--text-primary);
  margin:0;
}

.s9-save-search-modal__close {
  background:none;
  border:none;
  color:var(--text-secondary);
  cursor:pointer;
  padding:4px;
  border-radius:6px;
  transition:all .15s;
}
.s9-save-search-modal__close:hover { color:var(--text-primary); background:rgba(225,216,203,.1); }

.s9-save-search-modal__body {
  padding:20px;
}

.s9-save-search-modal__field {
  margin-bottom:16px;
}
.s9-save-search-modal__field:last-child { margin-bottom:0; }

.s9-save-search-modal__label {
  display:block;
  font-family:var(--s9p-font);
  font-size:11px;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--text-secondary);
  margin-bottom:6px;
}

.s9-save-search-modal__input {
  width:100%;
  padding:10px 14px;
  font-family:var(--s9p-font);
  font-size:14px;
  border:1px solid var(--border-color, rgba(225,216,203,.2));
  border-radius:8px;
  background:var(--bg, transparent);
  color:var(--text-primary);
  outline:none;
  transition:border-color .2s;
  box-sizing:border-box;
}
.s9-save-search-modal__input:focus {
  border-color:rgba(225,216,203,.5);
}
.s9-save-search-modal__input::placeholder { color:var(--text-muted); }

.s9-save-search-modal__pills {
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.s9-save-search-modal__pill {
  display:inline-block;
  padding:4px 10px;
  font-family:var(--s9p-font);
  font-size:11px;
  font-weight:500;
  background:rgba(225,216,203,.12);
  color:var(--text-secondary);
  border-radius:20px;
  white-space:nowrap;
}

/* Toggle */
.s9-save-search-modal__toggle-wrap {
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
}
.s9-save-search-modal__checkbox {
  width:18px;
  height:18px;
  accent-color:var(--s9p-success, #22c55e);
  cursor:pointer;
}
.s9-save-search-modal__toggle-label {
  font-family:var(--s9p-font);
  font-size:13px;
  color:var(--text-primary);
}

/* Frequency pills */
.s9-save-search-modal__freq-pills {
  display:flex;
  gap:0;
}
.s9-save-search-modal__freq-pill {
  padding:7px 16px;
  border:1px solid var(--border-color, rgba(225,216,203,.2));
  background:transparent;
  color:var(--text-secondary);
  font-family:var(--s9p-font);
  font-size:12px;
  font-weight:400;
  cursor:pointer;
  transition:all .2s;
}
.s9-save-search-modal__freq-pill:first-child { border-radius:20px 0 0 20px; }
.s9-save-search-modal__freq-pill:last-child { border-radius:0 20px 20px 0; border-left:none; }
.s9-save-search-modal__freq-pill:hover { background:rgba(225,216,203,.08); }
.s9-save-search-modal__freq-pill--active {
  background:rgba(225,216,203,.15) !important;
  color:var(--text-primary) !important;
  border-color:rgba(225,216,203,.3) !important;
  font-weight:500;
}

/* Login message */
.s9-save-search-modal__login-msg {
  display:flex;
  align-items:center;
  gap:8px;
  padding:12px 16px;
  background:rgba(234,179,8,.1);
  border:1px solid rgba(234,179,8,.2);
  border-radius:8px;
  font-family:var(--s9p-font);
  font-size:13px;
  color:#ca8a04;
}

/* Footer */
.s9-save-search-modal__footer {
  display:flex;
  justify-content:flex-end;
  gap:8px;
  padding:12px 20px;
  border-top:1px solid var(--border-color, rgba(225,216,203,.15));
}
.s9-save-search-modal__cancel {
  padding:8px 16px;
  font-family:var(--s9p-font);
  font-size:13px;
  font-weight:500;
  color:var(--text-secondary);
  background:transparent;
  border:1px solid var(--border-color, rgba(225,216,203,.2));
  border-radius:6px;
  cursor:pointer;
  transition:all .15s;
}
.s9-save-search-modal__cancel:hover { color:var(--text-primary); border-color:rgba(225,216,203,.4); }
.s9-save-search-modal__submit {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 20px;
  font-family:var(--s9p-font);
  font-size:13px;
  font-weight:600;
  color:#fff;
  background:#1a1a2e;
  border:none;
  border-radius:6px;
  cursor:pointer;
  transition:background .2s;
}
.s9-save-search-modal__submit:hover { background:#2a2a3e; }
.s9-save-search-modal__submit:disabled { opacity:.5; cursor:not-allowed; }
.s9-save-search-modal__submit svg { flex-shrink:0; }

@media (max-width:600px) {
  .s9-save-search-modal {
    max-width:calc(100vw - 32px);
  }
  .s9-save-search-btn span {
    display:none;
  }
}

/* ═══ 35. AGENT PROFILE PAGE ═══ */

/* Hero */
.s9-agent-hero {
  position:relative; min-height:520px; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  padding:clamp(100px,12vh,160px) var(--s9p-gutter) clamp(60px,8vh,100px);
  background:var(--s9p-bg-dark);
}
.s9-agent-hero__bg {
  position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 30%, rgba(225,216,203,.06) 0%, transparent 60%);
  pointer-events:none;
}
.s9-agent-hero__overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(26,23,20,.95) 0%, rgba(26,23,20,.7) 50%, rgba(26,23,20,.85) 100%);
}
.s9-agent-hero__content {
  position:relative; z-index:2;
  display:flex; flex-direction:column; align-items:center;
  text-align:center; max-width:640px;
}
.s9-agent-hero__bc {
  margin-bottom:28px;
  opacity:0; transform:translateY(10px);
}

/* Photo */
.s9-agent-hero__photo-wrap {
  width:clamp(120px,15vw,180px); height:clamp(120px,15vw,180px);
  border-radius:50%; overflow:hidden;
  border:3px solid rgba(225,216,203,.2);
  margin-bottom:24px;
  box-shadow:0 8px 40px rgba(0,0,0,.4);
}
.s9-agent-hero__photo {
  width:100%; height:100%; object-fit:cover; display:block;
}
.s9-agent-hero__photo-fallback {
  width:100%; height:100%;
  background:var(--s9p-dark-btn);
  display:flex; align-items:center; justify-content:center;
  font-size:clamp(32px,4vw,48px); font-weight:600;
  color:var(--s9p-cream-60);
  font-family:var(--s9p-font);
}

/* Name / Role */
.s9-agent-hero__name {
  font-family:var(--s9p-font);
  font-size:clamp(32px,4.5vw,56px); font-weight:600;
  color:var(--s9p-text-on-dark);
  line-height:1.1; letter-spacing:-.03em;
  margin-bottom:8px;
  opacity:0; transform:translateY(16px);
}
.s9-agent-hero__role {
  font-size:clamp(14px,1.4vw,18px); font-weight:300;
  color:var(--s9p-cream-60);
  margin-bottom:16px;
  opacity:0; transform:translateY(10px);
}

/* Agency in hero */
.s9-agent-hero__agency {
  display:flex; align-items:center; gap:8px;
  margin-bottom:20px;
  opacity:0; transform:translateY(10px);
}
.s9-agent-hero__agency-logo {
  height:22px; width:auto; opacity:.7;
}
.s9-agent-hero__agency span {
  font-size:13px; color:var(--s9p-cream-40);
  font-weight:400; letter-spacing:.5px;
}

/* Spec tags in hero */
.s9-agent-hero__specs {
  display:flex; gap:8px; flex-wrap:wrap;
  justify-content:center;
  opacity:0; transform:translateY(10px);
}
.s9-agent-hero__spec-tag {
  padding:5px 14px;
  border:1px solid var(--s9p-cream-15);
  border-radius:var(--s9p-radius-pill);
  font-size:11px; font-weight:400;
  color:var(--s9p-cream-60);
  letter-spacing:.5px;
}

/* Stats bar on agent page */
.s9-agent-stats-bar {
  grid-template-columns:repeat(4,1fr);
}

/* Bio + Sidebar layout */
.s9-agent-body {
  padding:clamp(52px,7vw,92px) var(--s9p-gutter);
  display:grid;
  grid-template-columns:1fr 360px;
  gap:clamp(40px,5vw,80px);
  border-top:1px solid var(--border-color);
}
.s9-agent-body__main { min-width:0; }

/* Bio text */
.s9-agent-bio {
  font-size:clamp(15px,1.4vw,18px); font-weight:300;
  color:var(--text-secondary); line-height:1.9;
}
.s9-agent-bio p { margin-bottom:16px; }
.s9-agent-bio strong { color:var(--text-primary); font-weight:500; }

/* Specializations grid */
.s9-agent-specs-grid {
  display:flex; flex-wrap:wrap; gap:8px; margin-top:16px;
}
.s9-agent-spec-item {
  padding:10px 20px;
  background:var(--bg-surface);
  border:1px solid var(--border-color);
  border-radius:var(--s9p-radius);
  font-size:13px; font-weight:400;
  color:var(--text-secondary);
  transition:border-color var(--s9p-transition);
}
.s9-agent-spec-item:hover { border-color:var(--s9p-cream-30); }

/* Language tags */
.s9-agent-langs { display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.s9-agent-lang-tag {
  padding:6px 16px;
  background:var(--bg-surface);
  border:1px solid var(--border-color);
  border-radius:var(--s9p-radius-pill);
  font-size:12px; font-weight:400;
  color:var(--text-secondary);
}

/* ── Contact Card (sidebar) ── */
.s9-agent-contact-card {
  background:var(--card-bg);
  border:1px solid var(--border-color);
  border-radius:var(--s9p-radius-lg);
  padding:26px;
  margin-bottom:14px;
}
.s9-agent-contact-row {
  display:flex; align-items:center; gap:12px;
  padding:12px 0;
  border-bottom:1px solid var(--border-color);
  font-size:13px; color:var(--text-secondary);
  transition:color var(--s9p-transition-fast);
  text-decoration:none;
}
.s9-agent-contact-row:last-of-type { border-bottom:none; }
.s9-agent-contact-row:hover { color:var(--text-primary); }
.s9-agent-contact-row svg { color:var(--text-muted); flex-shrink:0; }

/* WhatsApp button */
.s9-agent-whatsapp-btn {
  display:flex; align-items:center; justify-content:center;
  gap:10px;
  width:100%; margin-top:16px;
  padding:14px 20px;
  background:#25D366;
  color:#fff;
  border-radius:var(--s9p-radius-pill);
  font-family:var(--s9p-font);
  font-size:14px; font-weight:500;
  text-decoration:none;
  transition:background .2s ease, transform .2s ease;
}
.s9-agent-whatsapp-btn:hover {
  background:#20ba5a;
  transform:translateY(-1px);
}
.s9-agent-whatsapp-btn svg { flex-shrink:0; }

/* Social links */
.s9-agent-social-links {
  display:flex; gap:10px;
  margin-top:18px; padding-top:16px;
  border-top:1px solid var(--border-color);
}
.s9-agent-social-link {
  width:36px; height:36px;
  border-radius:50%;
  background:var(--bg-surface);
  border:1px solid var(--border-color);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-muted);
  transition:all var(--s9p-transition-fast);
  text-decoration:none;
}
.s9-agent-social-link:hover {
  border-color:var(--s9p-cream-30);
  color:var(--text-primary);
  background:var(--bg-raised);
}

/* License */
.s9-agent-license {
  display:flex; align-items:center; gap:8px;
  margin-top:16px; padding-top:14px;
  border-top:1px solid var(--border-color);
  font-size:11px; color:var(--text-muted);
  letter-spacing:.5px;
}

/* ── Agency Card (sidebar) ── */
.s9-agent-agency-card {
  background:var(--card-bg);
  border:1px solid var(--border-color);
  border-radius:var(--s9p-radius-lg);
  padding:26px;
}
.s9-agent-agency-info {
  display:flex; align-items:center; gap:14px;
  margin-bottom:14px;
}
.s9-agent-agency-logo {
  width:48px; height:48px;
  border-radius:var(--s9p-radius);
  object-fit:contain;
  background:var(--bg-surface);
  padding:4px;
}
.s9-agent-agency-name {
  display:block;
  font-size:15px; font-weight:600;
  color:var(--text-primary);
  line-height:1.3;
}
.s9-agent-agency-city {
  display:block;
  font-size:12px; color:var(--text-muted);
  margin-top:2px;
}
.s9-agent-agency-link {
  display:inline-flex; align-items:center; gap:6px;
  font-size:12px; color:var(--text-muted);
  font-weight:500; letter-spacing:.5px;
  text-decoration:none;
  transition:color var(--s9p-transition-fast);
}
.s9-agent-agency-link:hover { color:var(--text-primary); }

/* ── Contact Form Section ── */
.s9-agent-contact-section {
  padding:clamp(52px,7vw,92px) var(--s9p-gutter);
  border-top:1px solid var(--border-color);
  background:var(--bg-surface);
}
.s9-agent-contact-section__inner {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,5vw,72px);
  align-items:start;
}
.s9-agent-contact-section__title {
  font-size:clamp(22px,2.5vw,36px); font-weight:600;
  color:var(--text-primary);
  line-height:1.2; letter-spacing:-.02em;
  margin-bottom:12px;
}
.s9-agent-contact-section__desc {
  font-size:14px; color:var(--text-secondary);
  line-height:1.8; font-weight:300;
}

/* Form fields */
.s9-agent-form { display:flex; flex-direction:column; gap:14px; }
.s9-agent-form__row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.s9-agent-form__input {
  width:100%; padding:12px 16px;
  background:transparent;
  border:1px solid var(--border-color);
  border-radius:var(--s9p-radius);
  color:var(--text-primary);
  font-family:var(--s9p-font);
  font-size:14px; font-weight:300;
  outline:none;
  transition:border-color var(--s9p-transition-fast);
}
.s9-agent-form__input::placeholder { color:var(--text-muted); }
.s9-agent-form__input:focus { border-color:var(--s9p-cream-40); }
.s9-agent-form__textarea { resize:vertical; min-height:100px; }
.s9-agent-form__gdpr {
  display:flex; align-items:flex-start; gap:10px;
  cursor:pointer;
  font-size:13px; color:var(--text-muted); line-height:1.4;
}
.s9-agent-form__gdpr-link {
  color:var(--text-secondary) !important;
  text-decoration:underline !important;
}
.s9-agent-form__checkbox {
  margin-top:2px; flex-shrink:0;
  width:16px; height:16px; cursor:pointer;
  accent-color:var(--s9p-cream-60);
}
.s9-agent-form__actions {
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
}
.s9-agent-form__status { font-size:13px; }
.s9-agent-form__status--success { color:var(--s9p-success); }
.s9-agent-form__status--error { color:var(--s9p-error); }

/* ── Agent Properties Grid ── */
.s9-agent-properties {
  padding:clamp(52px,7vw,92px) var(--s9p-gutter);
  border-top:1px solid var(--border-color);
}
.s9-agent-properties__header { margin-bottom:clamp(24px,3vw,44px); }
.s9-agent-properties__grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(12px,1.5vw,20px);
}
.s9-agent-properties__more {
  display:flex; justify-content:center;
  margin-top:clamp(24px,3vw,44px);
}

/* ═══ 36. AGENT LISTING PAGE ═══ */

.s9-agent-listing {
  font-family:var(--s9p-font);
  min-height:80vh;
}

/* Header */
.s9-agent-listing__header {
  background:var(--s9p-bg-dark);
  padding:clamp(100px,12vh,160px) var(--s9p-gutter) clamp(40px,5vw,72px);
}
.s9-agent-listing__header-inner {
  max-width:720px;
}
.s9-agent-listing__breadcrumb {
  display:flex; gap:8px; align-items:center;
  margin-bottom:20px;
}
.s9-agent-listing__breadcrumb a,
.s9-agent-listing__breadcrumb span {
  font-size:12px; color:var(--s9p-cream-60);
  text-decoration:none;
}
.s9-agent-listing__breadcrumb a:hover { color:var(--s9p-text-on-dark); }
.s9-agent-listing__breadcrumb .sep { color:var(--s9p-cream-40); }
.s9-agent-listing__title {
  font-family:var(--s9p-font);
  font-size:clamp(32px,4.5vw,56px); font-weight:600;
  color:var(--s9p-text-on-dark);
  line-height:1.1; letter-spacing:-.03em;
  margin-bottom:10px;
}
.s9-agent-listing__count {
  font-size:15px; color:var(--s9p-cream-60);
  font-weight:300;
}

/* Filter pills */
.s9-agent-listing__filters {
  background:var(--s9p-white, #fff);
  border-bottom:1px solid var(--s9p-beige-light, #e8e0d4);
  padding:14px var(--s9p-gutter);
}
.s9-agent-listing__filters-inner {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
}
.s9-agent-listing__filter-label {
  font-size:11px; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--s9p-text-subtle); font-weight:500;
  margin-right:4px;
}
.s9-agent-listing__filter-pill {
  padding:7px 16px;
  border:1px solid var(--s9p-beige-light, #e8e0d4);
  border-radius:var(--s9p-radius-pill);
  font-size:12px; font-weight:400;
  color:var(--s9p-text-muted);
  text-decoration:none;
  transition:all .2s ease;
  font-family:var(--s9p-font);
}
.s9-agent-listing__filter-pill:hover {
  background:var(--s9p-bg-dark);
  color:var(--s9p-text-on-dark);
  border-color:var(--s9p-bg-dark);
}
.s9-agent-listing__filter-pill--active {
  background:var(--s9p-bg-dark) !important;
  color:var(--s9p-text-on-dark) !important;
  border-color:var(--s9p-bg-dark) !important;
  font-weight:500;
}

/* Agent cards grid */
.s9-agent-listing__grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2vw,24px);
  padding:clamp(24px,3vw,40px) var(--s9p-gutter) clamp(40px,5vw,72px);
}

/* Agent card */
.s9-agent-card-link {
  text-decoration:none; color:inherit; display:block;
}
.s9-agent-listing-card {
  background:var(--s9p-white, #fff);
  border-radius:var(--s9p-radius-lg);
  overflow:hidden;
  border:1px solid var(--s9p-beige-light, #e8e0d4);
  transition:transform var(--s9p-transition), border-color var(--s9p-transition), box-shadow var(--s9p-transition);
}
.s9-agent-card-link:hover .s9-agent-listing-card {
  transform:translateY(-3px);
  border-color:var(--s9p-beige-mid, #d4c9b8);
  box-shadow:0 8px 28px rgba(0,0,0,.08);
}

/* Card photo */
.s9-agent-listing-card__photo-wrap {
  width:100%; height:280px;
  overflow:hidden; position:relative;
  background:var(--s9p-beige-light, #ece6dd);
}
.s9-agent-listing-card__photo {
  width:100%; height:100%;
  object-fit:cover; display:block;
  transition:transform .6s var(--s9p-ease);
}
.s9-agent-card-link:hover .s9-agent-listing-card__photo {
  transform:scale(1.04);
}
.s9-agent-listing-card__photo-fallback {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--s9p-font-display); font-size:36px; font-weight:600;
  color:var(--s9p-text-subtle);
  letter-spacing:2px;
}

/* Card body */
.s9-agent-listing-card__body {
  padding:20px 22px 18px;
}
.s9-agent-listing-card__name {
  font-family:var(--s9p-font);
  font-size:18px; font-weight:600;
  color:var(--s9p-text-dark);
  line-height:1.3; letter-spacing:-.01em;
  margin-bottom:4px;
}
.s9-agent-listing-card__role {
  font-size:13px; color:var(--s9p-text-subtle);
  font-weight:300; margin-bottom:12px;
}

/* Spec tags */
.s9-agent-listing-card__specs {
  display:flex; gap:6px; flex-wrap:wrap;
  margin-bottom:14px;
}
.s9-agent-listing-card__spec {
  padding:3px 10px;
  border:1px solid var(--s9p-beige-light, #e8e0d4);
  border-radius:var(--s9p-radius-pill);
  font-size:10px; font-weight:400;
  color:var(--s9p-text-muted);
  letter-spacing:.3px;
}

/* Card footer */
.s9-agent-listing-card__footer {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:14px;
  border-top:1px solid var(--s9p-beige-light, #e8e0d4);
}
.s9-agent-listing-card__props {
  display:flex; align-items:center; gap:5px;
  font-size:12px; color:var(--s9p-text-subtle);
  font-weight:400;
}
.s9-agent-listing-card__props svg { opacity:.6; }
.s9-agent-listing-card__arrow {
  color:var(--s9p-text-subtle);
  opacity:0;
  transform:translateX(-4px);
  transition:opacity .3s, transform .3s;
}
.s9-agent-card-link:hover .s9-agent-listing-card__arrow {
  opacity:1;
  transform:translateX(0);
}

/* Empty state */
.s9-agent-listing__empty {
  padding:clamp(40px,5vw,80px) var(--s9p-gutter);
  text-align:center;
}
.s9-agent-listing__empty p {
  font-size:15px; color:var(--s9p-text-subtle);
}

/* ═══ 37. AGENT PAGE RESPONSIVE ═══ */

@media(max-width:1024px) {
  .s9-agent-body { grid-template-columns:1fr; }
  .s9-agent-contact-section__inner { grid-template-columns:1fr; }
  .s9-agent-properties__grid { grid-template-columns:repeat(2,1fr); }
  .s9-agent-listing__grid { grid-template-columns:repeat(2,1fr); }
  .s9-agent-stats-bar { grid-template-columns:repeat(2,1fr); }
}

@media(max-width:640px) {
  .s9-agent-hero { min-height:420px; padding-top:clamp(80px,10vh,120px); }
  .s9-agent-hero__photo-wrap { width:100px; height:100px; }
  .s9-agent-form__row { grid-template-columns:1fr; }
  .s9-agent-properties__grid { grid-template-columns:1fr; }
  .s9-agent-listing__grid { grid-template-columns:1fr; }
  .s9-agent-stats-bar { grid-template-columns:1fr; }
  .s9-agent-listing-card__photo-wrap { height:220px; }
}

/* ═══ 33b. CUSTOM DROPDOWNS (SOMA9 DS — public) ═══ */

/* ── Container ── */
.s9-filter-dropdown { position:relative; flex-shrink:0; }

/* ── Trigger button ── */
.s9-filter-dropdown__trigger {
  display:flex; align-items:center; gap:6px;
  padding:7px 30px 7px 12px; border:1px solid rgba(225,216,203,.15);
  border-radius:var(--s9p-radius, 6px);
  background:transparent; color:rgba(225,216,203,.7);
  font-size:12px; font-weight:400; cursor:pointer;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  outline:none; transition:all .2s ease; white-space:nowrap;
  position:relative; line-height:1.5;
}
.s9-filter-dropdown__trigger::after {
  content:''; position:absolute; right:10px; top:50%;
  transform:translateY(-50%);
  width:0; height:0;
  border-left:4px solid transparent; border-right:4px solid transparent;
  border-top:4px solid rgba(225,216,203,.5);
  transition:transform .2s var(--s9p-ease, ease);
}
.s9-filter-dropdown.is-open .s9-filter-dropdown__trigger::after {
  transform:translateY(-50%) rotate(180deg);
}
.s9-filter-dropdown__trigger:hover,
.s9-filter-dropdown__trigger:focus-visible {
  border-color:rgba(225,216,203,.4); color:#e1d8cb;
}
.s9-filter-dropdown.is-open .s9-filter-dropdown__trigger {
  border-color:rgba(225,216,203,.4); color:#e1d8cb;
}
.s9-filter-dropdown__trigger.is-placeholder { color:rgba(225,216,203,.5); }

/* ── Arrow icon (SVG variant) ── */
.s9-filter-dropdown__arrow {
  width:10px; height:10px; flex-shrink:0;
  color:rgba(225,216,203,.5);
  transition:transform .2s var(--s9p-ease, ease);
  pointer-events:none;
}
.s9-filter-dropdown.is-open .s9-filter-dropdown__arrow {
  transform:rotate(180deg);
}

/* ── Dropdown menu ── */
.s9-filter-dropdown__menu {
  position:absolute; top:calc(100% + 4px); left:0;
  min-width:100%; width:max-content;
  background:var(--s9p-bg-dark, #1a1714);
  border:1px solid rgba(225,216,203,.15);
  border-radius:var(--s9p-radius, 6px);
  box-shadow:0 8px 24px rgba(0,0,0,.35);
  z-index:600; padding:4px;
  opacity:0; transform:translateY(-4px);
  pointer-events:none;
  transition:opacity .15s var(--s9p-ease, ease), transform .15s var(--s9p-ease, ease);
  max-height:260px; overflow-y:auto;
}
.s9-filter-dropdown.is-open .s9-filter-dropdown__menu {
  opacity:1; transform:translateY(0); pointer-events:auto;
}
.s9-filter-dropdown__menu::-webkit-scrollbar { width:5px; }
.s9-filter-dropdown__menu::-webkit-scrollbar-track { background:transparent; }
.s9-filter-dropdown__menu::-webkit-scrollbar-thumb { background:rgba(225,216,203,.2); border-radius:10px; }

/* ── Option buttons ── */
.s9-filter-dropdown__option {
  display:flex; align-items:center; justify-content:space-between;
  width:100%; padding:7px 10px; border:none; background:transparent;
  color:rgba(225,216,203,.7); font-size:12px;
  font-family:var(--s9p-font, 'Host Grotesk', sans-serif);
  border-radius:4px; cursor:pointer;
  transition:background .1s, color .1s;
  white-space:nowrap; text-align:left;
}
.s9-filter-dropdown__option:hover { background:rgba(225,216,203,.08); color:#e1d8cb; }
.s9-filter-dropdown__option.is-selected {
  background:rgba(225,216,203,.12); color:#e1d8cb; font-weight:500;
}
.s9-filter-dropdown__option.is-selected::after {
  content:'\2713'; font-size:10px; color:rgba(225,216,203,.6);
  flex-shrink:0; margin-left:8px;
}

/* ── Shortcode filter bar variant (light background) ── */
.s9-filters .s9-filter-dropdown__trigger {
  border-color:var(--s9p-beige-light, #e8e0d4);
  color:var(--s9p-text-muted, #6b635b);
  background:transparent;
}
.s9-filters .s9-filter-dropdown__trigger::after {
  border-top-color:var(--s9p-text-subtle, #9a9088);
}
.s9-filters .s9-filter-dropdown__trigger:hover,
.s9-filters .s9-filter-dropdown__trigger:focus-visible {
  background:var(--s9p-bg-dark, #1a1714); color:var(--s9p-text-on-dark, #e1d8cb);
  border-color:var(--s9p-bg-dark, #1a1714);
}
.s9-filters .s9-filter-dropdown__trigger:hover::after,
.s9-filters .s9-filter-dropdown__trigger:focus-visible::after {
  border-top-color:var(--s9p-text-on-dark, #e1d8cb);
}
.s9-filters .s9-filter-dropdown.is-open .s9-filter-dropdown__trigger {
  background:var(--s9p-bg-dark, #1a1714); color:var(--s9p-text-on-dark, #e1d8cb);
  border-color:var(--s9p-bg-dark, #1a1714);
}
.s9-filters .s9-filter-dropdown.is-open .s9-filter-dropdown__trigger::after {
  border-top-color:var(--s9p-text-on-dark, #e1d8cb);
}
.s9-filters .s9-filter-dropdown__trigger.is-placeholder {
  color:var(--s9p-text-subtle, #9a9088);
}
.s9-filters .s9-filter-dropdown__menu {
  background:var(--s9p-white, #fff);
  border-color:var(--s9p-beige-light, #e8e0d4);
  box-shadow:0 8px 24px rgba(0,0,0,.12);
}
.s9-filters .s9-filter-dropdown__option {
  color:var(--s9p-text-muted, #6b635b);
}
.s9-filters .s9-filter-dropdown__option:hover {
  background:var(--s9p-beige-light, #ece6dd); color:var(--s9p-text-dark, #1a1714);
}
.s9-filters .s9-filter-dropdown__option.is-selected {
  background:var(--s9p-bg-dark, #1a1714); color:var(--s9p-text-on-dark, #e1d8cb);
}
.s9-filters .s9-filter-dropdown__option.is-selected::after {
  color:var(--s9p-text-on-dark, #e1d8cb);
}

/* Shortcode: connected borders (first/last rounding) */
.s9-filters .s9-filter-dropdown:first-child .s9-filter-dropdown__trigger { border-radius:4px 0 0 4px; }
.s9-filters .s9-filter-dropdown:last-of-type .s9-filter-dropdown__trigger { border-radius:0 4px 4px 0; }
.s9-filters .s9-filter-dropdown + .s9-filter-dropdown .s9-filter-dropdown__trigger { border-left:none; }

/* ── Mobile drawer: full-width dropdowns ── */
.s9-filterbar__drawer-body .s9-filter-dropdown { width:100%; }
.s9-filterbar__drawer-body .s9-filter-dropdown__trigger {
  width:100%; border-radius:var(--s9p-radius, 6px) !important;
  border:1px solid rgba(225,216,203,.15) !important;
}
.s9-filterbar__drawer-body .s9-filter-dropdown__menu { width:100%; }

/* ── Responsive: mobile stacked ── */
@media(max-width:768px) {
  .s9-filters .s9-filter-dropdown { flex:1 1 calc(50% - 4px); }
  .s9-filters .s9-filter-dropdown__trigger {
    border-radius:4px !important; border:1px solid var(--s9p-beige-light, #e8e0d4) !important;
    width:100%;
  }
  .s9-filters .s9-filter-dropdown + .s9-filter-dropdown .s9-filter-dropdown__trigger {
    border-left:1px solid var(--s9p-beige-light, #e8e0d4) !important;
  }
}

/* ═══ 34. @MEDIA PRINT ═══ */
@media print {
  /* Hide non-essential elements */
  .navbar,
  .hero-nav,
  .s9-sticky-bar,
  .s9-share-bar,
  .s9-cta-section,
  .s9-compare-tray,
  .s9-vert-section,
  .s9-card__compare-btn,
  .s9-card__fav-btn,
  .s9-card__share-btn,
  .s9-card-share-popover,
  .s9-detail-fav-btn,
  .s9-save-search-btn,
  .s9-save-search-overlay,
  .s9-favorites-filter,
  .s9-filterbar,
  .s9-filterbar__mobile-toggle,
  .s9-filterbar__drawer,
  .s9-filterbar__drawer-overlay,
  .s9-listing__loadmore,
  .s9-hero-actions,
  .s9-hero-badge,
  .s9-mortgage-section,
  .s9-share-section,
  .s9-tour-section,
  footer,
  .footer,
  #s9StickyBar,
  .s9-btn-primary,
  .s9-btn-outline,
  .s9-btn-outline-dark,
  .s9-contact-form,
  .nav-hamburger,
  .nav-search,
  .nav-lang,
  .nav-theme-toggle {
    display:none !important;
  }

  /* Reset backgrounds and colors for print */
  body,
  body.s9-detail-page {
    background:#fff !important;
    color:#000 !important;
    font-size:12pt;
    -webkit-print-color-adjust:exact;
    print-color-adjust:exact;
  }

  /* Hero section */
  .s9-hero {
    height:auto !important;
    min-height:auto !important;
    padding:20pt !important;
    break-after:avoid;
    page-break-after:avoid;
  }
  .s9-hero-bg {
    position:relative !important;
    inset:auto !important;
    height:300pt !important;
    opacity:1 !important;
    transform:none !important;
  }
  .s9-hero-overlay { display:none !important; }
  .s9-hero-content {
    position:relative !important;
    max-width:100% !important;
  }
  .s9-hero h1 {
    font-size:24pt !important;
    color:#000 !important;
    opacity:1 !important;
    transform:none !important;
  }
  .s9-hero-sub {
    color:#333 !important;
    opacity:1 !important;
    transform:none !important;
  }
  .s9-hero-price-wrap {
    position:relative !important;
    right:auto !important;
    bottom:auto !important;
    text-align:left !important;
    margin-top:10pt;
    opacity:1 !important;
    transform:none !important;
  }
  .s9-hero-price {
    color:#000 !important;
    font-size:18pt !important;
  }
  .s9-hero-price-label { color:#666 !important; }

  /* Stats bar */
  .s9-stats-bar {
    background:#f5f5f5 !important;
    border:1px solid #ddd !important;
  }
  .s9-stat-item {
    opacity:1 !important;
    transform:none !important;
    border-color:#ddd !important;
  }
  .s9-stat-value { color:#000 !important; }
  .s9-stat-label { color:#666 !important; }

  /* Gallery — show first image only */
  .s9-gallery-section {
    padding:20pt 0 !important;
    overflow:visible !important;
  }
  .s9-gallery-track {
    overflow:visible !important;
    flex-wrap:wrap;
    gap:8pt;
  }
  .s9-gallery-item {
    width:45% !important;
    height:auto !important;
    page-break-inside:avoid;
  }
  .s9-gallery-item:nth-child(n+5) { display:none; }
  .s9-gallery-arrow { display:none !important; }

  /* Description */
  .s9-desc-section {
    grid-template-columns:1fr !important;
    border-color:#ddd !important;
  }
  .s9-desc-text { color:#333 !important; }
  .s9-reveal {
    opacity:1 !important;
    transform:none !important;
  }

  /* Features */
  .s9-features-section {
    background:#fafafa !important;
    page-break-inside:avoid;
  }
  .s9-features-grid { grid-template-columns:1fr 1fr !important; }
  .s9-feature-item {
    opacity:1 !important;
    transform:none !important;
    border:1px solid #eee;
  }
  .s9-feature-name { color:#000 !important; }
  .s9-feature-detail { color:#555 !important; }

  /* Location */
  .s9-location-section {
    grid-template-columns:1fr !important;
    border-color:#ddd !important;
  }
  .s9-location-title { color:#000 !important; }
  .s9-dist-place { color:#333 !important; }
  .s9-dist-time { color:#000 !important; }
  .s9-location-map { display:none; }

  /* Floor plan */
  .s9-floorplan-section {
    grid-template-columns:1fr !important;
    border-color:#ddd !important;
    page-break-inside:avoid;
  }

  /* Agent info */
  .s9-agent-card {
    border:1px solid #ddd !important;
    background:#f9f9f9 !important;
    page-break-inside:avoid;
  }
  .s9-agent-name { color:#000 !important; }
  .s9-agent-role { color:#666 !important; }

  /* QR code for print — show if present */
  .s9-share-qr { display:flex !important; }

  /* General layout */
  a { color:#000 !important; }
  * {
    box-shadow:none !important;
    text-shadow:none !important;
  }

  @page {
    margin:1.5cm;
    size:A4;
  }
}
