/* =============================================================
   PROPERTY4YOU — Zoopla-inspired | Blue Brand
   ============================================================= */

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

:root{
  --blue:         #1B54CC;
  --blue-mid:     #2E66D9;
  --blue-dark:    #0E3A9E;
  --blue-navy:    #0A1F5E;
  --blue-pale:    #EEF3FF;
  --blue-light:   #E5ECFF;
  --sale-green:   #117A5A;
  --sale-pale:    #E3F5EE;
  --warm-bg:      #F4F2EF;
  --cream:        #FAFAF8;
  --white:        #FFFFFF;
  --text:         #262626;
  --text-muted:   #696969;
  --text-light:   #9E9E9E;
  --border:       #E8E8E8;
  --border-mid:   #D4D4D4;
  --wa-green:     #25D366;
  --wa-dark:      #128C7E;
  --shadow-sm:    0 1px 6px rgba(0,0,0,0.06);
  --shadow:       0 4px 16px rgba(0,0,0,0.10);
  --shadow-lg:    0 12px 40px rgba(0,0,0,0.15);
  --radius-sm:    6px;
  --radius:       10px;
  --radius-lg:    16px;
  --transition:   0.2s ease;
  --font:         'Inter','Segoe UI',-apple-system,sans-serif;
}

html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--text);background:var(--white);overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}
.bh-container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ── Buttons ── */
.bh-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:6px;font-weight:600;font-size:.93rem;cursor:pointer;transition:var(--transition);border:2px solid transparent;white-space:nowrap}
.bh-btn-primary{background:var(--blue);color:var(--white)}
.bh-btn-primary:hover{background:var(--blue-dark);color:var(--white)}
.bh-btn-wa{background:var(--wa-green);color:var(--white)}
.bh-btn-wa:hover{background:var(--wa-dark);color:var(--white)}
.bh-btn-wa-lg{display:inline-flex;align-items:center;gap:9px;padding:12px 24px;background:var(--wa-green);color:var(--white);border-radius:6px;font-weight:700;font-size:1rem;transition:var(--transition);border:none}
.bh-btn-wa-lg:hover{background:var(--wa-dark);color:var(--white)}
.bh-btn-outline{background:transparent;color:var(--blue);border-color:var(--blue);padding:11px 24px}
.bh-btn-outline:hover{background:var(--blue);color:var(--white)}
.bh-btn-outline-white{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.65);padding:12px 24px;border-radius:6px;font-weight:600;font-size:.93rem;display:inline-flex;align-items:center;gap:8px;transition:var(--transition)}
.bh-btn-outline-white:hover{background:rgba(255,255,255,.12);color:var(--white)}
.bh-btn-danger{background:#DC2626;color:white;border:none}
.bh-btn-danger:hover{background:#B91C1C}

/* ══════════════════════════
   NAV — Zoopla white | 3-col
══════════════════════════ */
.bh-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:var(--white);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 8px rgba(0,0,0,.06);
}
.bh-nav-inner{
  max-width:1200px;margin:0 auto;padding:0 24px;
  height:66px;display:flex;align-items:center;
}
.bh-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-right:32px}
.bh-logo-img{height:40px;width:auto;object-fit:contain}

/* Center nav links */
.bh-nav-links{
  flex:1;display:flex;align-items:center;justify-content:center;gap:4px;
}
.bh-nav-links a{
  color:var(--text-muted);padding:8px 14px;border-radius:var(--radius-sm);
  font-size:.89rem;font-weight:500;transition:var(--transition);
}
.bh-nav-links a:hover{color:var(--blue);background:var(--blue-pale)}

/* Right auth area */
.bh-nav-auth{flex-shrink:0;display:flex;align-items:center;gap:8px;margin-left:32px}
.bh-nav-auth a{color:var(--text-muted);padding:8px 14px;border-radius:var(--radius-sm);font-size:.89rem;font-weight:500;transition:var(--transition)}
.bh-nav-auth a:hover{color:var(--blue)}
.bh-nav-cta{background:var(--blue)!important;color:var(--white)!important;border-radius:6px!important;padding:9px 18px!important}
.bh-nav-cta:hover{background:var(--blue-dark)!important;color:var(--white)!important}

.bh-hamburger{display:none;flex-direction:column;gap:5px;background:transparent;border:none;cursor:pointer;padding:4px;margin-left:16px}
.bh-hamburger span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:var(--transition)}
.bh-nav-mobile-only{display:none}

@media(max-width:860px){
  .bh-hamburger{display:flex}
  .bh-nav-auth{display:none!important}
  .bh-nav-mobile-only{display:flex}
  .bh-nav-links{
    display:none;position:absolute;top:66px;left:0;right:0;
    background:var(--white);flex-direction:column;padding:12px 24px 20px;
    gap:4px;border-bottom:1px solid var(--border);box-shadow:0 8px 24px rgba(0,0,0,.10);
    margin:0;
  }
  .bh-nav-links.open{display:flex}
  .bh-nav-links a{width:100%;padding:12px 16px;color:var(--text)}
}

/* ══════════════════════════
   HERO — Zoopla style
   Full-bleed photo + centered
   search card
══════════════════════════ */
.bh-hero{
  position:relative;
  min-height:100vh;
  background:#1a3a6e center/cover no-repeat;
  display:flex;align-items:center;justify-content:center;
  padding:100px 24px 60px;
}
.bh-hero-overlay{
  position:absolute;inset:0;
  background:url('images/hero_bg.jpg') center/cover no-repeat;
}
.bh-hero-overlay::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(5,15,50,.55) 0%,rgba(10,31,94,.42) 60%,rgba(5,15,50,.62) 100%);
}
.bh-hero-content{
  position:relative;z-index:2;width:100%;max-width:680px;text-align:center;
}
.bh-hero-title{
  font-size:clamp(2.2rem,6vw,3.8rem);font-weight:800;color:var(--white);
  line-height:1.1;margin-bottom:12px;letter-spacing:-.02em;
  text-shadow:0 2px 16px rgba(0,0,0,.4);
}
.bh-hero-sub{
  font-size:clamp(.95rem,2vw,1.1rem);color:rgba(255,255,255,.85);
  margin-bottom:24px;line-height:1.6;
}

/* ── Zoopla search card ── */
.z-search-card{
  background:var(--white);
  border-radius:12px 12px 0 0;
  padding:24px 24px 20px;
  box-shadow:0 8px 40px rgba(0,0,0,.22);
  text-align:left;
}
.z-search-row{
  display:flex;gap:10px;align-items:stretch;flex-wrap:wrap;
}
.z-search-input-wrap{
  flex:2;min-width:200px;
  display:flex;align-items:center;gap:10px;
  border:1.5px solid var(--border-mid);border-radius:6px;
  padding:11px 14px;background:var(--white);transition:border-color .2s;
}
.z-search-input-wrap:focus-within{border-color:var(--blue)}
.z-search-input-wrap i{color:var(--text-muted);font-size:.95rem;flex-shrink:0}
.z-search-input{border:none;background:transparent;outline:none;font-size:.95rem;font-family:var(--font);color:var(--text);width:100%}
.z-search-input::placeholder{color:var(--text-muted)}
.z-filter-row{
  display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;
}
.z-filter-select,.z-filter-input{
  flex:1;min-width:140px;
  padding:9px 12px;border:1.5px solid var(--border-mid);border-radius:6px;
  font-size:.88rem;font-family:var(--font);color:var(--text);
  background:var(--white);outline:none;transition:border-color .2s;
}
.z-filter-select:focus,.z-filter-input:focus{border-color:var(--blue)}
.z-search-btn{
  padding:11px 28px;background:var(--blue);color:var(--white);
  border:none;border-radius:6px;font-weight:700;font-size:.95rem;
  cursor:pointer;transition:var(--transition);
  display:flex;align-items:center;gap:8px;white-space:nowrap;
  align-self:flex-start;
}
.z-search-btn:hover{background:var(--blue-dark)}
.bh-search-clear{
  color:var(--text-muted);font-size:.85rem;display:inline-flex;align-items:center;gap:5px;
  margin-top:8px;padding:2px 0;
}
.bh-search-clear:hover{color:var(--text)}

/* ══════════════════════════
   PROPERTY TYPE STRIP
══════════════════════════ */
.p4y-type-strip{background:var(--white);border-bottom:2px solid var(--border);overflow:hidden}
.p4y-type-pills{display:flex;align-items:stretch;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;max-width:1200px;margin:0 auto;padding:0 16px}
.p4y-type-pills::-webkit-scrollbar{display:none}
.p4y-type-pill{display:flex;flex-direction:column;align-items:center;gap:5px;padding:14px 18px;border:none;background:transparent;cursor:pointer;white-space:nowrap;font-size:.76rem;font-weight:600;color:var(--text-muted);border-bottom:3px solid transparent;transition:var(--transition);flex-shrink:0;line-height:1}
.p4y-type-pill i{font-size:1.1rem}
.p4y-type-pill:hover{color:var(--blue);background:var(--blue-pale)}
.p4y-type-pill.active{color:var(--blue);border-bottom-color:var(--blue)}
.p4y-type-pill input[type=radio]{position:absolute;opacity:0;pointer-events:none}

/* ══════════════════════════
   FILTER BAR
══════════════════════════ */
.p4y-filter-bar{background:var(--white);border-bottom:1px solid var(--border);padding:10px 0;position:sticky;top:0;z-index:110;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.p4y-filter-inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap}
.p4y-filt-group{display:flex;flex-direction:column;gap:3px;flex-shrink:0}
.p4y-filt-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}
.p4y-filt-select{padding:8px 28px 8px 10px;border:1.5px solid var(--border-mid);border-radius:6px;font-size:.86rem;font-family:var(--font);color:var(--text);background:var(--white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2394a3b8'/%3E%3C/svg%3E") no-repeat right 9px center;appearance:none;-webkit-appearance:none;outline:none;transition:border-color .2s;cursor:pointer;min-width:130px}
.p4y-filt-select:focus,.p4y-filt-select:hover{border-color:var(--blue)}
.p4y-price-wrap{display:flex;align-items:flex-end;gap:4px}
.p4y-price-sep{font-size:.82rem;color:var(--text-muted);padding-bottom:9px;font-weight:600}
.p4y-btn-group{display:flex;border:1.5px solid var(--border-mid);border-radius:6px;overflow:hidden}
.p4y-btn-grp-item{padding:8px 13px;background:var(--white);border:none;border-right:1px solid var(--border-mid);cursor:pointer;font-size:.84rem;font-weight:600;color:var(--text-muted);transition:var(--transition);white-space:nowrap}
.p4y-btn-grp-item:last-child{border-right:none}
.p4y-btn-grp-item:hover{background:var(--blue-pale);color:var(--blue)}
.p4y-btn-grp-item.active,.p4y-btn-grp-item input:checked~*{background:var(--blue);color:var(--white)}
.p4y-filter-actions{display:flex;gap:8px;align-items:flex-end;margin-left:auto}
.p4y-more-btn{padding:8px 14px;border:1.5px solid var(--border-mid);border-radius:6px;background:var(--white);cursor:pointer;font-size:.86rem;font-weight:600;color:var(--text);display:inline-flex;align-items:center;gap:6px;transition:var(--transition)}
.p4y-more-btn:hover,.p4y-more-btn.open{border-color:var(--blue);color:var(--blue)}
.p4y-more-btn .p4y-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--blue);color:#fff;border-radius:50%;width:16px;height:16px;font-size:.68rem;font-weight:800}
.p4y-apply-btn{padding:8px 20px;background:var(--blue);color:var(--white);border:none;border-radius:6px;font-weight:700;font-size:.88rem;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:var(--transition);white-space:nowrap}
.p4y-apply-btn:hover{background:var(--blue-dark)}
.p4y-clear-btn{padding:8px 14px;border:1.5px solid #FECACA;border-radius:6px;background:#FEF2F2;color:#B91C1C;cursor:pointer;font-size:.84rem;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:var(--transition);white-space:nowrap}
.p4y-clear-btn:hover{background:#FEE2E2}

/* ══════════════════════════
   MORE FILTERS PANEL
══════════════════════════ */
.p4y-more-panel{background:#F8FAFF;border-bottom:2px solid var(--blue-pale);max-height:0;overflow:hidden;transition:max-height .35s ease}
.p4y-more-panel.open{max-height:320px}
.p4y-more-inner{max-width:1200px;margin:0 auto;padding:20px 20px;display:flex;gap:32px;flex-wrap:wrap}
.p4y-amenity-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}
.p4y-amenity-checks{display:flex;flex-wrap:wrap;gap:8px}
.p4y-amenity-check{display:inline-flex;align-items:center;gap:7px;padding:7px 15px;border:1.5px solid var(--border-mid);border-radius:22px;cursor:pointer;font-size:.84rem;font-weight:500;color:var(--text);transition:var(--transition);user-select:none}
.p4y-amenity-check:hover{border-color:var(--blue);color:var(--blue)}
.p4y-amenity-check.checked{background:var(--blue-pale);border-color:var(--blue);color:var(--blue);font-weight:600}
.p4y-amenity-check i{font-size:.88rem}
.p4y-amenity-check input[type=checkbox]{display:none}

/* ══════════════════════════
   ACTIVE FILTER CHIPS
══════════════════════════ */
.p4y-active-chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px;align-items:center}
.p4y-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 11px 5px 12px;background:var(--blue-pale);color:var(--blue);border-radius:20px;font-size:.79rem;font-weight:600;border:1px solid #93c5fd}
.p4y-chip-remove{cursor:pointer;opacity:.65;margin-left:1px;font-size:.78rem;font-weight:800;padding:0 2px;line-height:1;border:none;background:none;color:var(--blue)}
.p4y-chip-remove:hover{opacity:1}
.p4y-chip-clear-all{font-size:.8rem;color:var(--text-muted);display:inline-flex;align-items:center;gap:5px;cursor:pointer;padding:5px 10px;border-radius:20px;border:1px solid var(--border-mid);background:var(--white);font-weight:500;transition:var(--transition)}
.p4y-chip-clear-all:hover{border-color:#DC2626;color:#DC2626}

/* ══════════════════════════
   RESULTS BAR (count + sort)
══════════════════════════ */
.p4y-results-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.p4y-results-count{font-size:.9rem;color:var(--text-muted)}
.p4y-results-count strong{color:var(--text);font-size:1rem;font-weight:700}
.p4y-sort-wrap{display:flex;align-items:center;gap:8px}
.p4y-sort-label{font-size:.82rem;color:var(--text-muted);font-weight:500;white-space:nowrap}
.p4y-sort-select{padding:7px 28px 7px 10px;border:1.5px solid var(--border-mid);border-radius:6px;font-size:.85rem;font-family:var(--font);color:var(--text);background:var(--white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2394a3b8'/%3E%3C/svg%3E") no-repeat right 8px center;appearance:none;-webkit-appearance:none;outline:none;cursor:pointer;transition:border-color .2s}
.p4y-sort-select:focus{border-color:var(--blue)}

/* Responsive filter bar */
@media(max-width:900px){
  .p4y-filter-inner{gap:6px}
  .p4y-filt-select{min-width:110px;font-size:.82rem}
  .p4y-filter-actions{width:100%;justify-content:flex-end}
  .p4y-btn-grp-item{padding:8px 10px;font-size:.8rem}
}
@media(max-width:640px){
  .p4y-type-pill{padding:12px 14px;font-size:.72rem}
  .p4y-more-inner{gap:20px}
}

/* ── Dark CTA bar (Zoopla "Know your value" panel) ── */
.z-hero-cta{
  background:var(--blue-navy);
  border-radius:0 0 12px 12px;
  padding:18px 24px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
  box-shadow:0 8px 40px rgba(0,0,0,.22);
}
.z-hero-cta-text strong{color:var(--white);font-size:.95rem;display:block;margin-bottom:2px}
.z-hero-cta-text span{color:rgba(255,255,255,.72);font-size:.84rem}
.z-cta-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 22px;border:2px solid rgba(255,255,255,.65);
  border-radius:6px;color:var(--white);font-weight:700;font-size:.88rem;
  transition:var(--transition);white-space:nowrap;
}
.z-cta-btn:hover{background:rgba(255,255,255,.12);color:var(--white)}

/* ── Trust bar below hero ── */
.z-trust-bar{
  background:var(--white);border-bottom:1px solid var(--border);
  padding:14px 0;
}
.z-trust-inner{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:flex;flex-wrap:wrap;justify-content:center;gap:12px 48px;
}
.z-trust-item{
  display:flex;align-items:center;gap:8px;
  font-size:.86rem;font-weight:600;color:var(--text);
}
.z-trust-item i{color:var(--blue)}

/* ══════════════════════════
   LISTINGS
══════════════════════════ */
.bh-listings{padding:48px 0 80px;background:var(--warm-bg)}
.bh-listings-header{margin-bottom:28px}
.bh-section-title{font-size:clamp(1.5rem,3.5vw,2.2rem);color:var(--text);font-weight:800;letter-spacing:-.01em}
.bh-count-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--blue-pale);color:var(--blue);border-radius:50px;padding:2px 12px;font-size:.8rem;font-weight:700;margin-left:10px;vertical-align:middle}

.bh-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:20px}
.bh-card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition);border:1px solid var(--border);position:relative}
.bh-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.bh-card-featured{border-color:var(--blue)}
.bh-featured-ribbon{position:absolute;top:14px;left:0;z-index:3;background:var(--blue);color:var(--white);font-size:.7rem;font-weight:700;padding:4px 14px 4px 12px;border-radius:0 50px 50px 0;text-transform:uppercase;letter-spacing:1px}
.bh-card-img-wrap{display:block;overflow:hidden;height:210px;position:relative;background:var(--blue-pale)}
.bh-card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.bh-card:hover .bh-card-img-wrap img{transform:scale(1.04)}
.bh-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--blue-mid);background:var(--blue-pale)}
.bh-card-type-badge{position:absolute;bottom:10px;left:12px;background:var(--sale-green);color:var(--white);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:4px 10px;border-radius:4px}
.bh-card-body{padding:16px 18px}
.bh-card-location{font-size:.78rem;color:var(--text-muted);margin-bottom:5px;display:flex;align-items:center;gap:5px}
.bh-card-location i{color:var(--blue)}
.bh-card-title{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:7px;line-height:1.3}
.bh-card-title a:hover{color:var(--blue)}
.bh-card-desc{font-size:.86rem;color:var(--text-muted);margin-bottom:10px;line-height:1.55}
.bh-card-specs{display:flex;gap:14px;font-size:.8rem;color:var(--text-muted);margin-bottom:10px;flex-wrap:wrap}
.bh-card-specs span{display:flex;align-items:center;gap:4px}
.bh-card-specs i{color:var(--blue)}
.bh-card-amenities{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.bh-amenity-dot{width:28px;height:28px;background:var(--blue-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;color:var(--blue);cursor:default}
.bh-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:12px;border-top:1px solid var(--border);flex-wrap:wrap;gap:6px}
.bh-card-price{display:flex;align-items:baseline;gap:4px}
.bh-price-from{font-size:.72rem;color:var(--text-muted)}
.bh-price-amount{font-size:1.3rem;font-weight:800;color:var(--text)}
.bh-card-btn{background:var(--blue);color:var(--white);padding:8px 18px;border-radius:6px;font-size:.82rem;font-weight:600;display:flex;align-items:center;gap:6px;transition:var(--transition)}
.bh-card-btn:hover{background:var(--blue-dark);color:var(--white)}
.bh-card-actions{display:flex;align-items:center;gap:8px}

.bh-empty{text-align:center;padding:80px 24px;color:var(--text-muted)}
.bh-empty i{font-size:4rem;margin-bottom:16px;color:var(--border-mid);display:block}
.bh-empty h3{font-size:1.4rem;font-weight:700;color:var(--text);margin-bottom:8px}
.bh-empty a{color:var(--blue);font-weight:600}

.bh-pagination{display:flex;justify-content:center;gap:8px;margin-top:40px;flex-wrap:wrap}
.bh-page-btn,.bh-page-num{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border-mid);border-radius:var(--radius-sm);font-size:.88rem;color:var(--text-muted);transition:var(--transition);background:var(--white)}
.bh-page-num.active,.bh-page-btn:hover,.bh-page-num:hover{background:var(--blue);color:var(--white);border-color:var(--blue)}

/* ══════════════════════════
   HOW IT WORKS
══════════════════════════ */
.bh-how{padding:72px 0;background:var(--white)}
.bh-section-header{text-align:center;margin-bottom:48px}
.bh-tag{display:inline-flex;align-items:center;gap:7px;background:var(--blue-pale);color:var(--blue);border-radius:50px;padding:5px 16px;font-size:.74rem;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:12px}
.bh-steps{display:flex;align-items:flex-start;justify-content:center;gap:12px;flex-wrap:wrap}
.bh-step{text-align:center;max-width:260px;flex:1;min-width:200px;position:relative}
.bh-step-icon{width:72px;height:72px;background:var(--blue-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.6rem;color:var(--blue);position:relative;transition:var(--transition)}
.bh-step:hover .bh-step-icon{background:var(--blue);color:var(--white)}
.bh-step-num{position:absolute;top:0;right:0;width:22px;height:22px;background:var(--blue);color:var(--white);border-radius:50%;font-size:.65rem;font-weight:900;display:flex;align-items:center;justify-content:center}
.bh-step h3{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:8px}
.bh-step p{font-size:.88rem;color:var(--text-muted);line-height:1.6}
.bh-step-arrow{font-size:1.2rem;color:var(--border-mid);align-self:center;flex-shrink:0;padding-top:16px}
@media(max-width:660px){.bh-step-arrow{display:none}}

/* ══════════════════════════
   CTA BANNER
══════════════════════════ */
.bh-wa-banner{padding:64px 0;background:linear-gradient(135deg,#051640 0%,var(--blue-navy) 45%,#1B3FAA 100%)}
.bh-wa-inner{display:flex;flex-wrap:wrap;align-items:center;gap:32px;justify-content:center;text-align:center}
.bh-wa-icon{font-size:4rem;color:#93B4F5}
.bh-wa-text{flex:1;min-width:260px}
.bh-wa-text h3{font-size:clamp(1.4rem,3vw,2rem);font-weight:800;color:var(--white);margin-bottom:8px}
.bh-wa-text p{color:rgba(255,255,255,.78);font-size:.96rem}
.bh-wa-btns{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}

/* ══════════════════════════
   FOOTER
══════════════════════════ */
.bh-footer{background:#051640;padding:64px 0 0}
.bh-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.bh-footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.bh-footer-logo i{font-size:1.6rem;color:#93B4F5}
.bh-footer-logo span{font-size:1.3rem;font-weight:800;color:var(--white)}
.bh-footer-brand p{font-size:.88rem;color:rgba(255,255,255,.6);line-height:1.75;margin-bottom:16px}
.bh-footer-wa{display:inline-flex;align-items:center;gap:8px;color:var(--wa-green);font-weight:600;font-size:.9rem}
.bh-footer-wa:hover{color:var(--white)}
.bh-footer-col h4{color:var(--white);font-size:.8rem;text-transform:uppercase;letter-spacing:2px;font-weight:700;margin-bottom:18px}
.bh-footer-col ul{display:flex;flex-direction:column;gap:9px}
.bh-footer-col a{font-size:.88rem;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:7px;transition:var(--transition)}
.bh-footer-col a:hover{color:#93B4F5;padding-left:4px}
.bh-footer-col i{font-size:.7rem}
.bh-footer-bottom{text-align:center;padding:20px;color:rgba(255,255,255,.4);font-size:.82rem}
.bh-footer-bottom a{color:#93B4F5}
@media(max-width:840px){.bh-footer-grid{grid-template-columns:1fr 1fr}.bh-footer-brand{grid-column:1/-1}}
@media(max-width:560px){.bh-footer-grid{grid-template-columns:1fr}}

.bh-wp-float{position:fixed;bottom:28px;right:28px;z-index:9999;width:56px;height:56px;background:var(--wa-green);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 4px 20px rgba(37,211,102,.5);transition:var(--transition)}
.bh-wp-float:hover{background:var(--wa-dark);color:var(--white);transform:scale(1.08)}

/* ══════════════════════════
   PROPERTY DETAIL
══════════════════════════ */
.bh-breadcrumb{background:var(--warm-bg);padding:12px 0;margin-top:66px;border-bottom:1px solid var(--border)}
.bh-breadcrumb .bh-container{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-muted);flex-wrap:wrap}
.bh-breadcrumb a{color:var(--blue)}
.bh-breadcrumb a:hover{text-decoration:underline}
.bh-breadcrumb i{font-size:.7rem;color:var(--text-light)}
.bh-detail-hero{background:var(--white);padding:32px 0 24px;border-bottom:1px solid var(--border)}
.bh-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap}
.bh-detail-location{font-size:.82rem;color:var(--text-muted);display:flex;align-items:center;gap:5px;margin-bottom:8px}
.bh-detail-location i{color:var(--blue)}
.bh-detail-title{font-size:clamp(1.6rem,4vw,2.6rem);font-weight:800;color:var(--text);margin-bottom:12px;letter-spacing:-.02em}
.bh-detail-meta{display:flex;gap:10px;flex-wrap:wrap}
.bh-detail-type-badge{background:var(--sale-pale);color:var(--sale-green);padding:5px 14px;border-radius:4px;font-size:.78rem;font-weight:700}
.bh-avail-badge{padding:5px 14px;border-radius:4px;font-size:.78rem;font-weight:700;display:flex;align-items:center;gap:5px}
.bh-avail-badge.available{background:#D1FAE5;color:#065F46}
.bh-avail-badge.unavailable{background:#FEE2E2;color:#991B1B}
.bh-detail-price-box{text-align:right;flex-shrink:0;min-width:160px}
.bh-detail-price{font-size:2.6rem;font-weight:800;color:var(--text);line-height:1}
.bh-detail-price-lbl{font-size:.84rem;color:var(--text-muted);margin-bottom:4px}
.bh-book-btn{width:100%;justify-content:center}
/* ── Gallery: hero + thumbs + lightbox ─── */
.p4y-gallery{padding:0 0 32px;background:var(--warm-bg)}
.p4y-hero-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:#111;cursor:pointer;margin-bottom:10px;user-select:none}
.p4y-hero-img{width:100%;height:520px;object-fit:cover;display:block;transition:opacity .2s}
.p4y-hero-img.p4y-fade{opacity:0}
.p4y-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.88);border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--text);cursor:pointer;box-shadow:var(--shadow);transition:var(--transition);z-index:3;opacity:0;font-size:.95rem}
.p4y-hero-wrap:hover .p4y-arrow{opacity:1}
.p4y-arrow:hover{background:var(--white);transform:translateY(-50%) scale(1.06)}
.p4y-arrow-l{left:16px}
.p4y-arrow-r{right:16px}
.p4y-counter{position:absolute;bottom:54px;right:16px;background:rgba(0,0,0,.55);color:#fff;font-size:.8rem;font-weight:600;padding:5px 12px;border-radius:20px;display:flex;align-items:center;gap:5px;backdrop-filter:blur(4px);z-index:3;pointer-events:none}
.p4y-all-btn{position:absolute;bottom:16px;right:16px;background:rgba(255,255,255,.90);border:none;border-radius:var(--radius-sm);padding:7px 14px;font-size:.82rem;font-weight:600;color:var(--text);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:var(--transition);z-index:3;backdrop-filter:blur(4px)}
.p4y-all-btn:hover{background:var(--white);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.p4y-all-btn i{color:var(--blue)}
.p4y-thumbs-bar{overflow:hidden}
.p4y-thumbs{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;scrollbar-width:thin;scrollbar-color:var(--border-mid) transparent}
.p4y-thumbs::-webkit-scrollbar{height:4px}
.p4y-thumbs::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:2px}
.p4y-tb{flex-shrink:0;width:96px;height:72px;border:2.5px solid transparent;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;background:none;padding:0;transition:var(--transition)}
.p4y-tb img{width:100%;height:100%;object-fit:cover;display:block}
.p4y-tb:hover{border-color:var(--blue-mid);transform:translateY(-2px)}
.p4y-tb.p4y-tb-active{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-pale)}
.p4y-lb{position:fixed;inset:0;background:rgba(0,0,0,.94);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}
.p4y-lb.p4y-lb-open{opacity:1;pointer-events:all}
.p4y-lb-close{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.12);border:none;border-radius:50%;width:46px;height:46px;color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:4}
.p4y-lb-close:hover{background:rgba(255,255,255,.22)}
.p4y-lb-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;border-radius:50%;width:52px;height:52px;color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:4}
.p4y-lb-arrow:hover{background:rgba(255,255,255,.22)}
.p4y-lb-l{left:20px}
.p4y-lb-r{right:20px}
.p4y-lb-stage{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 80px 0;width:100%;max-width:1200px}
.p4y-lb-img{max-width:100%;max-height:calc(100vh - 200px);object-fit:contain;border-radius:var(--radius);transition:opacity .18s}
.p4y-lb-img.p4y-fade{opacity:0}
.p4y-lb-caption{color:rgba(255,255,255,.65);font-size:.86rem;margin-top:10px;text-align:center}
.p4y-lb-thumbs{display:flex;gap:8px;padding:14px 20px;overflow-x:auto;max-width:100%}
.p4y-lb-tb{flex-shrink:0;width:72px;height:54px;border-radius:6px;overflow:hidden;border:2px solid transparent;cursor:pointer;background:none;padding:0;opacity:.55;transition:var(--transition)}
.p4y-lb-tb img{width:100%;height:100%;object-fit:cover;display:block}
.p4y-lb-tb:hover{opacity:1;border-color:rgba(255,255,255,.45)}
.p4y-lb-tb.p4y-lb-tb-active{opacity:1;border-color:#fff}
@media(max-width:640px){.p4y-hero-img{height:260px}.p4y-arrow{opacity:1;width:36px;height:36px}.p4y-lb-l{left:8px}.p4y-lb-r{right:8px}.p4y-lb-stage{padding:50px 56px 0}.p4y-all-btn span{display:none}}
.bh-detail-body{padding:48px 0 80px;background:var(--white)}
.bh-detail-layout{display:grid;grid-template-columns:1fr 300px;gap:40px}
.bh-key-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:32px}
.bh-fact{display:flex;align-items:center;gap:10px;padding:16px 18px;background:var(--white);transition:var(--transition)}
.bh-fact:hover{background:var(--blue-pale)}
.bh-fact i{font-size:1.3rem;color:var(--blue);flex-shrink:0}
.bh-fact strong{display:block;font-size:1.1rem;font-weight:700;color:var(--text)}
.bh-fact small{font-size:.74rem;color:var(--text-muted)}
.bh-detail-section{margin-bottom:36px}
.bh-detail-section h2{font-size:1.3rem;font-weight:700;margin-bottom:14px;color:var(--text)}
.bh-detail-section p{color:var(--text-muted);line-height:1.75;font-size:.95rem}
.bh-amenities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.bh-amenity-item{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--blue-pale);border-radius:var(--radius-sm);font-size:.88rem;color:var(--blue);font-weight:500}
.bh-map-wrap{border-radius:var(--radius);overflow:hidden}
.bh-map-label{margin-top:10px;font-size:.85rem;color:var(--text-muted);display:flex;align-items:center;gap:6px}
.bh-map-label i{color:var(--blue)}
.bh-booking-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:28px;position:sticky;top:86px;box-shadow:var(--shadow);height:fit-content}
.bh-b-amount{font-size:2.4rem;font-weight:800;color:var(--text)}
.bh-b-per{font-size:.88rem;color:var(--text-muted);margin-left:4px}
.bh-b-note{font-size:.82rem;color:var(--text-muted);margin-bottom:18px;display:flex;align-items:center;gap:6px}
.bh-b-owner{display:flex;align-items:center;gap:12px;padding:14px 0;border-top:1px solid var(--border);margin-top:14px}
.bh-b-avatar{width:44px;height:44px;background:var(--blue-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:1.2rem;flex-shrink:0}
.bh-b-name{font-weight:600;font-size:.92rem}
.bh-b-label{font-size:.76rem;color:var(--text-muted)}
.bh-b-checklist{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.bh-b-check{font-size:.82rem;color:var(--text-muted);display:flex;align-items:center;gap:8px}
.bh-b-check i{color:var(--sale-green)}
.bh-related{margin-top:60px;padding-top:40px;border-top:1px solid var(--border)}
.bh-related h2{font-size:1.5rem;font-weight:700;margin-bottom:24px}
.bh-related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}
@media(max-width:900px){.bh-detail-layout{grid-template-columns:1fr}.bh-booking-card{position:static}}
@media(max-width:640px){.bh-key-facts{grid-template-columns:repeat(2,1fr)}.bh-detail-price-box{width:100%;text-align:left}}

/* ══════════════════════════
   MANAGE / DASHBOARD
══════════════════════════ */
.bh-manage-body{background:#F3F4F6;min-height:100vh}
.bh-manage-layout{display:flex;min-height:100vh}
.bh-sidebar{width:260px;background:var(--blue-navy);position:fixed;top:0;left:0;height:100vh;display:flex;flex-direction:column;z-index:200;box-shadow:4px 0 24px rgba(0,0,0,.15);flex-shrink:0}
.bh-sidebar-logo{display:flex;align-items:center;justify-content:center;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}
.bh-sidebar-logo-img{height:52px;width:auto;object-fit:contain}
.bh-sidebar-nav{display:flex;flex-direction:column;padding:16px 12px;flex:1}
.bh-sidebar-nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);color:rgba(255,255,255,.72);font-size:.9rem;font-weight:500;transition:var(--transition);margin-bottom:2px}
.bh-sidebar-nav a:hover,.bh-sidebar-nav a.active{background:rgba(255,255,255,.10);color:var(--white)}
.bh-sidebar-nav a i{font-size:1rem;width:20px;text-align:center}
.bh-sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1)}
.bh-sidebar-user{font-size:.85rem;color:rgba(255,255,255,.72);display:flex;align-items:center;gap:8px;margin-bottom:6px}
.bh-sidebar-powered{font-size:.72rem;color:rgba(255,255,255,.4)}
.bh-sidebar-powered a{color:#93B4F5}
.bh-manage-main{margin-left:260px;flex:1;padding:32px;min-height:100vh}
.bh-manage-topbar{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:16px}
.bh-manage-title{font-size:1.8rem;font-weight:800;color:var(--text);letter-spacing:-.02em}
.bh-back-link{font-size:.82rem;color:var(--text-muted);display:inline-flex;align-items:center;gap:6px;margin-bottom:6px}
.bh-back-link:hover{color:var(--blue)}
.bh-alert{padding:14px 18px;border-radius:var(--radius-sm);margin-bottom:20px;display:flex;align-items:center;gap:10px;font-size:.9rem;font-weight:500}
.bh-alert-success{background:#D1FAE5;color:#065F46;border:1px solid #6EE7B7}
.bh-alert-error{background:#FEE2E2;color:#991B1B;border:1px solid #FECACA}
.bh-alert-info{background:var(--blue-pale);color:var(--blue-dark);border:1px solid #93B4F5}
.bh-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.bh-stat-card{background:var(--white);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.bh-stat-card-icon{width:52px;height:52px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.bh-stat-total .bh-stat-card-icon{background:var(--blue-pale);color:var(--blue)}
.bh-stat-avail .bh-stat-card-icon{background:#D1FAE5;color:#065F46}
.bh-stat-featured .bh-stat-card-icon{background:#FEF3C7;color:#B45309}
.bh-stat-billing .bh-stat-card-icon{background:var(--blue-pale);color:var(--blue-dark)}
.bh-stat-card-num{font-size:2rem;font-weight:800;color:var(--text);line-height:1}
.bh-stat-card-lbl{font-size:.78rem;color:var(--text-muted);margin-top:4px}
@media(max-width:900px){.bh-stats-row{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.bh-stats-row{grid-template-columns:1fr}}
.bh-manage-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:24px;border:1px solid var(--border)}
.bh-manage-card-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.bh-manage-card-header h2{font-size:1.1rem;font-weight:700;display:flex;align-items:center;gap:10px}
.bh-billing-note{font-size:.8rem;color:var(--text-muted)}
.bh-empty-dash{text-align:center;padding:50px;color:var(--text-muted)}
.bh-empty-dash i{font-size:3rem;margin-bottom:12px;display:block;color:var(--border-mid)}
.bh-empty-dash a{color:var(--blue);font-weight:600}
.bh-table-wrap{overflow-x:auto}
.bh-table{width:100%;border-collapse:collapse;font-size:.88rem}
.bh-table th{padding:12px 16px;text-align:left;font-size:.74rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600;border-bottom:1.5px solid var(--border);white-space:nowrap}
.bh-table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
.bh-table tr:last-child td{border-bottom:none}
.bh-table tr:hover td{background:var(--warm-bg)}
.bh-table-title{font-weight:700;color:var(--text);margin-bottom:2px}
.bh-table-imgs{color:var(--text-muted);font-size:.78rem}
.bh-type-chip{background:var(--blue-pale);color:var(--blue);font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:50px;white-space:nowrap}
.bh-toggle-btn{border:none;border-radius:50px;padding:5px 12px;font-size:.73rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:5px;transition:var(--transition)}
.bh-toggle-btn.available{background:#D1FAE5;color:#065F46}
.bh-toggle-btn.unavailable{background:#FEE2E2;color:#991B1B}
.bh-toggle-btn:hover{filter:brightness(.92)}
.bh-table-actions{display:flex;gap:6px;white-space:nowrap}
.bh-action-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:var(--transition)}
.bh-action-btn.view{background:var(--blue-pale);color:var(--blue)}
.bh-action-btn.edit{background:#DBEAFE;color:#1D4ED8}
.bh-action-btn.delete{background:#FEE2E2;color:#DC2626}
.bh-action-btn:hover{filter:brightness(.88);transform:scale(1.08)}
.bh-billing-notes{color:var(--text-muted);font-size:.84rem;max-width:200px}
@media(max-width:900px){.bh-sidebar{width:220px}.bh-manage-main{margin-left:220px;padding:20px}}
@media(max-width:680px){.bh-sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap}.bh-manage-main{margin-left:0}}

/* ══════════════════════════
   FORMS
══════════════════════════ */
.bh-form-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden}
.bh-form-section{padding:28px 32px;border-bottom:1px solid var(--border)}
.bh-form-section:last-child{border-bottom:none}
.bh-form-section-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:20px;display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:1.5px solid var(--blue-pale)}
.bh-form-section-title i{color:var(--blue)}
.bh-form-grid{display:grid;gap:16px}
.bh-form-grid-2{grid-template-columns:repeat(2,1fr)}
.bh-form-grid-3{grid-template-columns:repeat(3,1fr)}
.bh-col-full{grid-column:1/-1}
.bh-form-group{display:flex;flex-direction:column;gap:6px}
.bh-form-group label{font-size:.84rem;font-weight:600;color:var(--text)}
.bh-form-group small{font-size:.76rem;color:var(--text-muted)}
.req{color:#DC2626}
.bh-input{padding:11px 14px;border:1.5px solid var(--border-mid);border-radius:var(--radius-sm);font-size:.9rem;font-family:var(--font);color:var(--text);background:var(--white);transition:border-color .2s;width:100%}
.bh-input:focus{outline:none;border-color:var(--blue);background:var(--white)}
textarea.bh-input{resize:vertical}
.bh-ac-dropdown{position:absolute;top:100%;left:0;right:0;z-index:999;background:var(--white);border:1.5px solid var(--blue);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);box-shadow:0 8px 24px rgba(0,0,0,.12);max-height:260px;overflow-y:auto}
.bh-ac-item{padding:10px 14px;font-size:.88rem;color:var(--text);cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}
.bh-ac-item:last-child{border-bottom:none}
.bh-ac-item:hover{background:var(--blue-pale);color:var(--blue)}
.bh-form-hint{font-size:.83rem;color:var(--text-muted);margin-bottom:12px}
.bh-toggle-row{display:flex;flex-direction:column;gap:12px;padding-top:4px}
.bh-toggle-label{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--text);cursor:pointer}
.bh-toggle{width:42px;height:24px;background:var(--border-mid);border-radius:50px;position:relative;transition:background .25s;flex-shrink:0}
.bh-toggle::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;background:white;border-radius:50%;transition:left .25s}
.bh-toggle-label input{display:none}
.bh-toggle-label input:checked+.bh-toggle{background:var(--blue)}
.bh-toggle-label input:checked+.bh-toggle::after{left:21px}
.bh-amenity-checks{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}
.bh-check-label{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1.5px solid var(--border-mid);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);font-size:.88rem;color:var(--text);background:var(--white)}
.bh-check-label:hover{border-color:var(--blue);background:var(--blue-pale)}
.bh-check-label input{accent-color:var(--blue)}
.bh-check-label i{color:var(--blue);font-size:.95rem}
.bh-dropzone{border:2px dashed var(--border-mid);border-radius:var(--radius);padding:36px;text-align:center;cursor:pointer;transition:var(--transition);background:var(--warm-bg)}
.bh-dropzone:hover{border-color:var(--blue);background:var(--blue-pale)}
.bh-dropzone i{font-size:2.4rem;color:var(--blue);margin-bottom:10px;display:block}
.bh-dropzone p{font-size:.9rem;color:var(--text-muted)}
.bh-dropzone small{color:var(--text-light)}
.bh-link{color:var(--blue);font-weight:600;cursor:pointer}
.bh-preview-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.bh-preview-thumb{width:90px;height:68px;object-fit:cover;border-radius:var(--radius-sm);border:2px solid var(--border-mid)}
.bh-existing-imgs{display:flex;flex-wrap:wrap;gap:16px}
.bh-existing-img-item{position:relative}
.bh-existing-img-item img{width:100px;height:78px;object-fit:cover;border-radius:var(--radius-sm);border:2px solid var(--border-mid);display:block}
.bh-img-controls{margin-top:6px;display:flex;flex-direction:column;gap:4px;font-size:.74rem}
.bh-radio-label,.bh-delete-label{display:flex;align-items:center;gap:5px;cursor:pointer}
.bh-radio-label{color:var(--blue);font-weight:600}
.bh-delete-label{color:#DC2626}
.bh-form-actions{padding:24px 32px;display:flex;gap:12px;justify-content:flex-end;background:var(--warm-bg);border-top:1px solid var(--border)}
@media(max-width:720px){.bh-form-grid-2,.bh-form-grid-3{grid-template-columns:1fr}.bh-form-section{padding:20px}.bh-form-actions{padding:16px 20px}}

/* ── Modal ── */
.bh-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9998;align-items:center;justify-content:center}
.bh-modal-overlay.active{display:flex}
.bh-modal{background:var(--white);border-radius:var(--radius-lg);padding:40px;max-width:420px;width:90%;text-align:center;box-shadow:var(--shadow-lg)}
.bh-modal-icon{font-size:3rem;color:#F59E0B;margin-bottom:16px}
.bh-modal h3{font-size:1.3rem;font-weight:700;color:var(--text);margin-bottom:10px}
.bh-modal p{color:var(--text-muted);font-size:.92rem;margin-bottom:24px}
.bh-modal-actions{display:flex;gap:12px;justify-content:center}

/* ── Save button ── */
.bh-save-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:none;border:2px solid var(--border-mid);color:var(--text-muted);border-radius:6px;padding:6px 14px;font-size:.88rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap}
.bh-save-btn:hover{border-color:#EF4444;color:#EF4444}
.bh-save-btn.saved{border-color:#EF4444;color:#EF4444;background:#FEF2F2}
.bh-save-detail-btn{width:100%;justify-content:center;margin-top:12px;padding:10px 20px;font-size:.95rem}
.bh-save-detail-btn.saved{background:#FEF2F2}
.bh-save-cta-link{display:block;text-align:center;margin-top:12px;color:var(--text-muted);font-size:.88rem}
.bh-save-cta-link:hover{color:var(--blue)}

/* ── Auth ── */
.bh-auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#051640 0%,var(--blue-navy) 45%,#1a3daa 100%);padding:calc(66px + 32px) 20px 40px}
.bh-auth-card{background:var(--white);border-radius:var(--radius-lg);padding:44px 40px;width:100%;max-width:440px;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.bh-auth-card-wide{max-width:580px}
.bh-auth-header{text-align:center;margin-bottom:28px}
.bh-auth-icon{width:60px;height:60px;background:var(--blue-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--blue);margin:0 auto 16px}
.bh-auth-header h1{font-size:1.65rem;font-weight:800;color:var(--text);margin-bottom:6px;letter-spacing:-.02em}
.bh-auth-header p{font-size:.9rem;color:var(--text-muted);line-height:1.55}
.bh-auth-logo{display:flex;justify-content:center;margin-bottom:28px}
.bh-auth-logo img{height:50px;width:auto}
.bh-auth-title{font-size:1.55rem;font-weight:800;color:var(--text);margin-bottom:6px;text-align:center}
.bh-auth-sub{font-size:.88rem;color:var(--text-muted);text-align:center;margin-bottom:28px;line-height:1.55}
.bh-auth-form{display:flex;flex-direction:column;gap:18px}
.bh-auth-form .bh-form-group{display:flex;flex-direction:column;gap:6px}
.bh-auth-form .bh-form-group label{font-size:.84rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:7px}
.bh-auth-form .bh-form-group label i{color:var(--blue);font-size:.82rem}
.bh-auth-form input{padding:11px 14px;border:1.5px solid var(--border-mid);border-radius:var(--radius-sm);font-size:.95rem;font-family:var(--font);color:var(--text);background:var(--white);transition:border-color .2s;width:100%}
.bh-auth-form input:focus{outline:none;border-color:var(--blue);background:var(--white)}
.bh-auth-form input::placeholder{color:var(--text-light)}
.bh-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.bh-form-row{grid-template-columns:1fr}}
.bh-auth-submit{width:100%;padding:13px;background:var(--blue);color:var(--white);border:none;border-radius:6px;font-size:1rem;font-weight:700;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font)}
.bh-auth-submit:hover{background:var(--blue-dark)}
.bh-auth-divider{text-align:center;font-size:.84rem;color:var(--text-muted);margin:4px 0}
.bh-auth-link{color:var(--blue);font-weight:600}
.bh-auth-link:hover{text-decoration:underline}
.bh-auth-footer{margin-top:24px;text-align:center;font-size:.86rem;color:var(--text-muted);line-height:2;border-top:1px solid var(--border);padding-top:20px}
.bh-auth-footer a{color:var(--blue);font-weight:600}
.bh-auth-footer a:hover{text-decoration:underline}
.bh-nav-solid{background:var(--white)}

/* ── User dashboard ── */
.bh-user-dash-hero{background:linear-gradient(135deg,#051640 0%,var(--blue-navy) 100%);padding:80px 0 40px;color:var(--white)}
.bh-user-dash-header{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.bh-user-avatar-lg{font-size:4rem;color:rgba(255,255,255,.8);flex-shrink:0}
.bh-user-dash-info{flex:1}
.bh-user-dash-info h1{font-size:1.9rem;font-weight:800;color:var(--white);margin-bottom:6px;letter-spacing:-.02em}
.bh-user-dash-email{color:rgba(255,255,255,.82);font-size:.95rem;margin:0}
.bh-user-dash-since{color:rgba(255,255,255,.65);font-size:.88rem;margin:4px 0 0}
.bh-user-logout-btn{margin-left:auto;flex-shrink:0}
.bh-user-dash-body{padding:48px 0 80px;background:var(--warm-bg)}
.bh-user-dash-section{margin-bottom:48px}
.bh-user-dash-section-hd{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.bh-user-dash-section-hd h2{font-size:1.5rem;font-weight:700;color:var(--text)}
.bh-user-dash-empty{text-align:center;padding:60px 24px;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:var(--text-muted)}
.bh-user-dash-empty i{font-size:3.5rem;margin-bottom:16px;display:block;color:var(--blue-pale)}
.bh-user-dash-empty h3{font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:10px}

/* ── Analytics ── */
.bh-analytics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px}
.bh-kpi-card,.bh-chart-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}
.bh-chart-card{padding:24px;margin-bottom:24px}
.bh-kpi-label{font-size:.76rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600;margin-bottom:8px}
.bh-kpi-value{font-size:2.2rem;font-weight:800;color:var(--text);line-height:1}
.bh-kpi-sub{font-size:.8rem;color:var(--text-muted);margin-top:6px}
.bh-chart-card h3{font-size:1rem;font-weight:700;margin-bottom:20px;color:var(--text)}
.bh-monthly-table{width:100%;border-collapse:collapse;font-size:.88rem}
.bh-monthly-table th{padding:10px 14px;text-align:left;font-size:.76rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600;border-bottom:1.5px solid var(--border)}
.bh-monthly-table td{padding:12px 14px;border-bottom:1px solid var(--border)}
.bh-monthly-table tr:hover td{background:var(--warm-bg)}
.bh-current-badge{background:var(--blue-pale);color:var(--blue);font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:50px}

/* ── Archived ── */
.bh-archived-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.bh-archived-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.bh-archived-img{width:100%;height:180px;object-fit:cover;display:block}
.bh-archived-placeholder{width:100%;height:180px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--blue)}
.bh-archived-body{padding:16px}
.bh-archived-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.bh-chip{display:inline-flex;align-items:center;gap:5px;background:var(--warm-bg);color:var(--text-muted);font-size:.74rem;font-weight:600;padding:3px 10px;border-radius:50px}
.bh-chip-purple{background:var(--blue-pale);color:var(--blue)}
.bh-archived-title{font-weight:700;color:var(--text);margin-bottom:4px}
.bh-archived-loc{font-size:.82rem;color:var(--text-muted);margin-bottom:10px;display:flex;align-items:center;gap:5px}

/* ============================================================
   BUYER RESOURCE CENTRE — homepage strip
   ============================================================ */
.p4y-resources-strip{padding:80px 0;background:#f8faff}
.p4y-doc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.p4y-doc-card{display:flex;flex-direction:column;background:var(--white);border-radius:var(--radius);border:1.5px solid var(--border);padding:24px;text-decoration:none;color:inherit;transition:var(--transition);gap:14px}
.p4y-doc-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.1);text-decoration:none;color:inherit}
.p4y-doc-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.p4y-doc-body{flex:1}
.p4y-doc-cat{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:50px;margin-bottom:7px}
.p4y-doc-body h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.3}
.p4y-doc-body p{font-size:.84rem;color:var(--text-muted);line-height:1.6;margin:0}
.p4y-doc-dl{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:7px 14px;border-radius:50px;width:fit-content;transition:var(--transition)}
/* colour variants */
.p4y-doc-blue .p4y-doc-icon{background:#e8f0fe;color:#2563eb}
.p4y-doc-blue .p4y-doc-cat{background:#e8f0fe;color:#2563eb}
.p4y-doc-blue .p4y-doc-dl{background:#2563eb;color:#fff}
.p4y-doc-blue:hover .p4y-doc-dl{background:#1d4ed8}
.p4y-doc-green .p4y-doc-icon{background:#dcfce7;color:#16a34a}
.p4y-doc-green .p4y-doc-cat{background:#dcfce7;color:#16a34a}
.p4y-doc-green .p4y-doc-dl{background:#16a34a;color:#fff}
.p4y-doc-green:hover .p4y-doc-dl{background:#15803d}
.p4y-doc-purple .p4y-doc-icon{background:#f3e8ff;color:#7c3aed}
.p4y-doc-purple .p4y-doc-cat{background:#f3e8ff;color:#7c3aed}
.p4y-doc-purple .p4y-doc-dl{background:#7c3aed;color:#fff}
.p4y-doc-purple:hover .p4y-doc-dl{background:#6d28d9}
.p4y-doc-orange .p4y-doc-icon{background:#fff7ed;color:#ea580c}
.p4y-doc-orange .p4y-doc-cat{background:#fff7ed;color:#ea580c}
.p4y-doc-orange .p4y-doc-dl{background:#ea580c;color:#fff}
.p4y-doc-orange:hover .p4y-doc-dl{background:#c2410c}
.p4y-doc-teal .p4y-doc-icon{background:#ccfbf1;color:#0d9488}
.p4y-doc-teal .p4y-doc-cat{background:#ccfbf1;color:#0d9488}
.p4y-doc-teal .p4y-doc-dl{background:#0d9488;color:#fff}
.p4y-doc-teal:hover .p4y-doc-dl{background:#0f766e}
.p4y-doc-red .p4y-doc-icon{background:#fee2e2;color:#dc2626}
.p4y-doc-red .p4y-doc-cat{background:#fee2e2;color:#dc2626}
.p4y-doc-red .p4y-doc-dl{background:#dc2626;color:#fff}
.p4y-doc-red:hover .p4y-doc-dl{background:#b91c1c}
@media(max-width:900px){.p4y-doc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.p4y-doc-grid{grid-template-columns:1fr}}

/* ============================================================
   RESOURCES HUB PAGE — resources.html
   ============================================================ */
.p4y-res-hero{background:linear-gradient(135deg,var(--blue) 0%,#1e40af 100%);color:#fff;padding:72px 0 64px;text-align:center}
.p4y-res-hero h1{font-size:2.2rem;font-weight:800;margin-bottom:12px}
.p4y-res-hero p{font-size:1.05rem;opacity:.85;max-width:560px;margin:0 auto}
.p4y-res-grid{padding:60px 0 80px}
.p4y-res-grid .p4y-doc-grid{margin-top:0}
.p4y-res-back{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.8);font-size:.9rem;text-decoration:none;margin-bottom:24px;transition:var(--transition)}
.p4y-res-back:hover{color:#fff;text-decoration:none}

/* ============================================================
   PRINTABLE DOCUMENT PAGES — shared
   ============================================================ */
.p4y-print-wrap{max-width:780px;margin:0 auto;padding:48px 40px;font-family:'Inter',sans-serif;color:#1a1a2e;font-size:14px;line-height:1.7}
.p4y-print-header{display:flex;align-items:flex-start;justify-content:space-between;border-bottom:3px solid #2563eb;padding-bottom:20px;margin-bottom:32px}
.p4y-print-logo-text{font-size:1.5rem;font-weight:800;color:#2563eb;letter-spacing:-.03em}
.p4y-print-logo-text span{color:#1e40af}
.p4y-print-meta{text-align:right;font-size:.78rem;color:#6b7280}
.p4y-print-title{font-size:1.6rem;font-weight:800;margin-bottom:6px;color:#1a1a2e}
.p4y-print-sub{font-size:.9rem;color:#6b7280;margin-bottom:32px}
.p4y-print-section{margin-bottom:28px}
.p4y-print-section h2{font-size:1.1rem;font-weight:700;color:#1e40af;border-bottom:1px solid #e5e7eb;padding-bottom:6px;margin-bottom:14px}
.p4y-print-section h3{font-size:.95rem;font-weight:700;margin-bottom:6px;color:#1a1a2e}
.p4y-print-section p,.p4y-print-section li{font-size:.88rem;color:#374151;margin-bottom:4px}
.p4y-print-section ul,.p4y-print-section ol{padding-left:20px;margin-bottom:8px}
.p4y-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.p4y-field{display:flex;flex-direction:column;gap:3px}
.p4y-field label{font-size:.75rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}
.p4y-field-line{height:32px;border-bottom:1.5px solid #d1d5db;background:transparent}
.p4y-check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.p4y-check-item{display:flex;align-items:flex-start;gap:8px;font-size:.84rem;color:#374151;padding:5px 0}
.p4y-check-box{width:16px;height:16px;border:1.5px solid #9ca3af;border-radius:3px;flex-shrink:0;margin-top:2px}
.p4y-rating-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:.84rem}
.p4y-stars{display:flex;gap:3px}
.p4y-star{width:18px;height:18px;border:1.5px solid #d1d5db;border-radius:3px}
.p4y-note-box{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:14px 16px;font-size:.84rem;color:#6b7280;margin-top:8px}
.p4y-print-footer{margin-top:48px;padding-top:16px;border-top:1px solid #e5e7eb;font-size:.75rem;color:#9ca3af;display:flex;justify-content:space-between}
.p4y-duty-table{width:100%;border-collapse:collapse;font-size:.84rem;margin-bottom:14px}
.p4y-duty-table th{background:#eff6ff;color:#1e40af;font-weight:700;padding:8px 12px;text-align:left;border:1px solid #dbeafe}
.p4y-duty-table td{padding:8px 12px;border:1px solid #e5e7eb}
.p4y-duty-table tr:nth-child(even) td{background:#f9fafb}
.p4y-compare-table{width:100%;border-collapse:collapse;font-size:.84rem;margin-bottom:14px}
.p4y-compare-table th{padding:10px 14px;text-align:left;border:1px solid #e5e7eb;font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}
.p4y-compare-table td{padding:9px 14px;border:1px solid #e5e7eb;vertical-align:top}
.p4y-compare-table tr:nth-child(even) td{background:#f9fafb}
.p4y-th-blue{background:#eff6ff;color:#1e40af}
.p4y-th-green{background:#f0fdf4;color:#15803d}
.p4y-print-actions{display:flex;gap:12px;margin-bottom:36px}
.p4y-print-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:8px;font-size:.88rem;font-weight:700;cursor:pointer;border:none;text-decoration:none;transition:var(--transition)}
.p4y-print-btn-primary{background:#2563eb;color:#fff}
.p4y-print-btn-primary:hover{background:#1d4ed8;color:#fff;text-decoration:none}
.p4y-print-btn-outline{background:transparent;color:#374151;border:1.5px solid #d1d5db}
.p4y-print-btn-outline:hover{border-color:#9ca3af;color:#1a1a2e;text-decoration:none}
@media print{
  .p4y-print-actions,.bh-nav,.bh-footer,.p4y-res-hero{display:none!important}
  .p4y-print-wrap{padding:20px;max-width:100%}
  body{font-size:12px}
  .p4y-print-header{border-bottom:2px solid #2563eb}
}
.bh-price-badge{display:inline-block;background:var(--blue-pale);color:var(--blue);font-size:.9rem;font-weight:800;padding:5px 12px;border-radius:6px;margin-bottom:14px}
.bh-archived-actions{display:flex;gap:8px}
.bh-republish-wrap{max-width:600px;margin:0 auto;padding:40px 0 80px}
.bh-republish-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow)}

/* Hide legacy slot styles */
.bh-card-slot-chip,.bh-slot-units-chip,.bh-slots-preview,.bh-slots-card,.bh-slot-item,.bh-slot-badge{display:none!important}
/* ── User Dashboard: Saved Properties Grid ── */
.bh-saved-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding:20px 24px}
.bh-saved-card{background:var(--warm-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.bh-saved-thumb{display:block;height:180px;overflow:hidden}
.bh-saved-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.bh-saved-thumb:hover img{transform:scale(1.03)}
.bh-saved-no-img{height:180px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--blue)}
.bh-saved-info{padding:16px}
.bh-saved-title{font-weight:700;font-size:1rem;margin-bottom:6px}
.bh-saved-title a{color:var(--text);text-decoration:none}
.bh-saved-title a:hover{color:var(--blue)}
.bh-saved-loc{font-size:.82rem;color:var(--text-muted);margin-bottom:6px;display:flex;align-items:center;gap:5px}
.bh-saved-price{font-size:1.1rem;font-weight:800;color:var(--blue);margin-bottom:4px}
.bh-saved-meta{font-size:.8rem;color:var(--text-muted);margin-bottom:8px}

/* ── Status badge (inline in table) ── */
.bh-status-badge{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;font-weight:700;padding:4px 10px;border-radius:50px}
.bh-status-badge.available{background:#d1fae5;color:#065f46}
.bh-status-badge.inactive{background:#fee2e2;color:#991b1b}

/* ── Small button variant ── */
.bh-btn-sm{padding:6px 14px;font-size:.82rem}

/* ── Amenity toggle grid (user add listing form) ── */
.bh-amenity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:10px;padding:4px 0}

/* ── Existing photos row (edit form) ── */
.bh-existing-photos{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.bh-photo-thumb{position:relative;width:110px;height:80px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--border)}
.bh-photo-thumb img{width:100%;height:100%;object-fit:cover}
.bh-photo-primary{position:absolute;bottom:0;left:0;right:0;background:rgba(27,84,204,.82);color:#fff;font-size:.65rem;font-weight:700;text-align:center;padding:2px}

/* ── File input ── */
.bh-input-file{padding:8px;cursor:pointer}
.bh-input-file::file-selector-button{background:var(--blue);color:#fff;border:none;padding:6px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:.82rem;margin-right:10px}