/* ================================================================
   BPR NEW DESIGN - Tribaldos Inspired
   Premium Real Estate Theme v2.0
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800;900&display=swap');

/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
section[id]{scroll-margin-top:80px}
.bpr-new-body{font-family:'Montserrat',system-ui,-apple-system,sans-serif;color:#2d3436;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;background:#fff}
.bpr-new-body img{max-width:100%;height:auto}
.bpr-new-body a{text-decoration:none;color:inherit}
.bn-container{max-width:1280px;margin:0 auto;padding:0 24px}

/* === HEADER === */
.bn-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(26,39,68,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(178,52,57,.15);transition:all .3s}
.bn-header.scrolled{background:rgba(26,39,68,.98);box-shadow:0 4px 30px rgba(0,0,0,.3)}
.bn-header-inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:72px}
.bn-logo{display:flex;align-items:center;gap:12px;z-index:1002}
.bn-logo-img{height:48px;width:auto;object-fit:contain}
.bn-footer-logo-img{height:80px;width:auto;object-fit:contain}
.bn-logo-text{display:flex;flex-direction:column}
.bn-logo-name{font-size:16px;font-weight:800;color:#fff;letter-spacing:2px;line-height:1.2}
.bn-logo-sub{font-size:10px;font-weight:500;color:rgba(255,255,255,.6);letter-spacing:6px;line-height:1.2}

/* Desktop nav */
.bn-nav-desktop{display:flex;gap:8px;align-items:center}
.bpr-new-body .bn-nav-link{padding:8px 18px;font-size:13px;font-weight:600;color:rgba(255,255,255,.55) !important;letter-spacing:.5px;border-radius:6px;transition:all .2s;position:relative}
.bpr-new-body .bn-nav-link:hover{color:#fff !important;background:rgba(255,255,255,.1)}
.bpr-new-body .bn-nav-link.active{color:#fff !important}
.bn-nav-link.active::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:20px;height:2px;background:#b23439;border-radius:1px}
/* Admin login - discrete */
.bn-admin-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;color:rgba(255,255,255,.25) !important;transition:all .2s;margin-left:4px;flex-shrink:0}
.bn-admin-link:hover{color:rgba(255,255,255,.6) !important;background:rgba(255,255,255,.08)}

/* Hamburger - animated to X */
.bn-hamburger{display:none;position:relative;z-index:1002;width:32px;height:24px;cursor:pointer;background:transparent;border:none;padding:0}
.bn-hamburger span{display:block;width:100%;height:2.5px;background:#fff;border-radius:2px;transition:all .3s cubic-bezier(.68,-.55,.27,1.55);position:absolute;left:0}
.bn-hamburger span:nth-child(1){top:0}
.bn-hamburger span:nth-child(2){top:10px}
.bn-hamburger span:nth-child(3){top:20px}
.bn-hamburger.active span:nth-child(1){top:10px;transform:rotate(45deg);background:#b23439}
.bn-hamburger.active span:nth-child(2){opacity:0;transform:translateX(-20px)}
.bn-hamburger.active span:nth-child(3){top:10px;transform:rotate(-45deg);background:#b23439}

/* Full-screen mobile overlay */
.bn-mobile-overlay{position:fixed;top:0;left:0;width:100%;height:100vh;height:100dvh;background:rgba(26,39,68,.97);z-index:1001;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease}
.bn-mobile-overlay.active{opacity:1;visibility:visible}
.bn-mobile-overlay a{color:#fff;font-size:1.6rem;font-weight:300;letter-spacing:2px;padding:12px 24px;opacity:0;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease,color .2s ease}
.bn-mobile-overlay.active a{opacity:1;transform:translateY(0)}
.bn-mobile-overlay.active a:nth-child(1){transition-delay:.1s}
.bn-mobile-overlay.active a:nth-child(2){transition-delay:.15s}
.bn-mobile-overlay.active a:nth-child(3){transition-delay:.2s}
.bn-mobile-overlay.active a:nth-child(4){transition-delay:.25s}
.bn-mobile-overlay.active a:nth-child(5){transition-delay:.3s}
.bn-mobile-overlay a:hover,.bn-mobile-overlay a:focus{color:#b23439}
.bn-mobile-overlay-cta{margin-top:40px;display:flex;flex-direction:column;gap:12px;align-items:center;opacity:0;transform:translateY(20px);transition:opacity .3s ease .35s,transform .3s ease .35s}
.bn-mobile-overlay.active .bn-mobile-overlay-cta{opacity:1;transform:translateY(0)}

/* === HERO === */
.bn-hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:#1a2744;overflow:hidden}
.bn-hero::before{content:'';position:absolute;inset:0;background:
    radial-gradient(ellipse 80% 50% at 50% 100%, rgba(178,52,57,.08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 20% 80%, rgba(37,99,235,.06) 0%, transparent 50%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(37,99,235,.06) 0%, transparent 50%),
    linear-gradient(180deg, #0f1a2e 0%, #1a2744 30%, #2d4a6e 70%, #4c6c93 100%)}
.bn-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:200px;background:linear-gradient(0deg,rgba(178,52,57,.04) 0%,transparent 100%)}
.bn-hero-overlay{display:none}
.bn-hero-content{position:relative;z-index:2;text-align:center;padding:120px 24px 80px;max-width:800px}
.bn-hero-badge{display:inline-block;padding:6px 20px;background:#b23439;border:1px solid #b23439;border-radius:50px;font-size:12px;font-weight:700;color:#fff !important;letter-spacing:2px;text-transform:uppercase;margin-bottom:24px}
.bn-hero-title{font-size:48px;font-weight:900;color:#fff;letter-spacing:1px;line-height:1.15;margin-bottom:16px;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.bn-hero-sub{font-size:16px;font-weight:400;color:rgba(255,255,255,.5);margin-bottom:40px;max-width:520px;margin-left:auto;margin-right:auto;line-height:1.7}
.bn-hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.3);animation:bnBounce 2s infinite}
@keyframes bnBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* Search Box */
.bn-search-box{max-width:640px;margin:0 auto 28px}
.bn-search-inner{display:flex;align-items:center;background:#fff;border-radius:60px;padding:6px;box-shadow:0 12px 48px rgba(0,0,0,.25),0 0 0 1px rgba(178,52,57,.2)}
.bn-search-icon{display:flex;align-items:center;justify-content:center;padding:0 4px 0 16px;color:#9ca3af;flex-shrink:0}
.bn-search-inner input{flex:1;border:none;outline:none;padding:12px 12px;font-size:15px;font-family:inherit;font-weight:500;color:#1f2937;background:transparent;min-width:0}
.bn-search-inner input::placeholder{color:#9ca3af}
#bn-search-btn{display:flex;align-items:center;gap:8px;padding:12px 28px;background:linear-gradient(135deg,#b23439,#8e2a2e);color:#fff !important;border:none;border-radius:50px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}
#bn-search-btn:hover{background:linear-gradient(135deg,#c94448,#b23439);transform:translateY(-1px);box-shadow:0 4px 16px rgba(178,52,57,.4)}
#bn-search-btn svg{display:none}
#bn-search-btn span{display:inline}

/* Hero Pills */
.bn-hero-pills{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.bn-hero-pill{padding:8px 24px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:50px;color:rgba(255,255,255,.6);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}
.bn-hero-pill:hover{background:rgba(255,255,255,.12);color:#fff}
.bn-hero-pill.active{background:#b23439;border-color:#b23439;color:#fff}

/* === FLOATING SEARCH BUTTON === */
.bn-float-search{position:fixed;bottom:100px;right:28px;width:56px;height:56px;border-radius:50%;background:#1a2744;color:#fff;border:2px solid rgba(178,52,57,.4);cursor:pointer;z-index:998;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(26,39,68,.4);opacity:0;transform:scale(.8);transition:opacity .3s ease,transform .3s ease,background .2s ease;pointer-events:none}
.bn-float-search.visible{opacity:1;transform:scale(1);pointer-events:auto}
.bn-float-search:hover{background:#2d4a6e;transform:scale(1.08);box-shadow:0 6px 24px rgba(26,39,68,.5)}
.bn-float-search svg{width:24px;height:24px}

/* === STATS === */
.bn-stats{background:#1a2744;border-bottom:1px solid rgba(178,52,57,.1)}
.bn-stats-inner{max-width:1280px;margin:0 auto;padding:32px 24px;display:flex;justify-content:center;gap:60px}
.bn-stat{text-align:center}
.bn-stat-num{font-size:32px;font-weight:900;color:#b23439;letter-spacing:-1px}
.bn-stat-label{font-size:12px;font-weight:600;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:2px;margin-top:4px}

/* === SECTION REVEAL ANIMATIONS === */
.bn-reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.bn-reveal.visible{opacity:1;transform:translateY(0)}

/* === SECTIONS === */
.bn-section-header{text-align:center;margin-bottom:48px}
.bn-section-tag{display:inline-block;padding:6px 18px;background:#b23439;border-radius:50px;font-size:11px;font-weight:800;color:#fff !important;letter-spacing:3px;text-transform:uppercase;margin-bottom:14px}
.bn-section-title{font-size:32px;font-weight:900;color:#1a2744;letter-spacing:2px;margin-bottom:10px}
.bn-section-sub{font-size:15px;color:#6b7280;font-weight:400;max-width:480px;margin:0 auto}

/* === CATEGORIES === */
.bn-categories{padding:80px 0;background:#f8f9fc}
.bn-cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.bn-cat-card{background:#fff;border-radius:20px;padding:40px 32px;text-align:center;cursor:pointer;transition:all .3s;border:1px solid #eef0f6;position:relative;overflow:hidden}
.bn-cat-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#b23439,#c94448);transform:scaleX(0);transition:transform .3s;transform-origin:left}
.bn-cat-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(26,39,68,.08)}
.bn-cat-card:hover::before{transform:scaleX(1)}
.bn-cat-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,rgba(26,39,68,.04),rgba(178,52,57,.08));border-radius:20px;margin:0 auto 20px;color:#1a2744;transition:all .3s}
.bn-cat-card:hover .bn-cat-icon{background:linear-gradient(135deg,#1a2744,#2d4a6e);color:#b23439}
.bn-cat-name{font-size:18px;font-weight:800;color:#1a2744;margin-bottom:6px}
.bn-cat-count{font-size:14px;color:#6b7280;font-weight:500;margin-bottom:12px}
.bn-cat-arrow{font-size:20px;color:#b23439;opacity:0;transition:all .3s;display:inline-block}
.bn-cat-card:hover .bn-cat-arrow{opacity:1;transform:translateX(4px)}

/* === FEATURED === */
.bn-featured{padding:80px 0;background:#fff}
.bn-feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.bn-feat-cta{text-align:center;margin-top:48px}

/* Property Card */
.bn-prop-card{background:#fff;border-radius:20px;overflow:hidden;border:1px solid #eef0f6;cursor:pointer;transition:all .3s}
.bn-prop-card:hover{transform:translateY(-5px);box-shadow:0 16px 48px rgba(26,39,68,.1)}
.bn-prop-img{position:relative;height:220px;overflow:hidden;background:#f0f2f8}
.bn-prop-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.bn-prop-card:hover .bn-prop-img img{transform:scale(1.05)}
.bn-prop-badges{position:absolute;top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap;z-index:2}
.bn-badge{padding:5px 10px;border-radius:6px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}
.bn-badge-sale{background:#006838;color:#fff}
.bn-badge-rent{background:#2563eb;color:#fff}
.bn-prop-id{position:absolute;top:12px;right:12px;background:rgba(0,0,0,.6);color:#fff;padding:4px 10px;border-radius:6px;font-size:10px;font-weight:800;backdrop-filter:blur(4px);z-index:2}
.bn-no-img{display:flex;align-items:center;justify-content:center;height:100%;background:#f0f2f8;color:#7c8db0}
.bn-no-img-logo{width:auto;height:60%;max-height:140px;object-fit:contain;opacity:.4}
.bn-prop-body{padding:18px 20px 20px}
.bn-prop-price{font-size:22px;font-weight:900;color:#1a2744;letter-spacing:-.3px;margin-bottom:4px}
.bn-pm{font-size:13px;font-weight:500;color:#6b7280}
.bn-pa{font-size:15px;font-weight:600;color:#9ca3af}
.bn-prop-meta{display:flex;flex-wrap:wrap;gap:4px 0;font-size:13px;color:#4b5563;font-weight:500;margin-bottom:8px}
.bn-prop-meta span{display:inline-flex;align-items:center;gap:2px}
.bn-prop-meta span:not(:last-child)::after{content:'\00B7';margin:0 8px;color:#d1d5db}
.bn-prop-meta strong{font-weight:800;color:#1a2744}
.bn-prop-title{font-size:14px;font-weight:600;color:#4b5563;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px}
.bn-prop-loc{display:flex;align-items:center;gap:5px;font-size:12px;color:#9ca3af;font-weight:500}
.bn-prop-loc svg{color:#b23439;flex-shrink:0}

/* === BUTTONS === */
.bn-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 36px;border-radius:50px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s;border:none}
.bn-btn-gold{background:linear-gradient(135deg,#b23439,#8e2a2e);color:#fff !important}
.bn-btn-gold:hover{background:linear-gradient(135deg,#c94448,#b23439);transform:translateY(-2px);box-shadow:0 8px 24px rgba(178,52,57,.3);color:#fff !important}
.bn-btn-outline{background:transparent;color:#1a2744 !important;border:2px solid #1a2744}
.bn-btn-outline:hover{background:#1a2744;color:#fff !important}
.bn-btn-wa{background:#25D366;color:#fff}
.bn-btn-wa:hover{background:#20bd5a;transform:translateY(-2px)}

/* === SEARCH SECTION === */
.bn-search-section{padding:80px 0;background:#f8f9fc}
.bn-filters-bar{background:#fff;border-radius:20px;padding:28px;margin-bottom:24px;box-shadow:0 2px 12px rgba(0,0,0,.04);border:1px solid #eef0f6}
.bn-filters-row{display:flex;gap:20px;align-items:flex-end;margin-bottom:16px;flex-wrap:wrap}
.bn-filters-row:last-child{margin-bottom:0}
.bn-filter-group{flex:1;min-width:180px}
.bn-filter-wide{flex:2}
.bn-filter-group label{display:block;font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.bn-filter-group input[type="text"],
.bn-filter-group select{width:100%;padding:10px 14px;border:1.5px solid #eef0f6;border-radius:10px;font-size:14px;font-family:inherit;font-weight:500;color:#2d3436;background:#fff;outline:none;transition:border-color .2s;-webkit-appearance:none;appearance:none}
.bn-filter-group select{padding-right:36px;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='3'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center}
.bn-filter-group input:focus,
.bn-filter-group select:focus{border-color:#b23439;box-shadow:0 0 0 3px rgba(178,52,57,.1)}
.bn-filter-actions{display:flex;gap:10px;align-items:flex-end}

/* Pills */
.bn-pill-group{display:flex;gap:6px;flex-wrap:wrap}
.bn-pill,.bn-pill-sm{padding:9px 18px;border:1.5px solid #eef0f6;border-radius:50px;background:#fff;font-size:13px;font-weight:600;font-family:inherit;color:#4b5563;cursor:pointer;transition:all .15s}
.bn-pill-sm{padding:8px 14px;min-width:44px;text-align:center}
.bn-pill:hover,.bn-pill-sm:hover{border-color:#b23439;color:#b23439}
.bn-pill.active,.bn-pill-sm.active{background:#1a2744;color:#fff;border-color:#1a2744}

/* Price */
.bn-price-row{display:flex;align-items:center;gap:10px}
.bn-price-field{flex:1;display:flex;align-items:center;border:1.5px solid #eef0f6;border-radius:10px;padding:0 14px;background:#fff;transition:border-color .2s}
.bn-price-field:focus-within{border-color:#b23439;box-shadow:0 0 0 3px rgba(178,52,57,.1)}
.bn-price-field span{color:#9ca3af;font-weight:700;font-size:14px;margin-right:4px}
.bn-price-field input{border:none;outline:none;padding:10px 0;font-size:14px;font-family:inherit;font-weight:500;width:100%;background:transparent}
.bn-price-sep{color:#9ca3af;font-weight:700}

/* Location Dropdown */
.bn-loc-dropdown{position:relative}
.bn-loc-trigger{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border:1.5px solid #eef0f6;border-radius:10px;background:#fff;cursor:pointer;font-size:14px;font-weight:500;color:#2d3436;transition:all .2s}
.bn-loc-trigger:hover{border-color:#b23439}
.bn-loc-trigger.open{border-color:#b23439;border-radius:10px 10px 0 0;box-shadow:0 0 0 3px rgba(178,52,57,.1)}
.bn-loc-panel{position:absolute;top:100%;left:0;right:0;background:#fff;border:1.5px solid #b23439;border-top:none;border-radius:0 0 10px 10px;box-shadow:0 12px 32px rgba(0,0,0,.1);z-index:100;max-height:350px;display:none;flex-direction:column}
.bn-loc-search{margin:10px;padding:9px 12px;border:1.5px solid #eef0f6;border-radius:8px;font-size:13px;font-family:inherit;font-weight:500;outline:none}
.bn-loc-search:focus{border-color:#b23439}
.bn-loc-tree{flex:1;overflow-y:auto;padding:0 8px 8px;scrollbar-width:thin}
.bn-loc-tree::-webkit-scrollbar{width:4px}.bn-loc-tree::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}
.bn-loc-province{margin-bottom:1px}
.bn-loc-prov-header{display:flex;align-items:center;gap:7px;padding:8px 8px;border-radius:6px;cursor:pointer;transition:background .1s}
.bn-loc-prov-header:hover{background:#f8f9fc}
.bn-loc-expand{width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#9ca3af;transition:transform .2s;flex-shrink:0}
.bn-loc-expand.open{transform:rotate(90deg)}
.bn-loc-cb{width:18px;height:18px;min-width:18px;border:2px solid #d1d5db;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .12s;cursor:pointer;background:#fff}
.bn-loc-cb.checked{background:#1a2744;border-color:#1a2744}
.bn-loc-cb.partial{background:#7c8db0;border-color:#7c8db0}
.bn-loc-cb svg{display:none}.bn-loc-cb.checked svg,.bn-loc-cb.partial svg{display:block}
.bn-loc-name{font-size:13px;font-weight:600;color:#2d3436;flex:1}
.bn-loc-count{font-size:10px;font-weight:700;color:#9ca3af;background:#f3f4f6;padding:2px 8px;border-radius:10px}
.bn-loc-children{padding-left:24px;display:none}.bn-loc-children.open{display:block}
.bn-loc-child{display:flex;align-items:center;gap:7px;padding:5px 8px;border-radius:4px;cursor:pointer;transition:background .1s}
.bn-loc-child:hover{background:#f8f9fc}
.bn-loc-child .bn-loc-name{font-weight:500}
.bn-loc-actions{display:flex;justify-content:space-between;padding:10px;border-top:1px solid #eef0f6}
.bn-loc-actions button{padding:8px 18px;border-radius:8px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;border:none;transition:all .1s}
#bn-loc-clear{background:#f3f4f6;color:#4b5563}
#bn-loc-clear:hover{background:#e5e7eb}
.bn-loc-apply-btn{background:#1a2744;color:#fff}
.bn-loc-apply-btn:hover{background:#2d4a6e}

/* Active Tags */
.bn-active-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.bn-tag{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;background:rgba(178,52,57,.1);border:1px solid rgba(178,52,57,.3);border-radius:50px;font-size:12px;font-weight:600;color:#8a3a3c}
.bn-tag-x{cursor:pointer;opacity:.5;font-size:15px;line-height:1}.bn-tag-x:hover{opacity:1}

/* Count */
.bn-count{font-size:15px;font-weight:600;color:#6b7280;margin-bottom:20px}
.bn-count span{font-weight:800;color:#1a2744}

/* Results Grid */
.bn-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}

/* Pagination */
.bn-pagination{display:flex;justify-content:center;gap:5px;margin-top:40px}
.bn-page-btn{padding:10px 16px;border:1.5px solid #eef0f6;border-radius:10px;background:#fff;color:#4b5563;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .15s;min-width:42px;text-align:center}
.bn-page-btn:hover{border-color:#b23439;color:#b23439}
.bn-page-btn.active{background:#1a2744;color:#fff;border-color:#1a2744}
.bn-page-btn.disabled{opacity:.3;pointer-events:none}
.bn-page-dots{padding:10px 4px;color:#9ca3af;font-weight:700;display:flex;align-items:center;font-size:16px;letter-spacing:2px;user-select:none}

/* === CTA === */
.bn-cta{padding:80px 0;background:linear-gradient(135deg,#1a2744 0%,#2d4a6e 100%);text-align:center}
.bn-cta-title{font-size:32px;font-weight:900;color:#fff;letter-spacing:1px;margin-bottom:12px}
.bn-cta-sub{font-size:16px;color:rgba(255,255,255,.5);margin-bottom:32px;max-width:480px;margin-left:auto;margin-right:auto}
.bn-cta-btns{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}

/* === FOOTER === */
.bn-footer{background:#0f1a2e;padding:60px 0 0;color:rgba(255,255,255,.5)}
.bn-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.06)}
.bn-footer-col h4{font-size:14px;font-weight:700;color:#fff;margin-bottom:16px;letter-spacing:1px}
.bn-footer-col a{display:block;font-size:14px;color:rgba(255,255,255,.4);padding:4px 0;transition:color .2s}
.bn-footer-col a:hover{color:#b23439}
.bn-footer-col p{font-size:14px;line-height:1.8}
.bn-footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.bn-footer-logo span{font-size:16px;font-weight:800;color:#fff;letter-spacing:2px}
.bn-footer-desc{font-size:14px;line-height:1.8;max-width:360px}
.bn-footer-bottom{padding:20px 0;text-align:center;font-size:13px}

/* === WHATSAPP FLOAT === */
.bn-wa-float{position:fixed;bottom:28px;right:28px;width:60px;height:60px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);z-index:999;transition:all .3s}
.bn-wa-float:hover{transform:scale(1.1);box-shadow:0 8px 30px rgba(37,211,102,.5)}

/* === LOADING === */
.bn-loading{position:fixed;inset:0;background:rgba(255,255,255,.9);display:none;align-items:center;justify-content:center;z-index:100001;backdrop-filter:blur(4px)}
.bn-spinner{width:44px;height:44px;border:3px solid #eef0f6;border-top-color:#b23439;border-radius:50%;animation:bnSpin .7s linear infinite}
@keyframes bnSpin{to{transform:rotate(360deg)}}

/* === MODAL === */
.bn-modal{position:fixed;inset:0;z-index:100000;display:none;align-items:center;justify-content:center;padding:16px}
.bn-modal-overlay{position:fixed;inset:0;background:rgba(26,39,68,.7);backdrop-filter:blur(8px)}
.bn-modal-content{position:relative;background:#fff;border-radius:20px;width:100%;max-width:920px;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.25);animation:bnModalIn .3s cubic-bezier(.16,1,.3,1);overflow:hidden}
@keyframes bnModalIn{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:none}}
.bn-modal-close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;border:none;background:rgba(255,255,255,.9);color:#1f2937;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 2px 10px rgba(0,0,0,.15);transition:all .12s}
.bn-modal-close:hover{background:#fff;transform:scale(1.1)}
#bn-modal-body{flex:1;overflow-y:auto;min-height:0;scrollbar-width:thin}
#bn-modal-body::-webkit-scrollbar{width:5px}
#bn-modal-body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}

/* Gallery */
.bn-gallery{position:relative;background:#0a0a0a}
.bn-gallery-main{position:relative;height:360px;overflow:hidden;background:#0a0a0a}
.bn-gallery-main img{width:100%;height:100%;object-fit:contain}
.bn-gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.9);border:none;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(0,0,0,.2);transition:all .12s;color:#1f2937;z-index:5}
.bn-gallery-nav:hover{background:#fff;transform:translateY(-50%) scale(1.06)}
.bn-gallery-prev{left:12px}.bn-gallery-next{right:12px}
.bn-gallery-counter{position:absolute;bottom:12px;left:12px;background:rgba(0,0,0,.65);color:#fff;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:700;backdrop-filter:blur(4px);z-index:5}
.bn-gallery-thumbs{display:flex;gap:6px;padding:10px 16px;background:#f3f4f6;overflow-x:auto;scrollbar-width:thin}
.bn-gallery-thumbs::-webkit-scrollbar{height:3px}.bn-gallery-thumbs::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}
.bn-gallery-thumbs img{width:80px;height:56px;object-fit:cover;border-radius:8px;cursor:pointer;opacity:.5;transition:all .15s;border:2px solid transparent;flex-shrink:0}
.bn-gallery-thumbs img:hover{opacity:.8}
.bn-gallery-thumbs img.active{opacity:1;border-color:#b23439}

/* Detail */
.bn-detail-header{padding:22px 28px 18px;border-bottom:1px solid #eef0f6}
.bn-detail-badges{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.bn-detail-badges .bn-badge{font-size:11px;padding:5px 12px}
.bn-detail-price-row{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:6px}
.bn-detail-price{font-size:30px;font-weight:900;color:#1a2744;letter-spacing:-.5px}
.bn-detail-price small{font-size:14px;font-weight:500;color:#6b7280}
.bn-detail-title{font-size:18px;font-weight:700;color:#1a2744;margin:0 0 4px;line-height:1.3}
.bn-detail-subtitle{font-size:14px;color:#6b7280;margin-bottom:4px;font-weight:500}
.bn-detail-loc{display:flex;align-items:center;gap:5px;font-size:13px;color:#9ca3af;font-weight:500}
.bn-detail-loc svg{color:#b23439;width:14px;height:14px}
.bn-detail-id{font-size:12px;font-weight:700;color:#d1d5db;margin-top:4px}

/* Features Strip */
.bn-detail-features{display:flex;padding:18px 28px;background:#f8f9fc;border-bottom:1px solid #eef0f6}
.bn-detail-feat{flex:1;text-align:center;padding:4px 8px;position:relative}
.bn-detail-feat:not(:last-child)::after{content:'';position:absolute;right:0;top:10%;height:80%;width:1px;background:#e5e7eb}
.bn-detail-feat-val{font-size:24px;font-weight:900;color:#1a2744;line-height:1.2}
.bn-detail-feat-label{font-size:10px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}

/* Content */
.bn-detail-content{padding:22px 28px}
.bn-detail-section{margin-bottom:22px}
.bn-detail-section:last-child{margin-bottom:0}
.bn-detail-section h3{font-size:14px;font-weight:800;color:#1a2744;margin:0 0 10px;padding:0 0 8px;border-bottom:1px solid #f3f4f6;text-transform:uppercase;letter-spacing:.5px}
.bn-detail-desc{font-size:14px;line-height:1.75;color:#4b5563}
.bn-detail-desc p{margin-bottom:8px}
.bn-detail-desc img{max-width:100%;height:auto;max-height:300px;object-fit:contain;border-radius:10px;margin:8px 0;display:block}
.bn-amenities-grid{display:flex;flex-wrap:wrap;gap:8px}
.bn-amenity{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#f8f9fc;border-radius:8px;font-size:12px;font-weight:600;color:#2d3436}
.bn-amenity svg{color:#059669;flex-shrink:0}
.bn-detail-map{border-radius:12px;overflow:hidden;margin-top:8px}
.bn-detail-map iframe{display:block;width:100%;height:280px;border:0;border-radius:12px}

/* Detail CTA */
.bn-detail-cta{display:flex;gap:10px;padding:18px 28px;background:#fff;border-top:1px solid #eef0f6;position:sticky;bottom:0;z-index:5;box-shadow:0 -4px 16px rgba(0,0,0,.04)}
.bn-detail-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 16px;border-radius:12px;font-size:14px;font-weight:700;font-family:inherit;transition:all .15s;cursor:pointer}
.bn-btn-primary{background:linear-gradient(135deg,#b23439,#8e2a2e);color:#fff !important;border:none}
.bn-btn-primary:hover{background:linear-gradient(135deg,#c94448,#b23439);transform:translateY(-1px);color:#fff !important}
.bn-btn-secondary{background:#fff;color:#25D366;border:2px solid #25D366}
.bn-btn-secondary:hover{background:#f0fdf4;transform:translateY(-1px)}

/* Empty */
.bn-empty{grid-column:1/-1;text-align:center;padding:60px 20px}
.bn-empty h3{font-size:18px;font-weight:800;color:#1a2744;margin:12px 0 6px}
.bn-empty p{color:#9ca3af;font-size:14px}

/* === ADMIN PANEL === */
.bn-admin-panel{position:fixed;inset:0;z-index:100002;display:none;align-items:center;justify-content:center}
.bn-admin-panel.open{display:flex}
.bn-admin-overlay{position:fixed;inset:0;background:rgba(15,26,46,.85);backdrop-filter:blur(8px)}
.bn-admin-content{position:relative;background:#fff;width:95%;max-width:1200px;max-height:92vh;border-radius:16px;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.3);animation:bnModalIn .3s cubic-bezier(.16,1,.3,1);overflow:hidden}
.bn-admin-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid #eef0f6;background:#f8f9fc}
.bn-admin-header h2{font-size:16px;font-weight:800;color:#1a2744;margin:0}
.bn-admin-close{width:36px;height:36px;border-radius:50%;border:none;background:rgba(0,0,0,.05);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;color:#6b7280}
.bn-admin-close:hover{background:rgba(0,0,0,.1);color:#1a2744}
/* Admin Login */
.bn-admin-login{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px}
.bn-admin-login-box{width:100%;max-width:360px;text-align:center}
.bn-admin-login-box h3{font-size:20px;font-weight:800;color:#1a2744;margin:0 0 6px}
.bn-admin-login-box p{font-size:14px;color:#9ca3af;margin:0 0 24px}
.bn-admin-login-box input{width:100%;padding:12px 16px;border:1.5px solid #eef0f6;border-radius:10px;font-size:14px;font-family:inherit;font-weight:500;margin-bottom:12px;outline:none;transition:border-color .2s;color:#2d3436}
.bn-admin-login-box input:focus{border-color:#b23439;box-shadow:0 0 0 3px rgba(178,52,57,.1)}
.bn-admin-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:8px;padding:10px 14px;font-size:13px;font-weight:600;margin-bottom:16px}
/* Admin Dashboard */
.bn-admin-dashboard{flex:1;display:flex;flex-direction:column;min-height:0}
.bn-admin-stats{display:flex;gap:12px;padding:16px 24px;background:#f8f9fc;border-bottom:1px solid #eef0f6;flex-wrap:wrap}
.bn-admin-stat{background:#fff;border-radius:10px;padding:14px 18px;border:1px solid #eef0f6;min-width:120px;flex:1}
.bn-admin-stat-val{font-size:22px;font-weight:900;color:#1a2744}
.bn-admin-stat-label{font-size:10px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.bn-admin-stat-warn .bn-admin-stat-val{color:#dc2626}
.bn-admin-toolbar{display:flex;align-items:center;gap:12px;padding:14px 24px;border-bottom:1px solid #eef0f6}
.bn-admin-toolbar input{flex:1;padding:10px 14px;border:1.5px solid #eef0f6;border-radius:10px;font-size:14px;font-family:inherit;font-weight:500;outline:none;color:#2d3436}
.bn-admin-toolbar input:focus{border-color:#b23439}
.bn-admin-logout{padding:10px 18px;border-radius:10px;border:1.5px solid #eef0f6;background:#fff;font-size:13px;font-weight:700;font-family:inherit;color:#6b7280;cursor:pointer;transition:all .15s;white-space:nowrap}
.bn-admin-logout:hover{border-color:#dc2626;color:#dc2626;background:#fef2f2}
/* Admin Table */
.bn-admin-table-wrap{flex:1;overflow:auto;min-height:0}
.bn-admin-table{width:100%;border-collapse:collapse;font-size:13px}
.bn-admin-table thead{position:sticky;top:0;z-index:2}
.bn-admin-table th{background:#1a2744;color:#fff !important;padding:10px 12px;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px;text-align:left;white-space:nowrap}
.bn-admin-table td{padding:9px 12px;border-bottom:1px solid #f3f4f6;color:#4b5563;vertical-align:middle}
.bn-admin-table tbody tr:hover{background:#f8f9fc}
.bn-admin-table .td-lid{font-weight:800;color:#1a2744;white-space:nowrap;font-size:12px}
.bn-admin-table .td-title{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}
.bn-admin-table .td-price{font-weight:700;color:#1a2744;white-space:nowrap}
.bn-admin-table .td-date{white-space:nowrap;color:#9ca3af;font-size:12px}
.bn-admin-table .td-photos{text-align:center}
.bn-admin-table .td-photos.warn{color:#dc2626;font-weight:800}
.bn-admin-table .td-photos.ok{color:#059669;font-weight:700}
.bn-admin-table .td-loc{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}
.bn-admin-table .td-link a{color:#2563eb !important;font-weight:600;font-size:12px}
.bn-admin-table .td-link a:hover{text-decoration:underline}
.bn-admin-table input[type="checkbox"]{width:16px;height:16px;cursor:pointer;accent-color:#1a2744}
#bn-admin-share-wa span{background:rgba(255,255,255,.3);padding:1px 8px;border-radius:10px;font-size:12px;font-weight:800;margin-left:2px}

/* === RESPONSIVE === */
@media(max-width:1024px){
    .bn-feat-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
    .bn-nav-desktop{display:none}
    .bn-hamburger{display:block}
    .bn-admin-content{width:100%;max-width:100%;max-height:100vh;border-radius:0}
    .bn-admin-toolbar{flex-wrap:wrap}
    .bn-admin-toolbar input{min-width:100%}
    .bn-admin-stats{gap:8px}
    .bn-admin-stat{min-width:calc(50% - 8px);padding:10px 14px}
    .bn-admin-stat-val{font-size:18px}
    .bn-hero-title{font-size:32px}
    .bn-hero-sub{font-size:14px}
    .bn-search-inner{flex-direction:column;border-radius:16px;padding:8px}
    .bn-search-icon{display:none}
    .bn-search-inner input{padding:14px 16px;font-size:16px}
    #bn-search-btn{width:100%;justify-content:center;border-radius:12px;padding:14px}
    .bn-stats-inner{gap:24px;flex-wrap:wrap;justify-content:center}
    .bn-stat-num{font-size:24px}
    .bn-cat-grid{grid-template-columns:1fr}
    .bn-cat-card{padding:28px 24px}
    .bn-section-title{font-size:24px}
    .bn-filters-row{flex-direction:column;gap:14px}
    .bn-filter-group{min-width:100%}
    .bn-filter-wide{flex:1}
    .bn-results-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
    .bn-gallery-main{height:220px}
    .bn-detail-header{padding:16px 20px}
    .bn-detail-features{padding:14px 20px;flex-wrap:wrap}
    .bn-detail-feat{min-width:calc(33% - 1px)}
    .bn-detail-content{padding:16px 20px}
    .bn-detail-cta{padding:14px 20px}
    .bn-modal{padding:8px}
    .bn-modal-content{max-height:96vh;border-radius:14px}
    .bn-footer-grid{grid-template-columns:1fr;gap:32px}
    .bn-cta-title{font-size:24px}
    .bn-loc-panel{position:relative;top:auto;border:1.5px solid #b23439;border-radius:10px;margin-top:6px;max-height:300px}
    .bn-loc-trigger.open{border-radius:10px}
    /* Floating search: shift up for mobile to avoid WA button overlap */
    .bn-float-search{bottom:96px;right:20px;width:50px;height:50px}
}
@media(max-width:640px){
    .bn-hero-title{font-size:26px}
    .bn-hero-content{padding:100px 16px 60px}
    .bn-feat-grid{grid-template-columns:1fr}
    .bn-results-grid{grid-template-columns:1fr}
    .bn-prop-img{height:200px}
    .bn-gallery-main{height:180px}
    .bn-detail-footer{flex-direction:column}
    .bn-modal{padding:4px}
    .bn-modal-content{border-radius:10px;max-height:98vh}
    .bn-wa-float{bottom:20px;right:20px;width:52px;height:52px}
    .bn-float-search{bottom:82px;right:20px;width:48px;height:48px}
    .bn-categories,.bn-featured,.bn-search-section{padding:48px 0}
    .bn-cta{padding:48px 0}
    .bn-detail-features{flex-wrap:wrap}
    .bn-detail-feat{min-width:calc(50% - 1px)}
    .bn-detail-cta{flex-direction:column}
}
