/* ============================================================
   Find A HMO — style.css
   Palette: BRConsultantsUK (Dark charcoal + Gold + Teal)
   ============================================================ */

:root {
  --bg-primary: #1C1C1C;
  --bg-secondary: #252525;
  --bg-tertiary: #2E2E2E;
  --bg-card: #2A2A2A;
  --bg-hover: #333333;
  --gold: #F0DFA0;
  --gold-dim: #D4C078;
  --gold-glow: rgba(240,223,160,0.12);
  --gold-bright: #F5EAB8;
  --teal: #5BA4B5;
  --teal-dim: #4A8A99;
  --teal-glow: rgba(91,164,181,0.15);
  --white: #FFFFFF;
  --text-primary: #E8E8E8;
  --text-secondary: #B0B0B0;
  --text-muted: #777777;
  --border: #3A3A3A;
  --border-light: #444444;
  --success: #6BCB77;
  --warning: #E8A838;
  --danger: #E57373;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.5);
  --radius: 10px;
  --radius-sm: 6px;
  --radius-lg: 16px;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Source Sans 3', 'Segoe UI', sans-serif;
}

/* ===== RESET & BASE ===== */
*{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:hidden}
body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh;overflow-x:hidden;max-width:100vw}

/* ===== HEADER ===== */
.header{height:68px;background:rgba(28,28,28,0.95);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:space-between;padding:0 28px;border-bottom:2px solid var(--gold-dim);z-index:2000;position:fixed;top:0;left:0;right:0;overflow:hidden}
.logo{display:flex;align-items:center;gap:10px;cursor:pointer;text-decoration:none}
.logo-icon{font-family:var(--font-display);font-size:30px;font-weight:700;color:var(--gold);letter-spacing:0.5px}
.logo-icon span{color:var(--gold-bright);font-weight:400}
.header-nav{display:flex;gap:24px;align-items:center}
.nav-stat{font-size:14px;color:var(--text-secondary)}
.nav-stat b{color:var(--gold);font-weight:700;font-size:16px}
.header-actions{display:flex;gap:10px;align-items:center}

/* ===== BUTTONS ===== */
.btn{padding:9px 20px;border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;font-family:var(--font-body);font-weight:600;font-size:13px;transition:all 0.2s;background:transparent;color:var(--text-primary)}
.btn:hover{border-color:var(--gold-dim);color:var(--gold)}
.btn-gold{background:var(--gold);color:var(--bg-primary);border-color:var(--gold);font-weight:700}
.btn-gold:hover{background:var(--gold-bright);transform:translateY(-1px);box-shadow:0 4px 12px rgba(240,223,160,0.25)}
.btn-teal{background:var(--teal);color:var(--white);border-color:var(--teal)}
.btn-teal:hover{background:var(--teal-dim)}
.btn-sm{padding:6px 12px;font-size:11px}
.btn-outline-gold{border:1px solid var(--gold-dim);color:var(--gold);background:transparent}
.btn-outline-gold:hover{background:var(--gold-glow)}
.btn-danger{background:var(--danger);color:var(--white);border-color:var(--danger)}

/* ===== USER MENU ===== */
.user-menu{position:relative;display:inline-block}
.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--gold);color:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;cursor:pointer;border:2px solid transparent;transition:all 0.2s}
.user-avatar:hover{border-color:var(--gold-bright)}
.user-dropdown{position:absolute;top:44px;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);min-width:200px;box-shadow:var(--shadow-lg);z-index:1100;display:none}
.user-dropdown.open{display:block}
.ud-header{padding:14px;border-bottom:1px solid var(--border)}
.ud-name{font-weight:700;font-size:13px;color:var(--text-primary)}
.ud-email{font-size:11px;color:var(--text-muted)}
.ud-role{font-size:10px;color:var(--teal);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.ud-item{padding:10px 14px;font-size:13px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:8px;transition:background 0.15s}
.ud-item:hover{background:var(--bg-hover);color:var(--text-primary)}
.ud-item.gold{color:var(--gold)}

/* ===== LAYOUT ===== */
.main{display:flex;height:calc(100vh - 68px);margin-top:68px}
.sidebar{width:400px;min-width:400px;background:var(--bg-secondary);display:flex;flex-direction:column;border-right:1px solid var(--border);z-index:100;transition:margin-left 0.3s ease, opacity 0.3s ease;padding-bottom:36px}
.sidebar.hidden{margin-left:-400px;min-width:0;width:0;opacity:0;overflow:hidden;border:none}

/* ===== SEARCH ===== */
.search-section{padding:14px;border-bottom:1px solid var(--border)}
.search-row{display:flex;gap:6px;margin-bottom:10px}
.search-input{flex:1;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:var(--font-body);outline:none;transition:border-color 0.2s}
.search-input:focus{border-color:var(--gold-dim)}
.search-input::placeholder{color:var(--text-muted)}
.icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all 0.2s}
.icon-btn:hover{border-color:var(--gold-dim);color:var(--gold);background:var(--gold-glow)}
.icon-btn.active{border-color:var(--teal);color:var(--teal);background:var(--teal-glow)}
.radius-row{display:flex;gap:6px;align-items:center}
.radius-select{padding:6px 10px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px;font-family:var(--font-body);outline:none;cursor:pointer}
.radius-label{font-size:11px;color:var(--text-muted);white-space:nowrap}

/* ===== FILTERS ===== */
.filter-section{border-bottom:1px solid var(--border)}
.filter-header{padding:10px 14px;display:flex;justify-content:space-between;align-items:center;cursor:pointer}
.filter-header:hover{background:var(--bg-hover)}
.filter-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}
.filter-toggle{color:var(--text-muted);font-size:14px;transition:transform 0.2s}
.filter-toggle.open{transform:rotate(180deg)}
.filter-body{padding:0 14px 12px;display:none;max-height:180px;overflow-y:auto}
.filter-body.open{display:block}
.filter-option{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text-secondary);transition:all 0.15s}
.filter-option:hover{background:var(--bg-hover);color:var(--text-primary)}
.filter-option.active{color:var(--gold);background:var(--gold-glow)}
.filter-check{width:16px;height:16px;border:1.5px solid var(--border-light);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;transition:all 0.15s}
.filter-option.active .filter-check{border-color:var(--gold);background:var(--gold);color:var(--bg-primary)}
.filter-count{margin-left:auto;font-size:11px;color:var(--text-muted)}
.filter-body::-webkit-scrollbar{width:4px}
.filter-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* ===== FEATURED ===== */
.featured-section{border-bottom:1px solid var(--border);padding:12px 14px}
.featured-label{font-size:11px;font-weight:600;color:var(--gold-dim);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px}
.featured-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px}
.featured-scroll::-webkit-scrollbar{height:3px}
.featured-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.feat-card{min-width:200px;max-width:200px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all 0.2s;flex-shrink:0}
.feat-card:hover{border-color:var(--gold-dim);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.feat-img{height:90px;background:var(--bg-tertiary);position:relative;overflow:hidden}
.feat-img img{width:100%;height:100%;object-fit:cover}
.feat-badge-top{position:absolute;top:6px;left:6px;background:var(--gold);color:var(--bg-primary);font-size:9px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:0.5px}
.feat-body{padding:10px}
.feat-addr{font-size:12px;font-weight:600;color:var(--text-primary);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feat-meta{font-size:11px;color:var(--text-muted);margin-bottom:4px}
.feat-tags{display:flex;gap:4px;flex-wrap:wrap}
.feat-tag{font-size:10px;color:var(--gold-dim);background:var(--gold-glow);padding:2px 6px;border-radius:8px}

/* ===== RESULTS ===== */
/* Sidebar scrollable area */
.sidebar-scroll{flex:1;overflow-y:auto;min-height:0}
.sidebar-scroll::-webkit-scrollbar{width:5px}
.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* Filter bar */
.filter-bar{padding:10px 14px;background:var(--bg-primary);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.filter-bar-label{font-size:13px;font-weight:700;color:var(--text-primary)}
.results-count{font-size:11px;color:var(--text-secondary);margin-left:auto}
.results-count b{color:var(--gold);font-weight:700}
.btn-reset-filters{font-size:11px;font-weight:700;color:var(--gold);background:transparent;border:1.5px solid var(--gold-dim);border-radius:var(--radius-sm);padding:6px 14px;cursor:pointer;font-family:var(--font-body);transition:all 0.2s;white-space:nowrap;letter-spacing:0.5px;text-transform:uppercase}
.btn-reset-filters:hover{background:var(--gold-glow);border-color:var(--gold);color:var(--gold-bright)}

/* Live filter indicator */
.filter-live{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--teal);font-weight:600;letter-spacing:0.3px;text-transform:uppercase}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:livePulse 2s infinite}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:0.3}}

/* Filter bar flash on update */
.filter-bar.flash{animation:filterFlash 0.6s ease}
@keyframes filterFlash{0%{background:var(--bg-primary)}30%{background:var(--gold-glow)}100%{background:var(--bg-primary)}}
.prop-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:6px;cursor:pointer;transition:all 0.2s}
.prop-card:hover{border-color:var(--gold-dim);background:var(--bg-hover);transform:translateX(3px)}
.prop-card.active{border-color:var(--gold);background:var(--gold-glow)}
.card-top{display:flex;justify-content:space-between;gap:8px;margin-bottom:6px}
.card-addr{font-weight:600;font-size:13px;color:var(--text-primary);line-height:1.3;flex:1}
.card-pc{font-size:11px;color:var(--gold);font-weight:700;background:var(--gold-glow);padding:2px 8px;border-radius:4px;white-space:nowrap;height:fit-content}
.card-council{font-size:11px;color:var(--text-muted);margin-bottom:6px}
.card-badges{display:flex;gap:6px;flex-wrap:wrap}
.badge{font-size:11px;color:var(--text-secondary);background:var(--bg-tertiary);padding:3px 8px;border-radius:10px;display:flex;align-items:center;gap:3px}
.badge-gold{color:var(--gold-dim);background:var(--gold-glow)}
.badge-teal{color:var(--teal);background:var(--teal-glow)}
.badge-green{color:var(--success);background:rgba(107,203,119,0.12)}
.badge-orange{color:var(--warning);background:rgba(232,168,56,0.12)}

/* ===== AD PANEL ===== */
.ad-panel{padding:10px 14px;border-top:1px solid var(--border);background:var(--bg-primary);flex-shrink:0}
.ad-card{background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-card));border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;position:relative;overflow:hidden}
.ad-card::before{content:'';position:absolute;top:0;right:0;width:60px;height:60px;background:var(--gold-glow);border-radius:0 0 0 60px}
.ad-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px}
.ad-tag{display:inline-block;font-size:9px;color:var(--teal);border:1px solid var(--teal);border-radius:3px;padding:1px 6px;margin-bottom:6px;letter-spacing:0.5px;text-transform:uppercase;font-weight:600}
.ad-title{font-family:var(--font-display);font-size:15px;color:var(--gold);margin-bottom:4px;font-weight:600}
.ad-text{font-size:11px;color:var(--text-secondary);margin-bottom:8px;line-height:1.4}
.ad-cta{font-size:11px;color:var(--teal);font-weight:600;cursor:pointer}
.ad-cta:hover{text-decoration:underline}
.ad-dots{display:flex;gap:4px;justify-content:center;margin-top:8px}
.ad-dot{width:5px;height:5px;border-radius:50%;background:var(--border);cursor:pointer}
.ad-dot.active{background:var(--gold-dim)}

/* ===== MAP ===== */
.map-wrap{flex:1;position:relative}
#map{width:100%;height:100%}

/* Leaflet popup overrides */
.leaflet-popup-content-wrapper{border-radius:var(--radius)!important;box-shadow:var(--shadow-lg)!important;background:var(--bg-card)!important}
.leaflet-popup-content{margin:0!important;font-family:var(--font-body)!important;color:var(--text-primary)!important}
.leaflet-popup-tip{background:var(--bg-card)!important}
.popup-inner{padding:14px;min-width:240px}
.popup-addr{font-weight:600;font-size:13px;margin-bottom:3px;color:var(--text-primary)}
.popup-pc{color:var(--gold);font-size:12px;font-weight:700;margin-bottom:4px}
.popup-vac{font-size:11px;padding:3px 8px;border-radius:10px;display:inline-block;margin-bottom:8px}
.popup-vac.vac-now{color:var(--success);background:rgba(107,203,119,0.12)}
.popup-vac.vac-soon{color:var(--warning);background:rgba(232,168,56,0.12)}
.popup-vac.vac-no{color:var(--text-muted);background:var(--bg-tertiary)}
.popup-stats{display:flex;gap:12px;margin-bottom:10px}
.popup-stat{font-size:11px;color:var(--text-secondary)}
.popup-stat b{display:block;font-size:15px;color:var(--text-primary)}
.popup-btns{display:flex;gap:6px}
.popup-btn{flex:1;padding:8px;border:none;border-radius:var(--radius-sm);font-weight:700;cursor:pointer;font-family:var(--font-body);font-size:11px;text-align:center}
.popup-btn-gold{background:var(--gold);color:var(--bg-primary)}
.popup-btn-gold:hover{background:var(--gold-bright)}
.popup-btn-teal{background:var(--teal);color:var(--white)}
.popup-btn-teal:hover{background:var(--teal-dim)}

/* Map markers & clusters */
.custom-pin{width:24px;height:24px;border-radius:50% 50% 50% 0;background:var(--gold-dim);transform:rotate(-45deg);border:2.5px solid var(--white);box-shadow:0 2px 6px rgba(0,0,0,0.4)}

/* Colour-coded pins by vacancy status */
.pin-blue{background:#5B93D4}
.pin-green{background:#4CAF50}
.pin-orange{background:#FF9800}
.pin-red{background:#E53935}

/* Pin Legend - top of map */
.map-legend-top{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:800;background:rgba(255,255,255,0.92);backdrop-filter:blur(8px);border:1px solid rgba(0,0,0,0.12);border-radius:var(--radius);padding:8px 18px;display:flex;align-items:center;gap:16px;font-size:12px;color:#333;box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.legend-item{display:flex;align-items:center;gap:5px;white-space:nowrap;font-weight:500}
.legend-dot{width:11px;height:11px;border-radius:50%;border:2px solid rgba(255,255,255,0.8);flex-shrink:0;box-shadow:0 1px 3px rgba(0,0,0,0.2)}

/* Map controls - labelled buttons */
.map-controls{position:absolute;top:12px;right:12px;z-index:500;display:flex;flex-direction:column;gap:6px}
.map-ctrl-btn{background:rgba(28,28,28,0.9);backdrop-filter:blur(6px);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:6px;padding:7px 12px;font-family:var(--font-body);font-size:11px;white-space:nowrap}
.map-ctrl-btn:hover{border-color:var(--gold-dim);color:var(--gold)}
.map-ctrl-btn.active{border-color:var(--gold-dim);color:var(--gold);background:var(--gold-glow)}
.ctrl-icon{font-size:14px;flex-shrink:0}
.ctrl-label{color:inherit}

/* Leaflet zoom controls - raise above ticker */
.leaflet-control-zoom{margin-bottom:48px!important}

/* Autocomplete */
.search-autocomplete-wrap{position:relative;width:100%}
.autocomplete-dropdown{display:none;position:absolute;top:100%;left:0;right:0;z-index:1000;background:rgba(37,37,37,0.98);backdrop-filter:blur(10px);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);max-height:220px;overflow-y:auto;box-shadow:var(--shadow-lg)}
.autocomplete-dropdown.open{display:block}
.ac-item{padding:10px 14px;font-size:13px;color:var(--text-secondary);cursor:pointer;border-bottom:1px solid rgba(255,255,255,0.04);transition:background 0.15s;display:flex;align-items:center;gap:8px}
.ac-item:last-child{border-bottom:none}
.ac-item:hover,.ac-item.active{background:var(--gold-glow);color:var(--text-primary)}
.ac-item-icon{color:var(--gold);font-size:12px;flex-shrink:0}
.ac-item-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ac-item-type{font-size:10px;color:var(--text-muted);flex-shrink:0}

/* Auth modal extras */
.auth-extra{margin-top:18px;padding-top:16px;border-top:1px solid var(--border);text-align:center}
.why-register-link{color:var(--gold);font-size:14px;cursor:pointer;text-decoration:underline;font-weight:600}
.why-register-link:hover{color:var(--gold-bright)}
.auth-divider{height:12px}
.btn-later{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:10px 20px;border-radius:var(--radius-sm);font-size:12px;cursor:pointer;font-family:var(--font-body);transition:all 0.2s;width:100%}
.btn-later:hover{border-color:var(--text-secondary);color:var(--text-secondary)}

/* Why Register popup content */
.why-benefits{list-style:none;padding:0;margin:0 0 20px}
.why-benefit{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.why-benefit:last-child{border-bottom:none}
.why-benefit-icon{font-size:28px;flex-shrink:0;width:36px;text-align:center}
.why-benefit-text{flex:1}
.why-benefit-title{font-weight:700;font-size:16px;color:var(--text-primary);margin-bottom:4px}
.why-benefit-desc{font-size:14px;color:var(--text-secondary);line-height:1.5}
.why-cta{text-align:center;padding-top:18px;border-top:1px solid var(--border)}
.why-cta p{font-size:14px;color:var(--text-secondary);margin-bottom:12px}

/* Browse reminder toast */
.browse-reminder{position:fixed;bottom:50px;left:50%;transform:translateX(-50%);background:rgba(37,37,37,0.95);backdrop-filter:blur(10px);border:1px solid var(--gold-dim);border-radius:var(--radius-lg);padding:14px 20px;z-index:2500;max-width:400px;width:90%;text-align:center;box-shadow:var(--shadow-lg);animation:slideUp 0.4s ease}
.browse-reminder p{font-size:12px;color:var(--text-secondary);margin-bottom:10px;line-height:1.5}
.browse-reminder b{color:var(--gold)}
.browse-reminder-btns{display:flex;gap:8px;justify-content:center}
@keyframes slideUp{from{transform:translateX(-50%) translateY(30px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}
.user-loc-pulse{width:20px;height:20px;border-radius:50%;background:rgba(91,164,181,0.3);border:3px solid var(--teal);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:0.5}}
.radius-ring-label{background:none!important;border:none!important;box-shadow:none!important;color:var(--teal);font-family:var(--font-body);font-size:11px;font-weight:600;white-space:nowrap;opacity:0.8}
.leaflet-interactive.radius-circle{fill:var(--teal)!important;fill-opacity:0.04!important;stroke:var(--teal)!important;stroke-opacity:0.3!important;stroke-dasharray:6 4!important}

.marker-cluster-small{background-color:rgba(240,223,160,0.25)!important}
.marker-cluster-small div{background-color:var(--gold-dim)!important;color:var(--bg-primary)!important;font-family:var(--font-body)!important;font-weight:700!important;font-size:12px!important}
.marker-cluster-medium{background-color:rgba(240,223,160,0.35)!important}
.marker-cluster-medium div{background-color:var(--gold)!important;color:var(--bg-primary)!important;font-family:var(--font-body)!important;font-weight:700!important}
.marker-cluster-large{background-color:rgba(91,164,181,0.3)!important}
.marker-cluster-large div{background-color:var(--teal)!important;color:var(--white)!important;font-family:var(--font-body)!important;font-weight:700!important}

/* ===== DETAIL PANEL ===== */
.detail-panel{position:absolute;top:0;right:0;width:420px;height:100%;background:var(--bg-secondary);box-shadow:-4px 0 24px rgba(0,0,0,0.5);z-index:600;transform:translateX(100%);transition:transform 0.3s ease;overflow-y:auto}
.detail-panel.open{transform:translateX(0)}
.detail-panel::-webkit-scrollbar{width:5px}
.detail-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.detail-close{position:absolute;top:12px;right:12px;width:30px;height:30px;border-radius:50%;background:rgba(0,0,0,0.5);border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);font-size:16px;display:flex;align-items:center;justify-content:center;z-index:10}
.detail-close:hover{color:var(--gold);border-color:var(--gold-dim)}
.detail-photos{display:grid;grid-template-columns:1fr 1fr;gap:2px;height:200px;overflow:hidden}
.detail-photos .photo-main{grid-row:1/3}
.detail-photos .photo-item{position:relative;overflow:hidden;background:var(--bg-tertiary)}
.detail-photos .photo-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s}
.detail-photos .photo-item:hover img{transform:scale(1.05)}
.photo-label{position:absolute;bottom:4px;left:6px;font-size:9px;background:rgba(0,0,0,0.65);color:var(--white);padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:0.5px}
.detail-hero-info{padding:16px 20px;border-bottom:2px solid var(--gold-dim);background:var(--bg-primary)}
.detail-hero-info h2{font-family:var(--font-display);color:var(--gold);font-size:17px;font-weight:600;line-height:1.3}
.detail-hero-info .dpc{color:var(--teal);font-size:13px;font-weight:700;margin-top:3px}
.detail-hero-info .dcouncil{font-size:12px;color:var(--text-muted);margin-top:2px}
.detail-body{padding:20px}
.detail-sect{margin-bottom:20px}
.detail-sect h3{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:10px;font-weight:600}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.detail-item{background:var(--bg-tertiary);padding:10px;border-radius:var(--radius-sm);border:1px solid var(--border)}
.detail-item label{font-size:10px;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-muted);display:block;margin-bottom:3px}
.detail-item span{font-weight:600;font-size:14px;color:var(--text-primary)}
.detail-item.full{grid-column:1/-1}
.licence-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:16px;font-size:12px;font-weight:600}
.lic-active{background:rgba(107,203,119,0.12);color:var(--success)}
.lic-expired{background:rgba(229,115,115,0.12);color:var(--danger)}
.lic-unknown{background:var(--bg-tertiary);color:var(--text-muted)}
.amenity-list{display:flex;flex-wrap:wrap;gap:6px}
.amenity-pill{font-size:11px;padding:4px 10px;border-radius:12px;border:1px solid var(--border);color:var(--text-secondary);background:var(--bg-tertiary)}
.amenity-pill.has{border-color:var(--gold-dim);color:var(--gold);background:var(--gold-glow)}
.detail-cta{padding:0 20px 20px;display:flex;flex-direction:column;gap:8px}

/* Interest form */
.interest-box{background:var(--bg-tertiary);border:1px solid var(--gold-dim);border-radius:var(--radius);padding:16px;margin:0 20px 20px}
.interest-box h4{font-family:var(--font-display);color:var(--gold);font-size:15px;margin-bottom:4px}
.interest-box p{font-size:11px;color:var(--text-muted);margin-bottom:12px;line-height:1.4}
.ib-field{margin-bottom:10px}
.ib-field label{font-size:11px;color:var(--text-secondary);display:block;margin-bottom:4px;font-weight:600}
.ib-field input,.ib-field textarea,.ib-field select{width:100%;padding:8px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px;font-family:var(--font-body);outline:none}
.ib-field input:focus,.ib-field textarea:focus{border-color:var(--gold-dim)}
.ib-consent{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px;cursor:pointer}
.ib-consent input[type=checkbox]{margin-top:2px;accent-color:var(--gold)}
.ib-consent span{font-size:11px;color:var(--text-secondary);line-height:1.4}
.ib-submit{width:100%;padding:10px;background:var(--gold);color:var(--bg-primary);border:none;border-radius:var(--radius-sm);font-weight:700;font-size:13px;cursor:pointer;font-family:var(--font-body)}
.ib-submit:hover{background:var(--gold-bright)}
.ib-submit:disabled{opacity:0.4;cursor:not-allowed}

/* ===== MODALS ===== */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(4px);z-index:2000;display:none;align-items:center;justify-content:center}
.modal-bg.open{display:flex}
.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:540px;width:92%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal::-webkit-scrollbar{width:5px}
.modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.modal-top{padding:20px 20px 0;display:flex;justify-content:space-between;align-items:center}
.modal-top h2{font-family:var(--font-display);font-size:20px;color:var(--gold);font-weight:600}
.modal-x{width:30px;height:30px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);font-size:16px;display:flex;align-items:center;justify-content:center}
.modal-x:hover{color:var(--gold);border-color:var(--gold-dim)}
.modal-body{padding:20px}
.fg{margin-bottom:14px}
.fg label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:5px}
.fg input,.fg select,.fg textarea{width:100%;padding:9px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:var(--font-body);outline:none;transition:border-color 0.2s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold-dim)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--text-muted)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-submit{width:100%;padding:12px;background:var(--gold);color:var(--bg-primary);border:none;border-radius:var(--radius);font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font-body);margin-top:6px}
.form-submit:hover{background:var(--gold-bright)}
.form-note{font-size:11px;color:var(--text-muted);margin-top:10px;text-align:center;line-height:1.4}

/* Auth tabs */
.auth-tabs{display:flex;gap:0;margin-bottom:16px;border-bottom:2px solid var(--border)}
.auth-tab{flex:1;padding:10px;text-align:center;font-weight:600;font-size:13px;cursor:pointer;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all 0.2s}
.auth-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.auth-tab:hover{color:var(--text-primary)}
.role-pills{display:flex;gap:8px;margin-bottom:16px}
.role-pill{flex:1;padding:10px;text-align:center;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:12px;font-weight:600;color:var(--text-muted);transition:all 0.2s}
.role-pill.active{border-color:var(--gold);color:var(--gold);background:var(--gold-glow)}
.role-pill:hover{border-color:var(--gold-dim)}

/* ===== DASHBOARD ===== */
.dash-panel{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--bg-secondary);z-index:500;display:none;overflow-y:auto}
.dash-panel.open{display:block}
.dash-panel::-webkit-scrollbar{width:5px}
.dash-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.dash-header{padding:20px;border-bottom:2px solid var(--gold-dim);display:flex;justify-content:space-between;align-items:center}
.dash-header h2{font-family:var(--font-display);font-size:22px;color:var(--gold)}
.dash-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 20px}
.dash-tab{padding:12px 16px;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all 0.2s}
.dash-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.dash-tab:hover{color:var(--text-primary)}
.dash-content{padding:20px}
.dash-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:10px;position:relative}
.dash-card-title{font-weight:600;font-size:14px;color:var(--text-primary);margin-bottom:4px}
.dash-card-meta{font-size:12px;color:var(--text-muted);margin-bottom:8px}
.dash-card-actions{display:flex;gap:6px;flex-wrap:wrap}
.enquiry-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:8px}
.eq-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.eq-from{font-weight:600;font-size:13px;color:var(--text-primary)}
.eq-date{font-size:10px;color:var(--text-muted)}
.eq-prop{font-size:11px;color:var(--teal);margin-bottom:4px}
.eq-msg{font-size:12px;color:var(--text-secondary);line-height:1.4;margin-bottom:8px;padding:8px;background:var(--bg-tertiary);border-radius:var(--radius-sm)}
.eq-contact{font-size:11px;color:var(--text-muted);display:flex;gap:12px;margin-bottom:8px}
.eq-contact b{color:var(--text-secondary)}
.eq-actions{display:flex;gap:6px}
.empty-state{padding:40px 20px;text-align:center;color:var(--text-muted)}
.empty-state .emoji{font-size:36px;margin-bottom:8px}

/* Dashboard Guide (How it works) */
.dash-guide{padding:10px 0}
.guide-title{font-family:var(--font-display);font-size:20px;color:var(--gold);font-weight:600;margin-bottom:6px}
.guide-sub{font-size:13px;color:var(--text-secondary);margin-bottom:24px}
.guide-steps{display:flex;gap:16px}
.guide-step{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;text-align:center;position:relative}
.guide-step:not(:last-child)::after{content:'→';position:absolute;top:50%;right:-12px;transform:translateY(-50%);color:var(--gold-dim);font-size:18px;opacity:0.5;z-index:1}
.guide-num{width:48px;height:48px;border-radius:50%;background:var(--gold-glow);border:2px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--gold);margin:0 auto 10px}
.guide-step-title{font-weight:700;font-size:13px;color:var(--text-primary);margin-bottom:6px}
.guide-step-text{font-size:11px;color:var(--text-muted);line-height:1.5}

/* ===== HOME / LANDING PAGE ===== */
.home-overlay{position:fixed;top:68px;left:0;right:0;bottom:0;z-index:1500;overflow-y:auto;overflow-x:hidden;width:100%}
.home-overlay.hidden{display:none}
.home-scroll{min-height:100%;position:relative;padding-bottom:60px}

/* Hero */
.hero-section{position:relative;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden;width:100%}
.hero-bg{position:fixed;top:68px;left:0;right:0;bottom:0;background:url('../images/hero-bg.png') center center/cover no-repeat;filter:brightness(0.25) saturate(0.3);z-index:-1}
.hero-bg::after{content:'';position:fixed;top:68px;left:0;right:0;bottom:0;background:linear-gradient(180deg,rgba(28,28,28,0.4) 0%,rgba(28,28,28,0.7) 100%);z-index:-1}
.hero-content{position:relative;z-index:1;text-align:center;max-width:680px;width:100%;padding:60px 20px 40px}
.home-title{font-family:var(--font-display);font-size:56px;color:var(--gold);font-weight:700;margin-bottom:8px;text-shadow:0 3px 20px rgba(0,0,0,0.5);letter-spacing:1px}
.home-title span{color:var(--gold-bright);font-weight:400}
.home-tagline{font-size:20px;color:var(--white);font-weight:300;margin-bottom:6px;text-shadow:0 1px 8px rgba(0,0,0,0.5)}
.home-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:28px;line-height:1.6;text-shadow:0 1px 4px rgba(0,0,0,0.5);max-width:560px;margin-left:auto;margin-right:auto}

/* Search card */
.hero-search-card{background:rgba(37,37,37,0.92);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 22px;max-width:600px;width:100%;margin:0 auto 14px;box-shadow:var(--shadow-lg)}
.search-role-toggle{display:flex;gap:20px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.role-radio{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);cursor:pointer;transition:color 0.2s;font-weight:500}
.role-radio.active{color:var(--gold)}
.role-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-light);display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.role-dot::after{content:'';width:10px;height:10px;border-radius:50%;background:transparent;transition:background 0.2s}
.role-radio.active .role-dot{border-color:var(--gold)}
.role-radio.active .role-dot::after{background:var(--gold)}
.search-fields{display:flex;gap:8px;align-items:stretch}
.hero-search-input{flex:1;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--white);font-family:var(--font-body);outline:none;transition:border-color 0.2s}
.hero-search-input:focus{border-color:var(--gold-dim)}
.hero-search-input::placeholder{color:var(--text-muted)}
.hero-radius-wrap{display:flex;flex-direction:column;gap:2px;justify-content:center}
.hero-radius-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;text-align:center}
.hero-radius-select{padding:8px 10px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px;font-family:var(--font-body);outline:none;cursor:pointer}
.hero-search-btn{padding:12px 28px;background:var(--gold);color:var(--bg-primary);border:none;border-radius:var(--radius-sm);font-weight:700;font-size:14px;cursor:pointer;font-family:var(--font-body);white-space:nowrap;transition:all 0.2s}
.hero-search-btn:hover{background:var(--gold-bright);transform:translateY(-1px);box-shadow:0 4px 12px rgba(240,223,160,0.3)}
.home-locate{color:var(--teal);font-size:13px;cursor:pointer;display:inline-block;text-shadow:0 1px 4px rgba(0,0,0,0.5);transition:color 0.2s}
.home-locate:hover{text-decoration:underline;color:var(--gold)}

/* Stats bar - fixed bottom */
/* News Ticker - fixed bottom */
.news-ticker{position:fixed;bottom:0;left:0;right:0;z-index:1600;background:rgba(28,28,28,0.95);backdrop-filter:blur(10px);border-top:1px solid var(--gold-dim);padding:8px 0;overflow:hidden;white-space:nowrap}
.ticker-track{display:inline-block;animation:tickerScroll 120s linear infinite;padding-left:100%}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{display:inline;font-size:12px;color:var(--text-secondary);letter-spacing:0.3px}
.ticker-item b{color:var(--gold);font-weight:600}
.ticker-sep{display:inline-block;width:6px;height:6px;background:var(--gold-dim);border-radius:50%;margin:0 24px;vertical-align:middle;opacity:0.6}
@keyframes tickerScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Card Carousel Component */
.card-carousel{position:relative;display:flex;align-items:center;gap:0}
.card-carousel-track{flex:1;min-width:0}
.card-carousel-nav{display:none;width:36px;height:36px;border-radius:50%;background:rgba(42,42,42,0.9);border:1px solid var(--border);color:var(--text-secondary);font-size:22px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;z-index:2;transition:all 0.2s}
.card-carousel-nav:hover{border-color:var(--gold-dim);color:var(--gold)}
.card-carousel-dots{display:none;gap:8px;justify-content:center;margin-top:16px}
.card-carousel-dots .cdot{width:9px;height:9px;border-radius:50%;background:var(--border);cursor:pointer;transition:background 0.2s}
.card-carousel-dots .cdot.active{background:var(--gold-dim)}

/* Features */
.features-section{max-width:1000px;width:100%;margin:0 auto;padding:50px 20px;text-align:center;position:relative}
.features-heading{font-family:var(--font-display);font-size:26px;color:var(--gold);font-weight:600;margin-bottom:10px}
.features-sub{font-size:14px;color:var(--text-secondary);line-height:1.5;max-width:600px;margin:0 auto 32px}
#featuresGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.feature-card{background:rgba(37,37,37,0.88);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 16px;text-align:center;cursor:pointer;transition:all 0.3s}
.feature-card:hover{border-color:var(--gold-dim);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.feature-icon{width:60px;height:60px;border-radius:50%;background:var(--gold-glow);border:2px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 14px}
.feature-card-title{font-weight:700;font-size:15px;color:var(--gold);margin-bottom:6px}
.feature-card-text{font-size:12px;color:var(--text-secondary);line-height:1.5;margin-bottom:14px}
.feature-card-btn{display:inline-block;padding:8px 20px;background:var(--gold);color:var(--bg-primary);border:none;border-radius:var(--radius-sm);font-weight:700;font-size:12px;cursor:pointer;font-family:var(--font-body);transition:all 0.2s}
.feature-card-btn:hover{background:var(--gold-bright)}
.feature-card-btn.teal{background:var(--teal);color:var(--white)}
.feature-card-btn.teal:hover{background:var(--teal-dim)}

/* How it works */
.how-section{max-width:900px;width:100%;margin:0 auto;padding:40px 20px;text-align:center;position:relative}
.how-heading{font-family:var(--font-display);font-size:24px;color:var(--gold);font-weight:600;margin-bottom:32px}
#howSteps{max-width:900px;margin:0 auto;display:flex;gap:28px;align-items:stretch;justify-content:center}
.how-step{flex:1;padding:20px;position:relative;background:rgba(37,37,37,0.8);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:var(--radius-lg)}
.how-step:not(:last-child)::after{content:'→';position:absolute;top:50%;right:-18px;transform:translateY(-50%);color:var(--gold-dim);font-size:20px;opacity:0.5;z-index:1}
.how-num{width:56px;height:56px;border-radius:50%;background:var(--gold-glow);border:2px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--gold);margin:0 auto 12px}
.how-step-title{font-weight:700;font-size:14px;color:var(--text-primary);margin-bottom:6px}
.how-step-text{font-size:12px;color:var(--text-muted);line-height:1.5}

/* Reviews */
.reviews-section{max-width:960px;width:100%;margin:0 auto;padding:50px 20px;text-align:center;position:relative}
.reviews-heading{font-family:var(--font-display);font-size:24px;color:var(--gold);font-weight:600;margin-bottom:6px}
.reviews-sub{font-size:14px;color:var(--text-secondary);margin-bottom:10px}
.reviews-logos{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:24px}
.reviews-carousel-wrap{position:relative;padding:0 44px}
.reviews-carousel{display:flex;gap:14px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:4px 0}
.reviews-carousel::-webkit-scrollbar{display:none}
.review-card{min-width:calc((100% - 28px) / 3);max-width:calc((100% - 28px) / 3);scroll-snap-align:start;background:rgba(37,37,37,0.88);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:var(--radius);padding:18px;text-align:left;flex-shrink:0;transition:border-color 0.2s}
.review-card:hover{border-color:var(--gold-dim)}
.review-stars{color:var(--success);font-size:14px;margin-bottom:8px;letter-spacing:2px}
.review-text{font-size:12px;color:var(--text-secondary);line-height:1.5;margin-bottom:12px;min-height:60px}
.review-footer{display:flex;align-items:center;justify-content:space-between}
.review-source{font-size:11px;font-weight:600}
.review-source.tp{color:var(--success)}
.review-source.google .g-g{color:#4285F4}.review-source.google .g-o1{color:#EA4335}.review-source.google .g-o2{color:#FBBC05}.review-source.google .g-l{color:#34A853}.review-source.google .g-e{color:#EA4335}
.review-author{font-size:11px;color:var(--text-muted);text-align:right}
.review-author b{display:block;color:var(--text-secondary);font-size:12px}
.review-nav{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:rgba(42,42,42,0.9);border:1px solid var(--border);color:var(--text-secondary);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:all 0.2s}
.review-nav:hover{border-color:var(--gold-dim);color:var(--gold)}
.review-prev{left:0}
.review-next{right:0}
.review-dots{display:flex;gap:6px;justify-content:center;margin-top:14px}
.review-dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:background 0.2s}
.review-dot.active{background:var(--gold-dim)}

/* Comparison - Claimed vs Unclaimed */
.compare-section{max-width:800px;width:100%;margin:0 auto;padding:50px 20px;text-align:center;position:relative}
.compare-heading{font-family:var(--font-display);font-size:24px;color:var(--gold);font-weight:600;margin-bottom:6px}
.compare-sub{font-size:14px;color:var(--text-secondary);margin-bottom:28px;max-width:500px;margin-left:auto;margin-right:auto}
.compare-grid{display:flex;align-items:stretch;gap:0;justify-content:center}
.compare-card{flex:1;max-width:320px;background:rgba(37,37,37,0.88);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;text-align:left}
.compare-card.claimed{border-color:var(--gold-dim)}
.compare-badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;margin-bottom:12px;text-transform:uppercase;letter-spacing:0.5px}
.unclaimed-badge{background:rgba(255,255,255,0.08);color:var(--text-muted)}
.claimed-badge{background:var(--gold-glow);color:var(--gold);border:1px solid var(--gold-dim)}
.compare-card-title{font-weight:700;font-size:14px;color:var(--text-primary);margin-bottom:10px}
.compare-photo-placeholder{background:var(--bg-tertiary);border:1px dashed var(--border);border-radius:var(--radius);padding:20px;text-align:center;color:var(--text-muted);font-size:12px;margin-bottom:12px}
.compare-photo-active{background:var(--gold-glow);border:1px solid var(--gold-dim);border-radius:var(--radius);padding:20px;text-align:center;color:var(--gold);font-size:12px;font-weight:600;margin-bottom:12px}
.compare-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid rgba(255,255,255,0.04);font-size:12px}
.compare-row:last-child{border-bottom:none}
.compare-label{color:var(--text-muted);font-weight:500}
.compare-val.muted{color:var(--text-muted);font-style:italic}
.compare-val.gold{color:var(--gold);font-weight:600}
.compare-arrow{display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--gold-dim);padding:0 12px;font-weight:300}

/* Pricing */
.pricing-section{max-width:900px;width:100%;margin:0 auto;padding:50px 20px;text-align:center;position:relative}
.pricing-heading{font-family:var(--font-display);font-size:24px;color:var(--gold);font-weight:600;margin-bottom:6px}
.pricing-sub{font-size:14px;color:var(--text-secondary);margin-bottom:28px;max-width:500px;margin-left:auto;margin-right:auto}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:800px;margin:0 auto}
.pricing-card{background:rgba(37,37,37,0.88);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 18px;text-align:center;transition:all 0.3s;position:relative}
.pricing-card:hover{border-color:var(--gold-dim);transform:translateY(-4px)}
.pricing-card.popular{border-color:var(--gold-dim);box-shadow:0 0 20px rgba(240,223,160,0.08)}
.pricing-card.popular::before{content:'Most Popular';position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--bg-primary);font-size:10px;font-weight:700;padding:2px 12px;border-radius:10px;text-transform:uppercase;letter-spacing:0.5px}
.pricing-card-name{font-weight:700;font-size:15px;color:var(--text-primary);margin-bottom:4px}
.pricing-card-price{font-family:var(--font-display);font-size:32px;color:var(--gold);font-weight:700;margin-bottom:2px}
.pricing-card-price small{font-size:14px;font-weight:400;color:var(--text-secondary)}
.pricing-card-desc{font-size:12px;color:var(--text-muted);margin-bottom:14px;line-height:1.4}
.pricing-card-features{text-align:left;margin-bottom:16px}
.pricing-feature{font-size:12px;color:var(--text-secondary);padding:5px 0;display:flex;align-items:flex-start;gap:6px;line-height:1.4}
.pricing-feature::before{content:'✓';color:var(--gold);font-weight:700;flex-shrink:0}
.pricing-card-btn{display:inline-block;padding:10px 24px;background:var(--gold);color:var(--bg-primary);border:none;border-radius:var(--radius-sm);font-weight:700;font-size:13px;cursor:pointer;font-family:var(--font-body);transition:all 0.2s;width:100%}
.pricing-card-btn:hover{background:var(--gold-bright)}
.pricing-card-btn.outline{background:transparent;border:1px solid var(--gold-dim);color:var(--gold)}
.pricing-card-btn.outline:hover{background:var(--gold-glow)}
.pricing-note{font-size:11px;color:var(--text-muted);margin-top:20px;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.5}
.pricing-saving{background:rgba(76,175,80,0.1);border:1px solid rgba(76,175,80,0.3);border-radius:var(--radius);padding:10px;margin-top:16px;font-size:11px;color:var(--success);line-height:1.4}

/* CTA */
.cta-section{padding:50px 20px;text-align:center;position:relative}
.cta-inner{max-width:500px;margin:0 auto;background:rgba(37,37,37,0.88);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 30px}
.cta-inner h2{font-family:var(--font-display);font-size:26px;color:var(--gold);font-weight:600;margin-bottom:8px}
.cta-inner p{font-size:14px;color:var(--text-secondary);margin-bottom:20px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== TOAST ===== */
#toast{position:fixed;bottom:-60px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--bg-primary);padding:12px 24px;border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:3000;transition:bottom 0.3s;font-weight:700;font-size:13px;white-space:nowrap}

/* ===== LOADING ===== */
/* Pattern lock screen */
.site-gate{position:fixed;inset:0;z-index:99999;background:#0a0a0a;display:flex;align-items:center;justify-content:center;transition:opacity 0.5s ease,visibility 0.5s ease;font-family:'DM Sans',sans-serif;-webkit-tap-highlight-color:transparent;user-select:none;overflow:hidden}
.site-gate::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(0,200,150,0.03) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(0,200,150,0.02) 0%,transparent 50%);pointer-events:none}
.site-gate.unlocked{opacity:0;visibility:hidden;pointer-events:none}

#lockScreen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%}
.lock-brand{text-align:center;margin-bottom:48px}
.lock-brand h1{font-family:'Playfair Display',serif;font-weight:600;font-size:2.6rem;letter-spacing:0.02em;color:#f1f1f1}
.lock-brand h1 span{color:#00c896}
.lock-brand p{font-size:0.95rem;color:#666;margin-top:8px;letter-spacing:0.15em;text-transform:uppercase}

.grid-wrapper{position:relative;width:240px;height:240px}
.grid-wrapper.lock-shake{animation:lockShake 0.4s ease-in-out}
@keyframes lockShake{0%,100%{transform:translateX(0)}15%{transform:translateX(-6px)}30%{transform:translateX(6px)}45%{transform:translateX(-5px)}60%{transform:translateX(5px)}75%{transform:translateX(-3px)}90%{transform:translateX(3px)}}

#lockCanvas{position:absolute;top:0;left:0;width:240px;height:240px;z-index:1;pointer-events:none}
.lock-dots{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:100%;height:100%;position:relative;z-index:2}
.lock-dot{display:flex;align-items:center;justify-content:center;cursor:pointer}
.lock-dot-inner{width:20px;height:20px;border-radius:50%;background:#2a2a2a;border:2px solid #3a3a3a;transition:all 0.15s ease}
.lock-dot-inner.lock-active{background:#00c896;border-color:#00c896;box-shadow:0 0 16px rgba(0,200,150,0.35),0 0 32px rgba(0,200,150,0.35);transform:scale(1.25)}
.lock-dot-inner.lock-success{background:#2ed573;border-color:#2ed573;box-shadow:0 0 16px rgba(46,213,115,0.35),0 0 32px rgba(46,213,115,0.35);transform:scale(1.25)}
.lock-dot-inner.lock-error{background:#ff4757;border-color:#ff4757;box-shadow:0 0 16px rgba(255,71,87,0.35),0 0 32px rgba(255,71,87,0.35);transform:scale(1.25)}

.lock-hint{text-align:center;margin-top:40px;font-size:1.15rem;color:#666;letter-spacing:0.05em;min-height:1.4em;transition:color 0.2s ease}
.lock-hint.lock-success-text{color:#2ed573}
.lock-hint.lock-error-text{color:#ff4757}

/* Confidentiality overlay */
#confidentialityOverlay{display:none;position:fixed;inset:0;background:#0a0a0a;z-index:100;flex-direction:column;align-items:center;justify-content:center;padding:32px;opacity:0;transition:opacity 0.5s ease}
#confidentialityOverlay.visible{display:flex;opacity:1}

.conf-card{max-width:500px;text-align:center}
.conf-card h2{font-family:'Playfair Display',serif;font-size:2.4rem;font-weight:600;color:#f1f1f1;margin-bottom:8px}
.conf-card h2 span{color:#00c896}
.conf-card .conf-subtitle{font-size:1.15rem;color:#666;margin-bottom:44px;line-height:1.6}
.conf-card .conf-subtitle strong{color:#f1f1f1}
.conf-card .conf-disclaimer{font-size:1.1rem;color:#f1f1f1;line-height:1.7;margin-bottom:40px;padding:0 8px}

.conf-check{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:40px;cursor:pointer}
.conf-check input[type="checkbox"]{appearance:none;-webkit-appearance:none;width:26px;height:26px;border:2px solid #3a3a3a;border-radius:6px;background:#2a2a2a;cursor:pointer;flex-shrink:0;position:relative;transition:all 0.15s ease}
.conf-check input[type="checkbox"]:checked{background:#00c896;border-color:#00c896}
.conf-check input[type="checkbox"]:checked::after{content:'\2713';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:15px;font-weight:700}
.conf-check label{font-size:1.05rem;color:#f1f1f1;cursor:pointer;text-align:left}

.conf-enter{display:inline-block;padding:16px 52px;background:#00c896;color:#0a0a0a;font-family:'DM Sans',sans-serif;font-size:1.1rem;font-weight:700;border:none;border-radius:8px;cursor:pointer;letter-spacing:0.04em;transition:all 0.2s ease;opacity:0.3;pointer-events:none;margin-bottom:32px}
.conf-enter.active{opacity:1;pointer-events:auto}
.conf-enter.active:hover{background:#00e6a8;transform:translateY(-1px);box-shadow:0 4px 20px rgba(0,200,150,0.3)}

.gate-demo-info{text-align:left;border-top:1px solid #2a2a2a;padding-top:24px;margin-top:8px}
.gate-demo-title{font-size:12px;color:#999;font-weight:600;margin-bottom:8px}
.gate-demo-cred{font-size:12px;color:#666;margin-bottom:4px;line-height:1.5}
.gate-demo-cred b{color:#00c896;font-weight:600}

.lock-footer{position:absolute;bottom:24px;font-size:0.8rem;color:#555;letter-spacing:0.1em;text-transform:uppercase}
.lock-version{color:#00c896;font-weight:700;margin-right:8px;letter-spacing:0.05em}
.lock-brand .lock-version-top{display:block;font-family:'DM Sans',sans-serif;font-size:0.75rem;color:#00c896;font-weight:700;letter-spacing:0.15em;margin-top:12px}

@media(max-height:560px){
  .lock-brand{margin-bottom:24px}
  .lock-brand h1{font-size:2rem}
  .lock-hint{margin-top:24px}
  .conf-card h2{font-size:1.8rem}
}

.loading-overlay{position:absolute;inset:0;background:var(--bg-primary);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}
.loading-overlay.hidden{display:none}
.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-size:13px;color:var(--text-muted)}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  /* Global mobile overflow prevention */
  .home-overlay{width:100vw;max-width:100vw}
  .home-overlay>*{max-width:100vw;overflow-x:hidden}

  .sidebar{width:100%;min-width:100%;height:50vh}
  .sidebar.hidden{margin-left:0;height:0;min-height:0;width:100%;min-width:100%}
  .main{flex-direction:column}
  .header-nav{display:none}
  .header-actions{gap:4px}
  .header-actions .btn{font-size:11px;padding:6px 10px}
  #listBtn{font-size:10px;padding:5px 8px}

  /* Map controls - icon only on mobile */
  .ctrl-label{display:none}
  .map-ctrl-btn{padding:7px 8px}

  /* Map legend */
  .map-legend-top{padding:5px 10px;gap:8px;font-size:10px;top:8px}
  .legend-dot{width:8px;height:8px}
  .detail-panel{width:100%}

  /* Hero - constrain everything */
  .hero-section{min-height:auto;padding:20px 0 10px;width:100%}
  .hero-content{padding:20px 16px 16px;max-width:100%;width:100%}
  .home-title{font-size:28px}
  .home-tagline{font-size:15px}
  .home-subtitle{font-size:12px;margin-bottom:16px;max-width:100%}

  /* Search card - full width with padding */
  .hero-search-card{padding:14px 14px;margin:0 0 12px;border-radius:var(--radius);max-width:100%;width:100%}
  .search-role-toggle{gap:10px;margin-bottom:10px;padding-bottom:8px}
  .role-radio{font-size:12px}
  .search-fields{flex-direction:column;gap:8px}
  .hero-search-input{padding:11px 12px;font-size:14px;width:100%}
  .hero-radius-wrap{flex-direction:row;gap:8px;align-items:center;justify-content:center}
  .hero-radius-label{margin:0;font-size:10px}
  .hero-radius-select{min-width:80px}
  .hero-search-btn{padding:12px;font-size:14px;width:100%}

  /* Card carousel - show arrows + dots on mobile */
  .card-carousel-nav{display:flex}
  .card-carousel-dots{display:flex}
  .card-carousel{gap:6px;width:100%;max-width:100%}
  .card-carousel-track{overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* Features - single card carousel */
  .features-section{padding:30px 0;max-width:100%;width:100%}
  .features-heading{font-size:18px;padding:0 16px}
  .features-sub{font-size:12px;padding:0 16px;margin-bottom:16px}
  #featuresGrid{display:flex!important;grid-template-columns:none!important;flex-wrap:nowrap!important;gap:12px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 2px}
  #featuresGrid::-webkit-scrollbar{display:none}
  .feature-card{min-width:calc(100vw - 130px)!important;max-width:calc(100vw - 130px)!important;flex-shrink:0!important;scroll-snap-align:center;padding:20px 16px}

  /* How it works - single card carousel */
  .how-section{padding:30px 0;max-width:100%;width:100%}
  .how-heading{font-size:18px;padding:0 16px;margin-bottom:16px}
  #howSteps{flex-direction:row!important;flex-wrap:nowrap!important;gap:12px;overflow-x:auto!important;scroll-behavior:smooth;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 2px}
  #howSteps::-webkit-scrollbar{display:none}
  .how-step{min-width:calc(100vw - 130px)!important;max-width:calc(100vw - 130px)!important;flex-shrink:0!important;scroll-snap-align:center;margin:0}
  .how-step:not(:last-child)::after{display:none!important}

  /* Reviews - single card carousel */
  .reviews-section{padding:30px 0;max-width:100%;width:100%}
  .reviews-heading{font-size:18px;padding:0 16px}
  .reviews-sub{padding:0 16px;font-size:12px}
  .reviews-logos{margin-bottom:14px}
  .reviews-carousel-wrap{padding:0 40px}
  .reviews-carousel{scroll-snap-type:x mandatory}
  .reviews-carousel>*{scroll-snap-align:center}
  .review-card{min-width:calc(100vw - 110px)!important;max-width:calc(100vw - 110px)!important}
  .review-text{min-height:auto;font-size:11px}
  .review-nav{width:32px;height:32px;font-size:16px}

  /* Ticker */
  .news-ticker{padding:6px 0}
  .ticker-item{font-size:11px}
  .ticker-sep{margin:0 16px}

  /* Comparison */
  .compare-section{padding:30px 16px}
  .compare-heading{font-size:18px}
  .compare-grid{flex-direction:column;gap:12px;align-items:center}
  .compare-card{max-width:100%;width:100%}
  .compare-arrow{transform:rotate(90deg);padding:4px 0}

  /* Pricing */
  .pricing-section{padding:30px 16px}
  .pricing-heading{font-size:18px}
  .pricing-grid{grid-template-columns:1fr;gap:14px}
  .pricing-card-price{font-size:28px}

  /* CTA */
  .cta-section{padding:30px 16px;max-width:100%;width:100%}
  .cta-inner{padding:24px 16px}
  .cta-inner h2{font-size:18px}
  .cta-btns{flex-direction:column}
  .cta-btns .btn{width:100%}
}

/* Tablet */
@media(min-width:769px) and (max-width:1024px){
  .hero-content{max-width:580px}
  #featuresGrid{grid-template-columns:repeat(4,1fr);gap:10px}
  .features-section{padding:40px 16px}
  .how-section{padding:40px 16px}
  .reviews-section{padding:40px 16px}
}
