
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Segoe UI',Arial,sans-serif;background:#0F0B1F;color:#E2E0EA;overflow:hidden}

/* === LAYOUT === */
.app{display:flex;flex-direction:column;height:100vh}
.topbar{background:#1A1530;border-bottom:1px solid #2D2650;padding:0;flex-shrink:0;z-index:1000;position:relative}
.topbar-row1{display:flex;align-items:center;gap:8px;padding:8px 16px}
.topbar-brand{font-size:15px;font-weight:700;color:#fff;white-space:nowrap;margin-right:2px}
.search-unified-wrap{position:relative;flex:1;max-width:320px}
.topbar-search{width:100%;padding:7px 12px;border-radius:8px;border:1px solid #3D3660;background:#0F0B1F;color:#E2E0EA;font-size:13px;outline:none;box-sizing:border-box}
.topbar-search:focus{border-color:#6C3AED;box-shadow:0 0 0 2px rgba(108,58,237,0.3)}
.topbar-search::placeholder{color:#6B6580}

/* Dropdown filters */
.dd-wrap{position:relative}
.dd-btn{padding:6px 10px;border-radius:8px;border:1px solid #3D3660;background:#0F0B1F;color:#C4B5FD;font-size:12px;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:4px;transition:all .15s}
.dd-btn:hover,.dd-btn.open{border-color:#6C3AED;background:#1E1650}
.dd-btn .dd-arrow{font-size:9px;opacity:.6}
.dd-btn .dd-count{background:#6C3AED;color:#fff;border-radius:10px;padding:0 6px;font-size:10px;margin-left:2px}
.dd-panel{position:absolute;top:calc(100% + 4px);left:0;min-width:280px;max-height:400px;overflow-y:auto;background:#1A1530;border:1px solid #2D2650;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.4);padding:10px;display:none;z-index:1100}
.dd-panel.show{display:block}
.dd-panel-title{font-size:10px;color:#6B6580;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:600}
.dd-chips{display:flex;flex-wrap:wrap;gap:4px}
.chip{padding:4px 10px;border-radius:12px;border:1px solid #3D3660;background:transparent;color:#8B80A8;font-size:11px;cursor:pointer;transition:all .15s}
.chip:hover{border-color:#6C3AED;color:#C4B5FD}
.chip.active{background:#6C3AED;border-color:#6C3AED;color:#fff}
.chip.dim{opacity:0.4;cursor:not-allowed}
.mosaic-badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:9px;font-weight:600;background:#6C3AED22;color:#C4B5FD;margin-left:4px;vertical-align:middle}
.ba-mode-row{display:flex;gap:4px;margin-bottom:8px}
.ba-mode-btn{padding:3px 8px;border-radius:10px;border:1px solid #3D3660;background:transparent;color:#6B6580;font-size:10px;cursor:pointer}
.ba-mode-btn.active{background:#3D3660;color:#C4B5FD}

/* Nearby search row */
.topbar-row-nearby{display:flex;align-items:center;gap:8px;padding:4px 16px 6px;border-top:1px solid #2D265066}
.row-nearby-label{font-size:10px;color:#6B6580;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.nearby-input{padding:5px 10px;border-radius:6px;border:1px solid #3D3660;background:#0F0B1F;color:#E2E0EA;font-size:12px;outline:none;width:220px}
.nearby-input:focus{border-color:#6C3AED;box-shadow:0 0 0 2px rgba(108,58,237,0.3)}
.nearby-input::placeholder{color:#6B6580}
.radius-inline{display:flex;align-items:center;gap:6px;font-size:11px;color:#6B6580}
.radius-inline input[type=range]{width:90px;accent-color:#6C3AED}

/* Advertiser targeting */
.adv-target-wrap{position:relative}
.adv-target-btn{padding:5px 10px;border-radius:6px;border:1px solid #6C3AED;background:transparent;color:#C4B5FD;font-size:11px;cursor:pointer;white-space:nowrap;transition:all .15s;display:flex;align-items:center;gap:4px}
.adv-target-btn:hover{background:#6C3AED33}
.adv-target-btn.active{background:#6C3AED;color:#fff}
.adv-panel{display:none;position:absolute;top:calc(100% + 4px);left:0;background:#1A1530;border:1px solid #3D3660;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.5);z-index:999;width:340px;padding:12px}
.adv-panel.show{display:block}
.adv-panel input{width:100%;padding:7px 10px;border-radius:6px;border:1px solid #3D3660;background:#0F0B1F;color:#E2E0EA;font-size:12px;outline:none;margin-bottom:8px}
.adv-panel input:focus{border-color:#6C3AED}
.adv-brand-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.adv-brand-item{padding:6px 10px;border-radius:5px;font-size:12px;color:#C4B5FD;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.adv-brand-item:hover{background:#2D2650}
.adv-brand-item .brand-count{font-size:10px;color:#6B6580}
.adv-active-banner{display:flex;align-items:center;gap:8px;padding:4px 16px 4px;font-size:12px;color:#C4B5FD;background:#6C3AED22;border-top:1px solid #6C3AED44}
.adv-active-banner .adv-brand-name{font-weight:700;color:#fff}
.adv-active-banner .adv-dismiss{background:none;border:none;color:#C4B5FD;cursor:pointer;font-size:14px;margin-left:auto;padding:2px 6px}
.adv-active-banner .adv-dismiss:hover{color:#fff}

/* Row 3 - active filter tags */
.topbar-row2{display:none;align-items:center;gap:8px;padding:4px 16px 6px;flex-wrap:wrap}
.topbar-row2.visible{display:flex}
.amenity-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:14px;font-size:11px;font-weight:600;border:1px solid rgba(255,255,255,.15)}
.amenity-tag .tag-remove{background:none;border:none;color:inherit;cursor:pointer;font-size:13px;opacity:.7;padding:0 0 0 2px;line-height:1}
.amenity-tag .tag-remove:hover{opacity:1}
.amenity-match-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.filter-summary{font-size:11px;color:#6B6580}

/* Export button */
.export-btn-sm{padding:6px 12px;border-radius:8px;border:1px solid #3D3660;background:linear-gradient(135deg,#6C3AED,#4C1D95);color:#fff;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s;margin-left:auto}
.export-btn-sm:hover{box-shadow:0 0 0 2px rgba(108,58,237,0.3)}

/* === MAIN CONTENT === */
.main{display:flex;flex:1;overflow:hidden}
.sidebar{width:320px;min-width:320px;background:#1A1530;display:flex;flex-direction:column;border-right:1px solid #2D2650}
.site-count{padding:8px 14px;font-size:11px;color:#6B6580;border-bottom:1px solid #2D2650;display:flex;justify-content:space-between;align-items:center}
.site-list{flex:1;overflow-y:auto;padding:6px}
.site-card{padding:10px 12px 10px 14px;border-radius:8px;background:#0F0B1F;margin-bottom:4px;cursor:pointer;border:1px solid transparent;transition:all .15s;border-left:3px solid transparent}
.site-card:hover{border-color:#6C3AED;border-left-color:#6C3AED;background:#1A1530}
.site-card.selected{border-color:#6C3AED;background:#1E1650;box-shadow:0 0 12px rgba(108,58,237,.2)}
.site-card.grade-left-A{border-left-color:#059669}
.site-card.grade-left-H{border-left-color:#D97706}
.site-card.grade-left-O{border-left-color:#DC2626}
.site-name{font-size:13px;font-weight:600;color:#E2E0EA;display:flex;align-items:center;gap:6px}
.site-meta{font-size:10px;color:#8B80A8;margin-top:2px;display:flex;gap:6px;flex-wrap:wrap}
.site-ba-icons{margin-top:3px;display:flex;gap:2px;flex-wrap:wrap}
.site-ba-icon{font-size:11px;opacity:.7}
.amenity-match-row{font-size:10px;margin-top:2px;display:flex;align-items:center;gap:4px}
.grade{display:inline-block;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700}
.grade-A{background:#059669;color:#fff}
.grade-H{background:#D97706;color:#fff}
.grade-O{background:#DC2626;color:#fff}
.luxury-badge{font-size:9px;color:#C4A35A;background:#C4A35A22;padding:1px 6px;border-radius:4px;font-weight:600;letter-spacing:.3px}

/* Map */
.map-area{flex:1;position:relative}
#map{width:100%;height:100%}
/* Search results dropdown (inside topbar) */
.map-search-results{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:rgba(26,21,48,.96);border:1px solid #3D3660;border-radius:8px;max-height:280px;overflow-y:auto;backdrop-filter:blur(10px);display:none;z-index:1200}
.map-search-results.show{display:block}
.msr-item{padding:8px 12px;cursor:pointer;font-size:12px;color:#E2E0EA;border-bottom:1px solid #2D2650}
.msr-item:last-child{border-bottom:none}
.msr-item:hover{background:rgba(108,58,237,.15)}
.msr-item .msr-name{font-weight:600}
.msr-item .msr-sub{color:#8B80A8;font-size:11px;margin-top:1px}
.msr-nearby{padding:6px 12px;font-size:10px;color:#6C3AED;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #2D2650}

/* Detail panel */
.detail-panel{position:absolute;top:12px;right:12px;width:340px;max-height:calc(100vh - 100px);background:rgba(26,21,48,0.96);border-radius:12px;border:1px solid #2D2650;overflow-y:auto;display:none;z-index:1000;backdrop-filter:blur(10px);animation:panelSlide .2s ease forwards}
@keyframes panelSlide{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(108,58,237,.4)}50%{box-shadow:0 0 0 6px rgba(108,58,237,0)}}
@keyframes pulseGreen{0%,100%{box-shadow:0 0 0 0 rgba(5,150,105,.4)}50%{box-shadow:0 0 0 6px rgba(5,150,105,0)}}
@keyframes pulseAmber{0%,100%{box-shadow:0 0 0 0 rgba(217,119,6,.4)}50%{box-shadow:0 0 0 6px rgba(217,119,6,0)}}
@keyframes pulseRed{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.4)}50%{box-shadow:0 0 0 6px rgba(220,38,38,0)}}
.detail-header{padding:14px 16px;background:linear-gradient(135deg,#6C3AED,#4C1D95)}
.detail-header h2{font-size:15px;color:#fff;font-weight:600}
.detail-header p{font-size:11px;color:#C4B5FD;margin-top:2px}
.detail-close{position:absolute;top:12px;right:14px;background:none;border:none;color:#fff;font-size:18px;cursor:pointer}
.detail-body{padding:14px 16px;max-height:calc(100vh - 220px);overflow-y:auto}
.detail-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px}
.stat-box{background:#0F0B1F;border-radius:8px;padding:10px;text-align:center}
.stat-val{font-size:18px;font-weight:700;color:#C4B5FD}
.stat-label{font-size:10px;color:#6B6580;margin-top:2px}
.detail-section{margin-bottom:12px}
.detail-section h3{font-size:12px;color:#9B8FC0;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:600}
.ba-tag{padding:3px 8px;border-radius:10px;font-size:10px;background:#1E1650;color:#C4B5FD;border:1px solid #3D3660}
.building-amenity-tags{display:flex;flex-wrap:wrap;gap:4px}
.amenity-brand-search{width:100%;padding:7px 10px;border-radius:6px;border:1px solid #3D3660;background:#0F0B1F;color:#E2E0EA;font-size:12px;margin-bottom:8px;outline:none}
.amenity-brand-search:focus{border-color:#6C3AED}
.amenity-list{max-height:300px;overflow-y:auto}
.amenity-item{display:flex;align-items:center;padding:5px 8px;border-radius:6px;margin-bottom:2px;background:#0F0B1F;font-size:12px;cursor:pointer;transition:background .15s}
.amenity-item:hover{background:#1E1650}
.amenity-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;margin-right:6px;flex-shrink:0}
.amenity-name{flex:1;color:#E2E0EA}
.amenity-brand-tag{font-size:10px;color:#8B80A8;background:#1A1530;padding:1px 6px;border-radius:8px;margin-left:4px}
.amenity-dist{font-size:10px;color:#6B6580;margin-left:8px;white-space:nowrap}
.cat-Supermarket .amenity-icon{background:#059669}
.cat-Gym .amenity-icon{background:#DC2626}
.cat-Restaurant .amenity-icon{background:#D97706}
.cat-Café .amenity-icon{background:#92400E}
.cat-Pub .amenity-icon{background:#7C3AED}
.cat-Park .amenity-icon{background:#10B981}
.cat-School .amenity-icon{background:#2563EB}
.cat-Station .amenity-icon{background:#6366F1}
.cat-Pharmacy .amenity-icon{background:#EC4899}
.cat-ShoppingCentre .amenity-icon{background:#F59E0B}
.cat-Spa .amenity-icon{background:#14B8A6}
.amenity-cat-filters{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}
.cat-filter{padding:3px 8px;border-radius:10px;border:1px solid #3D3660;background:transparent;color:#8B80A8;font-size:10px;cursor:pointer;transition:all .15s}
.cat-filter.active{background:#6C3AED;border-color:#6C3AED;color:#fff}

/* Tooltip overrides for leaflet */
.site-tooltip{background:#1A1530!important;color:#E2E0EA!important;border:1px solid #3D3660!important;border-radius:6px!important;font-size:12px!important;padding:4px 8px!important}
.amenity-tooltip{background:#1A1530!important;color:#E2E0EA!important;border:1px solid #3D3660!important;border-radius:6px!important;font-size:11px!important;padding:4px 8px!important}

.stats-bar{display:flex;gap:0;border-bottom:1px solid #2D2650;background:#0F0B1F}
.stats-bar .sb-item{flex:1;padding:8px 6px;text-align:center;border-right:1px solid #2D2650}
.stats-bar .sb-item:last-child{border-right:none}
.stats-bar .sb-val{font-size:15px;font-weight:700;color:#C4B5FD}
.stats-bar .sb-lbl{font-size:9px;color:#6B6580;text-transform:uppercase;letter-spacing:.4px;margin-top:1px}
.site-tooltip-rich{background:#1A1530!important;color:#E2E0EA!important;border:1px solid #3D3660!important;border-radius:8px!important;font-size:11px!important;padding:8px 10px!important;line-height:1.5!important;white-space:nowrap!important;max-width:none!important;box-shadow:0 4px 12px rgba(0,0,0,.4)!important}
.site-tooltip-rich::before{border-top-color:#3D3660!important}
.site-tooltip-rich .tt-name{font-weight:700;font-size:12px;margin-bottom:2px}
.site-tooltip-rich .tt-meta{color:#8B80A8;font-size:10px}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#0F0B1F}
::-webkit-scrollbar-thumb{background:#3D3660;border-radius:3px}

/* === SELECTION BASKET === */
.basket-toggle{position:absolute;top:8px;right:8px;width:20px;height:20px;border-radius:4px;border:2px solid #3D3660;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;color:transparent;transition:all .15s;z-index:1}
.basket-toggle:hover{border-color:#6C3AED;background:rgba(108,58,237,.1)}
.basket-toggle.in-basket{border-color:#059669;background:#059669;color:#fff}
.site-card{position:relative}

.basket-bar{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#1E1650,#1A1530);border-top:2px solid #6C3AED;z-index:2000;transform:translateY(100%);transition:transform .25s ease;box-shadow:0 -4px 20px rgba(0,0,0,.4)}
.basket-bar.visible{transform:translateY(0)}
.basket-bar-inner{display:flex;align-items:center;gap:12px;padding:10px 20px;max-width:100%;overflow-x:auto}
.basket-count{font-size:14px;font-weight:700;color:#fff;white-space:nowrap;display:flex;align-items:center;gap:6px}
.basket-count .bc-num{background:#6C3AED;color:#fff;width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px}
.basket-stats{display:flex;gap:16px;flex:1;justify-content:center}
.basket-stat{text-align:center;white-space:nowrap}
.basket-stat .bs-val{font-size:16px;font-weight:700;color:#C4B5FD}
.basket-stat .bs-lbl{font-size:9px;color:#6B6580;text-transform:uppercase;letter-spacing:.4px}
.basket-grades{display:flex;gap:4px;align-items:center}
.basket-grade-pip{padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;color:#fff}
.basket-actions{display:flex;gap:6px;margin-left:auto;flex-shrink:0}
.basket-btn{padding:7px 14px;border-radius:8px;border:none;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}
.basket-btn-export{background:linear-gradient(135deg,#6C3AED,#4C1D95);color:#fff}
.basket-btn-export:hover{box-shadow:0 0 0 2px rgba(108,58,237,.4)}
.basket-btn-clear{background:transparent;border:1px solid #3D3660;color:#8B80A8}
.basket-btn-clear:hover{border-color:#DC2626;color:#DC2626}
.basket-btn-expand{background:transparent;border:1px solid #3D3660;color:#C4B5FD;font-size:13px;padding:7px 10px}
.basket-btn-expand:hover{border-color:#6C3AED}

.basket-detail{display:none;padding:12px 20px 16px;border-top:1px solid #2D2650;max-height:35vh;overflow-y:auto}
.basket-detail.show{display:block}
.basket-detail-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));gap:8px}
.basket-detail-card{background:#0F0B1F;border-radius:8px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#E2E0EA}
.basket-detail-card .bdc-name{font-weight:600}
.basket-detail-card .bdc-meta{color:#8B80A8;font-size:10px}
.basket-detail-card .bdc-remove{background:none;border:none;color:#DC2626;cursor:pointer;font-size:14px;padding:0 4px;opacity:.6}
.basket-detail-card .bdc-remove:hover{opacity:1}
.basket-area-breakdown{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.basket-area-chip{padding:3px 10px;border-radius:10px;background:#1E1650;border:1px solid #3D3660;font-size:10px;color:#C4B5FD}

/* === COMPETITOR OVERLAY === */
.comp-toggle-wrap{display:flex;align-items:center;gap:6px}
.comp-toggle{position:relative;width:34px;height:18px;border-radius:9px;background:#3D3660;cursor:pointer;border:none;transition:background .2s;flex-shrink:0}
.comp-toggle.on{background:#6C3AED}
.comp-toggle::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s}
.comp-toggle.on::after{transform:translateX(16px)}
.comp-toggle-label{font-size:10px;color:#8B80A8;white-space:nowrap;cursor:pointer}
.safelist-toggle-wrap{display:flex;align-items:center;gap:6px}
.safelist-toggle{position:relative;width:34px;height:18px;border-radius:9px;background:#3D3660;cursor:pointer;border:none;transition:background .2s;flex-shrink:0}
.safelist-toggle.on{background:#059669}
.safelist-toggle::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s}
.safelist-toggle.on::after{transform:translateX(16px)}
.safelist-toggle-label{font-size:10px;color:#8B80A8;white-space:nowrap;cursor:pointer}
.safe-badge{font-size:9px;padding:1px 5px;border-radius:3px;font-weight:600;margin-left:4px}
.safe-badge.on-list{background:#05966922;color:#059669;border:1px solid #05966944}
.safe-badge.off-list{background:#DC262622;color:#DC2626;border:1px solid #DC262644}
.zone-badge{font-size:9px;padding:1px 5px;border-radius:3px;background:#6C3AED22;color:#A78BFA;border:1px solid #6C3AED33;margin-left:4px;font-weight:600}
.comp-legend{display:flex;gap:10px;align-items:center;font-size:10px;color:#6B6580}
.comp-legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:3px}

/* Proximity button + count (in nearby row) */
.prox-btn{padding:5px 10px;border-radius:6px;border:1px solid #3D3660;background:#0F0B1F;color:#C4B5FD;font-size:11px;cursor:pointer;transition:all .15s}
.prox-btn:hover{border-color:#6C3AED;background:#1E1650}
.prox-count{font-size:11px;color:#C4B5FD;font-weight:600;white-space:nowrap}

/* Draw-to-select */
.draw-btn{padding:5px 10px;border-radius:6px;border:1px solid #3D3660;background:#0F0B1F;color:#C4B5FD;font-size:11px;cursor:pointer;white-space:nowrap;transition:all .15s;display:flex;align-items:center;gap:4px}
.draw-btn:hover{border-color:#6C3AED;background:#1E1650}
.draw-btn.active{background:#6C3AED;border-color:#6C3AED;color:#fff}
.leaflet-draw-toolbar a{background-color:#1A1530!important;color:#C4B5FD!important;border:1px solid #3D3660!important}
.leaflet-draw-toolbar a:hover{background-color:#2D2650!important}
.leaflet-draw-actions a{background-color:#1A1530!important;color:#C4B5FD!important}
.draw-info-banner{display:none;align-items:center;gap:8px;padding:4px 16px;font-size:12px;color:#F59E0B;background:#78350F33;border-top:1px solid #78350F66}
.draw-info-banner.show{display:flex}
.draw-info-banner .draw-dismiss{background:none;border:none;color:#F59E0B;cursor:pointer;font-size:14px;margin-left:auto;padding:2px 6px}

/* Brand viz layer pulse */
@keyframes brandPulse{0%,100%{opacity:.8}50%{opacity:.4}}

/* Map Legend */
.map-legend{position:absolute;bottom:28px;left:12px;z-index:800;background:rgba(26,21,48,.94);border:1px solid #2D2650;border-radius:10px;backdrop-filter:blur(8px);min-width:160px;box-shadow:0 4px 16px rgba(0,0,0,.4);transition:all .2s}
.map-legend-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;user-select:none}
.map-legend-header h4{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#8B80A8;margin:0;font-weight:600}
.map-legend-toggle{background:none;border:none;color:#6B6580;font-size:10px;cursor:pointer;transition:transform .2s}
.map-legend-toggle.collapsed{transform:rotate(180deg)}
.map-legend-body{padding:0 12px 10px;display:flex;flex-direction:column;gap:6px}
.map-legend-body.hidden{display:none}
.legend-item{display:flex;align-items:center;gap:8px;font-size:11px;color:#C4B5FD}
.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:1.5px solid rgba(255,255,255,.6)}
.legend-sq{width:8px;height:8px;border-radius:2px;flex-shrink:0;border:1px solid rgba(255,255,255,.4)}
.legend-diamond{width:9px;height:9px;border-radius:2px;flex-shrink:0;border:1.5px solid rgba(255,255,255,.5);transform:rotate(45deg)}
.legend-section{font-size:9px;color:#6B6580;text-transform:uppercase;letter-spacing:.3px;margin-top:4px;padding-top:4px;border-top:1px solid #2D265066}

/* Saved Campaigns */
.save-load-wrap{position:relative;display:flex;gap:4px}
.basket-btn-save{background:transparent;border:1px solid #3D3660;color:#C4B5FD;padding:7px 10px;border-radius:8px;font-size:11px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:4px}
.basket-btn-save:hover{border-color:#6C3AED;background:#1E1650}
.saved-dd{position:absolute;bottom:calc(100% + 6px);right:0;background:#1A1530;border:1px solid #2D2650;border-radius:10px;box-shadow:0 -4px 20px rgba(0,0,0,.5);min-width:260px;max-height:300px;overflow-y:auto;display:none;z-index:2100;padding:8px}
.saved-dd.show{display:block}
.saved-dd-title{font-size:10px;color:#6B6580;text-transform:uppercase;letter-spacing:.5px;padding:4px 8px;font-weight:600}
.saved-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:all .15s}
.saved-item:hover{background:#1E1650}
.saved-item-info{flex:1}
.saved-item-name{font-size:12px;font-weight:600;color:#E2E0EA}
.saved-item-meta{font-size:10px;color:#6B6580;margin-top:1px}
.saved-item-del{background:none;border:none;color:#6B6580;cursor:pointer;font-size:13px;padding:2px 4px;opacity:.5;transition:all .15s}
.saved-item-del:hover{color:#DC2626;opacity:1}
.saved-empty{padding:12px;text-align:center;color:#6B6580;font-size:11px}

/* Multi-brand chips in banner */
.adv-brand-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;background:#6C3AED44;border:1px solid #6C3AED66;color:#C4B5FD;font-size:11px;font-weight:600}
.adv-brand-chip .chip-remove{background:none;border:none;color:#C4B5FD;cursor:pointer;font-size:12px;padding:0 0 0 2px;opacity:.7}
.adv-brand-chip .chip-remove:hover{opacity:1;color:#fff}

/* UI Polish */
.topbar-brand{background:linear-gradient(135deg,#6C3AED,#A78BFA);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stats-bar .sb-item{transition:background .15s}
.stats-bar .sb-item:hover{background:#1A1530}
.site-list{scroll-behavior:smooth}
.map-area{position:relative}
.map-vignette{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:400;box-shadow:inset 0 0 40px rgba(15,11,31,.5)}
.basket-btn-expand{transition:transform .2s,border-color .15s}
.basket-btn-expand.rotated{transform:rotate(180deg)}
.comp-toggle.on{box-shadow:0 0 8px rgba(108,58,237,.5)}
.adv-brand-item.selected-brand{background:#6C3AED22}
.adv-brand-item.selected-brand::after{content:'✓';color:#059669;font-weight:700;margin-left:auto;padding-left:8px}

/* Reset button */
.reset-btn{margin-left:auto;padding:5px 12px;border-radius:6px;border:1px solid #DC2626;background:transparent;color:#DC2626;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.reset-btn:hover{background:#DC262622}
.tour-relaunch{padding:5px 10px;border-radius:6px;border:1px solid #6C3AED;background:transparent;color:#A78BFA;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.tour-relaunch:hover{background:#6C3AED;color:#fff}

/* Guided tour */
.tour-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9998;pointer-events:none}
.tour-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9997;background:rgba(10,7,25,.75);pointer-events:auto;transition:opacity .3s}
.tour-backdrop.hiding{opacity:0}
.tour-highlight{position:absolute;z-index:9999;border-radius:8px;box-shadow:0 0 0 4000px rgba(10,7,25,.82),0 0 0 3px #6C3AED,0 0 30px rgba(108,58,237,.6),0 0 60px rgba(108,58,237,.25);pointer-events:none;transition:all .35s ease;animation:tourPulse 2s ease-in-out infinite}
@keyframes tourPulse{0%,100%{box-shadow:0 0 0 4000px rgba(10,7,25,.82),0 0 0 3px #6C3AED,0 0 30px rgba(108,58,237,.6),0 0 60px rgba(108,58,237,.25)}50%{box-shadow:0 0 0 4000px rgba(10,7,25,.82),0 0 0 3px #A78BFA,0 0 40px rgba(108,58,237,.8),0 0 80px rgba(108,58,237,.35)}}
.tour-card{position:absolute;z-index:10000;background:#1A1530;border:1px solid #2D2650;border-radius:12px;padding:20px 24px 16px;box-shadow:0 12px 40px rgba(0,0,0,.6);max-width:380px;width:380px;pointer-events:auto;transition:opacity .25s,transform .25s;opacity:1;transform:translateY(0)}
.tour-card.entering{opacity:0;transform:translateY(8px)}
.tour-card-arrow{position:absolute;width:12px;height:12px;background:#1A1530;border:1px solid #2D2650;transform:rotate(45deg);z-index:-1}
.tour-card-arrow.arrow-up{top:-7px;left:32px;border-right:none;border-bottom:none}
.tour-card-arrow.arrow-down{bottom:-7px;left:32px;border-left:none;border-top:none}
.tour-step-counter{font-size:10px;color:#6B6580;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:600}
.tour-card h3{font-size:15px;font-weight:700;color:#fff;margin-bottom:6px}
.tour-card p{font-size:12.5px;color:#8B80A8;line-height:1.6;margin-bottom:16px}
.tour-card p strong{color:#C4B5FD}
.tour-nav{display:flex;align-items:center;gap:8px;justify-content:space-between}
.tour-nav-left{display:flex;align-items:center;gap:8px}
.tour-dots{display:flex;gap:5px}
.tour-dot{width:7px;height:7px;border-radius:50%;background:#3D3660;transition:all .2s}
.tour-dot.active{background:#6C3AED;transform:scale(1.2)}
.tour-dot.done{background:#059669}
.tour-btn{padding:8px 16px;border-radius:8px;border:none;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.tour-btn-skip{background:transparent;border:1px solid #3D3660;color:#8B80A8}
.tour-btn-skip:hover{border-color:#6B6580;color:#C4B5FD}
.tour-btn-back{background:transparent;border:1px solid #3D3660;color:#C4B5FD}
.tour-btn-back:hover{border-color:#6C3AED}
.tour-btn-next{background:linear-gradient(135deg,#6C3AED,#4C1D95);color:#fff}
.tour-btn-next:hover{box-shadow:0 0 12px rgba(108,58,237,.4)}

/* === PLAN & PRICE (v4) === */
.planner-btn{padding:6px 12px;border-radius:8px;border:1px solid #059669;background:#05966922;color:#6EE7B7;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}
.planner-btn:hover{background:#059669;color:#fff}
.planner-backdrop{display:none;position:fixed;inset:0;background:rgba(5,3,15,.72);z-index:2000}
.planner-backdrop.show{display:block}
.planner-modal{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(720px,94vw);max-height:90vh;overflow-y:auto;background:#1A1530;border:1px solid #3D3660;border-radius:14px;box-shadow:0 24px 64px rgba(0,0,0,.6);padding:22px 24px;z-index:2001}
.planner-modal.show{display:block}
.planner-title{font-size:20px;font-weight:700;color:#fff;margin-bottom:4px}
.planner-sub{font-size:12px;color:#8B80A8;margin-bottom:14px;line-height:1.5}
.planner-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px 14px;margin-bottom:14px}
.planner-field label{display:block;font-size:10px;color:#6B6580;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-weight:600}
.planner-field input,.planner-field select{width:100%;padding:7px 10px;border-radius:7px;border:1px solid #3D3660;background:#0F0B1F;color:#E2E0EA;font-size:13px;outline:none;box-sizing:border-box}
.planner-field input:focus,.planner-field select:focus{border-color:#6C3AED}
.planner-modes{display:flex;gap:4px}
.planner-mode{flex:1;padding:7px 0;border-radius:7px;border:1px solid #3D3660;background:transparent;color:#8B80A8;font-size:12px;cursor:pointer}
.planner-mode.active{background:#6C3AED;border-color:#6C3AED;color:#fff}
.planner-results{margin:6px 0 12px}
.planner-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-bottom:10px}
.planner-stat{background:#0F0B1F;border:1px solid #2D2650;border-radius:9px;padding:9px 10px;text-align:center}
.planner-stat .ps-val{font-size:17px;font-weight:700;color:#C4B5FD}
.planner-stat .ps-lbl{font-size:9px;color:#6B6580;text-transform:uppercase;letter-spacing:.4px;margin-top:2px}
.planner-verdict{border-radius:9px;padding:9px 12px;font-size:12px;font-weight:600;margin-bottom:8px}
.planner-verdict.ok{background:#05966922;border:1px solid #059669;color:#6EE7B7}
.planner-verdict.warn{background:#D9770622;border:1px solid #D97706;color:#FCD34D}
.planner-verdict.bad{background:#DC262622;border:1px solid #DC2626;color:#FCA5A5}
.planner-conflicts{font-size:11px;color:#F59E0B;margin-bottom:8px;line-height:1.5}
.planner-sitelist{font-size:11px;color:#8B80A8;max-height:130px;overflow-y:auto;background:#0F0B1F;border-radius:8px;padding:8px 10px;line-height:1.7}
.planner-actions{display:flex;gap:8px;flex-wrap:wrap}
.planner-go{padding:9px 18px;border-radius:8px;border:none;background:#059669;color:#fff;font-size:13px;font-weight:700;cursor:pointer}
.planner-go:hover{background:#047857}
.planner-secondary{padding:9px 14px;border-radius:8px;border:1px solid #6C3AED;background:transparent;color:#C4B5FD;font-size:13px;cursor:pointer}
.planner-secondary:hover:not(:disabled){background:#6C3AED33}
.planner-secondary:disabled{opacity:.35;cursor:not-allowed}
.planner-caveat{font-size:10px;color:#6B6580;margin-top:10px;line-height:1.5}
@media (max-width:760px){.planner-modal{padding:16px}.planner-grid{grid-template-columns:1fr 1fr}}

/* Per-screen pricing table (internal planner) */
.plan-price-table{max-height:220px;overflow-y:auto;background:#0F0B1F;border:1px solid #2D2650;border-radius:8px;padding:6px 8px}
.ppt-row{display:flex;align-items:center;gap:8px;padding:2px 0;font-size:11px}
.ppt-site{flex:0 0 180px;color:#8B80A8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ppt-id{flex:1;color:#E2E0EA;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ppt-cur{color:#6B6580}
.ppt-row input{width:74px;background:#1A1530;border:1px solid #3D3660;border-radius:5px;color:#C4B5FD;padding:3px 6px;font-size:11px;text-align:right;outline:none}
.ppt-row input:focus{border-color:#6C3AED}
