/* My Realtors Pro v9 — Portal CSS — Dark/Light/Auto Theme */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=Playfair+Display:wght@700;900&display=swap');

/* ═══ CSS VARIABLES — DARK (default) ═══ */
:root,[data-theme="dark"]{
  --p-bg:#070b14;--p-surface:#0e1525;--p-card:#131d30;--p-border:#1e2d4a;
  --p-accent:#3b82f6;--p-accent-rgb:59,130,246;--p-accent2:#6366f1;
  --p-gold:#f59e0b;--p-success:#10b981;--p-danger:#ef4444;--p-warning:#f59e0b;
  --p-text:#e2e8f0;--p-muted:#64748b;--p-radius:12px;
  --p-topbar-bg:#0e1525;--p-auth-bg:#070b14;
  --p-shadow:0 4px 24px rgba(0,0,0,.4);
  --p-input-bg:#0e1525;--p-input-border:#1e2d4a;
}
/* ═══ LIGHT THEME ═══ */
[data-theme="light"]{
  --p-bg:#f0f4f8;--p-surface:#ffffff;--p-card:#f8fafc;--p-border:#e2e8f0;
  --p-accent:#2563eb;--p-accent-rgb:37,99,235;--p-accent2:#4f46e5;
  --p-gold:#d97706;--p-success:#059669;--p-danger:#dc2626;
  --p-text:#1e293b;--p-muted:#64748b;
  --p-topbar-bg:#ffffff;--p-auth-bg:#e8eef5;
  --p-shadow:0 4px 24px rgba(0,0,0,.1);
  --p-input-bg:#f8fafc;--p-input-border:#cbd5e1;
}

/* ═══ BASE ═══ */
.bp-portal-body{margin:0;padding:0;background:var(--p-bg);min-height:100vh;font-family:'DM Sans',sans-serif;color:var(--p-text);-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}
#bp-portal-root *{box-sizing:border-box;transition:background-color .2s,border-color .2s,color .2s}
.bp-hidden{display:none!important}

/* ═══ AUTH ═══ */
.bp-auth-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:radial-gradient(ellipse at 20% 50%,rgba(var(--p-accent-rgb),.15) 0%,transparent 60%),var(--p-bg);position:relative;overflow:hidden}
.bp-auth-shapes{position:absolute;inset:0;pointer-events:none}
.bp-shape{position:absolute;border-radius:50%;filter:blur(60px);opacity:.2}
.bp-shape-1{width:280px;height:280px;background:var(--p-accent);top:-10%;left:-10%;animation:float1 8s ease-in-out infinite}
.bp-shape-2{width:220px;height:220px;background:var(--p-accent2);bottom:-5%;right:-5%;animation:float2 10s ease-in-out infinite}
.bp-shape-3{width:160px;height:160px;background:var(--p-gold);top:50%;left:60%;animation:float1 6s ease-in-out infinite reverse}
@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(14px,-14px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-10px,10px)}}
.bp-auth-card{background:var(--p-surface);border:1px solid var(--p-border);border-radius:18px;padding:28px 24px;width:100%;max-width:420px;position:relative;z-index:10;box-shadow:var(--p-shadow);animation:slideUp .3s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.bp-auth-brand{text-align:center;margin-bottom:22px}
.bp-brand-logo{max-height:60px;max-width:160px;border-radius:8px;object-fit:contain}
.bp-brand-icon{font-size:38px;margin-bottom:6px}
.bp-brand-name{font-family:'Playfair Display',serif;font-size:22px;font-weight:900;color:var(--p-text);margin:6px 0 2px}
.bp-brand-sub{color:var(--p-muted);font-size:13px}
.bp-login-mode-tabs{display:flex;border:1px solid var(--p-border);border-radius:10px;overflow:hidden;margin-bottom:18px}
.bp-lm-tab{flex:1;padding:10px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;background:var(--p-surface);border:none;color:var(--p-muted);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}
.bp-lm-tab.active{background:linear-gradient(135deg,var(--p-accent),var(--p-accent2));color:#fff}
.bp-login-mode-panel{display:none}
.bp-login-mode-panel.active{display:block}
.bp-field{margin-bottom:14px}
.bp-field label{display:block;font-size:12px;font-weight:600;color:var(--p-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.bp-field input{width:100%;background:var(--p-input-bg);border:1px solid var(--p-input-border);border-radius:10px;padding:12px 14px;color:var(--p-text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;-webkit-appearance:none}
.bp-field input:focus{border-color:var(--p-accent);box-shadow:0 0 0 3px rgba(var(--p-accent-rgb),.15)}
.bp-pass-wrap{position:relative;display:flex;align-items:center}
.bp-pass-wrap input{padding-right:44px}
.bp-toggle-pass{position:absolute;right:12px;background:none;border:none;cursor:pointer;font-size:15px;color:var(--p-muted);padding:0;-webkit-tap-highlight-color:transparent}
.bp-btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--p-accent),var(--p-accent2));color:#fff;border:none;border-radius:10px;padding:13px 20px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.bp-btn-primary:active{opacity:.85}
.bp-btn-p-primary{background:linear-gradient(135deg,var(--p-accent),var(--p-accent2));color:#fff;border:none;border-radius:10px;padding:10px 16px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap}
.bp-btn-admin{background:linear-gradient(135deg,#dc2626,#7c3aed)!important}
.bp-btn-full{width:100%}
.bp-alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:12px}
.bp-alert-error{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.3);color:#fca5a5}
.bp-alert-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);color:#6ee7b7}
.bp-auth-link{color:var(--p-accent);font-size:13px;font-weight:600;text-decoration:none}
.bp-forgot-wrap{text-align:center;margin-bottom:18px}
.bp-forgot-icon{font-size:34px;margin-bottom:10px}
.bp-forgot-wrap h3{font-size:17px;font-weight:800;color:var(--p-text);margin-bottom:7px}
.bp-forgot-wrap p{font-size:13px;color:var(--p-muted);margin-bottom:14px}
.bp-contact-card{background:var(--p-card);border:1px solid var(--p-border);border-radius:10px;padding:14px;text-align:left}
.bp-cc-name{font-size:14px;font-weight:700;color:var(--p-text);margin-bottom:8px}
.bp-cc-row{font-size:13px;color:var(--p-text);padding:5px 0;border-top:1px solid var(--p-border);line-height:1.6}
.bp-cc-row a{color:var(--p-accent);text-decoration:none;font-weight:600}
.bp-info-box-portal{background:rgba(var(--p-accent-rgb),.08);border:1px solid rgba(var(--p-accent-rgb),.2);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--p-accent);margin-bottom:14px;line-height:1.6}

/* ═══ THEME BUTTON ═══ */
.bp-theme-btn{background:none;border:1px solid var(--p-border);border-radius:8px;padding:6px 10px;cursor:pointer;font-size:16px;color:var(--p-muted);transition:all .15s;-webkit-tap-highlight-color:transparent}
.bp-theme-btn:hover{border-color:var(--p-accent);color:var(--p-accent)}
.bp-admin-badge{font-size:11px;background:rgba(220,38,38,.15);border:1px solid rgba(220,38,38,.3);color:#fca5a5;padding:4px 8px;border-radius:16px;text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent}

/* ═══ TOP BAR ═══ */
.bp-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--p-topbar-bg);border-bottom:1px solid var(--p-border);position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.1)}
.bp-topbar-brand{display:flex;align-items:center;gap:8px;min-width:0}
.bp-topbar-logo{max-height:32px;max-width:110px;object-fit:contain;border-radius:5px}
.bp-topbar-name{font-family:'Playfair Display',serif;font-size:15px;font-weight:900;color:var(--p-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.bp-topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.bp-topbar-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--p-accent),var(--p-accent2));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden}
.bp-topbar-avatar img{width:32px;height:32px;object-fit:cover;border-radius:50%}
.bp-hamburger{background:none;border:none;font-size:20px;color:var(--p-text);cursor:pointer;padding:4px;-webkit-tap-highlight-color:transparent}

/* ═══ LAYOUT ═══ */
.bp-dash-layout{display:flex;min-height:calc(100vh - 54px)}
.bp-sidebar{width:260px;background:var(--p-surface);border-right:1px solid var(--p-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:200;transform:translateX(-100%);transition:transform .25s ease;overflow-y:auto;-webkit-overflow-scrolling:touch}
.bp-sidebar.open{transform:translateX(0)}
.bp-sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199}
.bp-sidebar-overlay.show{display:block}
.bp-sidebar-close-wrap{display:flex;justify-content:flex-end;padding:12px 14px 0}
.bp-sidebar-close{background:none;border:none;color:var(--p-muted);font-size:18px;cursor:pointer;padding:4px}
.bp-sidebar-brand{padding:0 18px 12px;border-bottom:1px solid var(--p-border)}
.bp-sidebar-logo{max-height:40px;max-width:130px;object-fit:contain;border-radius:6px}
.bp-sidebar-icon{font-size:24px}
.bp-sidebar-title{font-family:'Playfair Display',serif;font-size:14px;font-weight:700;color:var(--p-text);margin-top:4px}
.bp-sidebar-member{padding:12px 18px;border-bottom:1px solid var(--p-border);display:flex;align-items:center;gap:10px}
.bp-sidebar-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--p-accent),var(--p-accent2));display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden}
.bp-sidebar-avatar img{width:38px;height:38px;object-fit:cover;border-radius:50%}
.bp-sidebar-member-name{font-weight:700;font-size:13px;color:var(--p-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bp-sidebar-member-id,.bp-sidebar-member-phone,.bp-sidebar-member-pos{font-size:11px;color:var(--p-muted)}
.bp-sidebar-member-pos{color:var(--p-accent)}
.bp-sidenav{padding:8px;flex:1}
.bp-nav-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--p-muted);padding:8px 10px 4px}
.bp-nav-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;text-decoration:none;color:var(--p-muted);font-size:13px;font-weight:500;transition:all .15s;margin-bottom:2px;-webkit-tap-highlight-color:transparent}
.bp-nav-item.active{background:linear-gradient(135deg,rgba(var(--p-accent-rgb),.18),rgba(99,102,241,.12));color:var(--p-text);font-weight:700;border:1px solid rgba(var(--p-accent-rgb),.25)}
.bp-nav-item:hover:not(.active){background:rgba(var(--p-accent-rgb),.06);color:var(--p-text)}
.bp-logout-btn{margin:10px;background:none;border:1px solid var(--p-border);border-radius:10px;padding:10px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--p-muted);cursor:pointer;transition:all .15s}
.bp-logout-btn:hover{border-color:var(--p-danger);color:var(--p-danger)}
.bp-main{flex:1;padding:14px;min-width:0;overflow-x:hidden}
.bp-page-header{margin-bottom:16px}
.bp-page-header h2{font-family:'Playfair Display',serif;font-size:20px;font-weight:900;color:var(--p-text);margin:0 0 3px}
.bp-page-header p{color:var(--p-muted);font-size:13px;margin:0}

/* ═══ STATS ═══ */
.bp-stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.bp-pstat{background:var(--p-card);border:1px solid var(--p-border);border-radius:var(--p-radius);padding:12px 10px;text-align:center}
.bp-pstat-icon{font-size:20px;margin-bottom:4px}
.bp-pstat-val{font-size:18px;font-weight:800;color:var(--p-text)}
.bp-pstat-lbl{font-size:10px;color:var(--p-muted);text-transform:uppercase;letter-spacing:.4px;font-weight:600;margin-top:2px}

/* ═══ OVERVIEW ═══ */
.bp-overview-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:14px}
.bp-ov-card{background:var(--p-card);border:1px solid var(--p-border);border-radius:var(--p-radius);overflow:hidden}
.bp-ov-card-head{font-size:13px;font-weight:700;color:var(--p-text);padding:12px 14px;border-bottom:1px solid var(--p-border)}
.bp-ov-card-body{padding:12px 14px}
.bp-dl-row{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--p-border)}
.bp-dl-row:last-child{border-bottom:none}
.bp-dl-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--p-accent),var(--p-accent2));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden}
.bp-dl-avatar img{width:30px;height:30px;object-fit:cover;border-radius:50%}
.bp-dl-name{font-weight:600;font-size:13px;color:var(--p-text)}
.bp-dl-pos{font-size:11px;color:var(--p-accent)}
.bp-dl-id{font-size:11px;color:var(--p-muted)}
.bp-dl-right{margin-left:auto;font-size:11px;color:var(--p-muted)}

/* ═══ TREE ═══ */
.bp-tree-wrap{background:var(--p-card);border:1px solid var(--p-border);border-radius:var(--p-radius);overflow:auto;-webkit-overflow-scrolling:touch;min-height:200px;max-height:65vh}
.bp-portal-tree{padding:18px 20px;min-width:max-content}
.portal-org-tree{display:flex;flex-direction:column;align-items:center}
.p-node-wrap{display:flex;flex-direction:column;align-items:center}
.p-org-card{display:flex;align-items:center;gap:7px;background:var(--p-surface);border:1px solid var(--p-border);border-radius:10px;padding:8px 12px;min-width:170px;max-width:220px}
.p-org-card.is-self{border-color:var(--p-accent);background:rgba(var(--p-accent-rgb),.07)}
.p-org-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden}
.p-org-avatar img{width:30px;height:30px;object-fit:cover;border-radius:50%}
.p-org-name{font-size:12px;font-weight:700;color:var(--p-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.p-org-pos{font-size:10px;color:var(--p-accent);margin-top:1px}
.p-org-id{font-size:10px;color:var(--p-muted)}
.p-org-network{font-size:10px;color:var(--p-success)}
.p-expand-btn{width:18px;height:18px;border-radius:50%;background:var(--p-border);border:none;color:var(--p-text);font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform .2s;padding:0;margin-left:auto;-webkit-tap-highlight-color:transparent}
.p-expand-btn.open{transform:rotate(90deg)}
.p-connector{width:2px;height:16px;background:var(--p-border);margin:0 auto}
.p-children-row{display:flex;gap:0;align-items:flex-start;justify-content:center;position:relative}
.p-children-row::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);height:2px;background:var(--p-border);width:calc(100% - 40px)}
.p-child-col{display:flex;flex-direction:column;align-items:center;padding:0 8px;position:relative}
.p-child-col::before{content:'';position:absolute;top:0;left:50%;width:2px;height:16px;background:var(--p-border)}
.p-children-wrap{overflow:hidden;transition:max-height .3s;max-height:9999px}
.p-children-wrap.collapsed{max-height:0!important}

/* ═══ BUSINESS / SALE CARDS ═══ */
.bp-biz-card{background:var(--p-surface);border:1px solid var(--p-border);border-radius:var(--p-radius);padding:14px;margin-bottom:10px}
.bp-biz-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;gap:8px;flex-wrap:wrap}
.bp-biz-name{font-size:14px;font-weight:700;color:var(--p-text)}
.bp-customer-box{background:rgba(var(--p-accent-rgb),.05);border:1px solid rgba(var(--p-accent-rgb),.15);border-radius:9px;padding:10px 12px;margin-bottom:10px}
.bp-customer-label{font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--p-muted);font-weight:700;margin-bottom:4px}
.bp-customer-name{font-size:13px;font-weight:700;color:var(--p-text);margin-bottom:2px}
.bp-customer-detail{font-size:12px;color:var(--p-muted)}
.bp-biz-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:10px}
.bp-biz-item{background:var(--p-card);border-radius:8px;padding:8px 10px;border:1px solid var(--p-border)}
.bp-biz-item-label{font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--p-muted);font-weight:600}
.bp-biz-item-val{font-size:12px;font-weight:700;color:var(--p-text);margin-top:2px}
.bp-biz-financial{background:var(--p-bg);border:1px solid var(--p-border);border-radius:9px}
.bp-biz-fin-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid var(--p-border);font-size:12px}
.bp-biz-fin-row:last-child{border-bottom:none}
.bp-biz-fin-label{color:var(--p-muted)}
.bp-biz-fin-val{font-weight:700;color:var(--p-text)}
.bp-biz-fin-val.success{color:var(--p-success)}
.bp-biz-fin-val.danger{color:var(--p-danger)}
.bp-biz-fin-val.gold{color:var(--p-gold);font-size:14px}
.bp-biz-dates{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px}
.bp-biz-date{background:var(--p-card);border-radius:7px;padding:7px;text-align:center}
.bp-biz-date-label{font-size:9px;text-transform:uppercase;color:var(--p-muted);font-weight:600}
.bp-biz-date-val{font-size:11px;font-weight:700;color:var(--p-text);margin-top:2px}

/* ═══ SALE STATUS BADGES ═══ */
.bp-sale-status{display:inline-block;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:700}
.bp-ss-booked{background:rgba(59,130,246,.15);color:#93c5fd}
.bp-ss-payment_pending{background:rgba(251,146,60,.15);color:#fdba74}
.bp-ss-payment_completed{background:rgba(16,185,129,.15);color:#6ee7b7}
.bp-ss-ready_for_registration{background:rgba(99,102,241,.15);color:#c4b5fd}
.bp-ss-registered{background:rgba(20,184,166,.15);color:#5eead4}
.bp-ss-cancelled{background:rgba(239,68,68,.15);color:#fca5a5}

/* ═══ SITE VISITS — IMPROVED CARDS ═══ */
.bp-visit-card{background:var(--p-surface);border:1px solid var(--p-border);border-radius:var(--p-radius);margin-bottom:10px;overflow:hidden}
.bp-visit-card-header{padding:12px 14px;display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap;border-bottom:1px solid var(--p-border)}
.bp-visit-customer-name{font-size:15px;font-weight:700;color:var(--p-text)}
.bp-visit-customer-meta{font-size:12px;color:var(--p-muted);margin-top:2px}
.bp-visit-status-p{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}
.bp-vstp-booking_done{background:rgba(16,185,129,.15);color:#6ee7b7}
.bp-vstp-interested{background:rgba(245,158,11,.15);color:#fcd34d}
.bp-vstp-not_interested,.bp-vstp-no_show{background:rgba(239,68,68,.15);color:#fca5a5}
.bp-vstp-negotiation{background:rgba(99,102,241,.15);color:#c4b5fd}
.bp-vstp-follow_up{background:rgba(251,146,60,.15);color:#fdba74}
.bp-vstp-visit_completed{background:rgba(20,184,166,.15);color:#5eead4}
.bp-vstp-visit_scheduled,.bp-vstp-date_fixed,.bp-vstp-visit_confirmed,.bp-vstp-attendance_confirmed,.bp-vstp-reminder_sent,.bp-vstp-agent_assigned{background:rgba(59,130,246,.15);color:#93c5fd}
.bp-vstp-rescheduled{background:rgba(245,158,11,.15);color:#fcd34d}
.bp-visit-body{padding:12px 14px}
.bp-visit-photo{width:100%;max-height:160px;object-fit:cover;display:block}
.bp-visit-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:8px}
.bp-visit-info-item{background:var(--p-card);border:1px solid var(--p-border);border-radius:8px;padding:8px 10px}
.bp-visit-info-label{font-size:10px;text-transform:uppercase;color:var(--p-muted);font-weight:600}
.bp-visit-info-val{font-size:12px;font-weight:600;color:var(--p-text);margin-top:2px;word-break:break-word}
.bp-visit-full-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--p-border);font-size:13px}
.bp-visit-full-row:last-child{border-bottom:none}
.bp-visit-full-label{color:var(--p-muted);font-size:12px;flex-shrink:0;margin-right:8px}
.bp-visit-full-val{font-weight:600;color:var(--p-text);text-align:right}
.bp-visit-comments-box{background:var(--p-card);border-radius:8px;padding:9px 12px;font-size:12px;color:var(--p-muted);margin-top:8px;line-height:1.6}
.bp-visit-actions{display:flex;gap:7px;padding:10px 14px;border-top:1px solid var(--p-border);flex-wrap:wrap;align-items:center;background:var(--p-card)}
.bp-visit-action-btn{background:none;border:1px solid var(--p-border);border-radius:8px;padding:5px 12px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;color:var(--p-muted);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}
.bp-visit-action-btn.edit{border-color:rgba(var(--p-accent-rgb),.3);color:var(--p-accent)}
.bp-visit-action-btn.delete{border-color:rgba(239,68,68,.3);color:var(--p-danger)}
.bp-expert-badge{font-size:11px;color:var(--p-accent);font-weight:600}
.bp-bulk-bar{background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.15);border-radius:10px;padding:10px 14px;margin-bottom:10px;display:none;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.bp-bulk-bar.show{display:flex}

/* ═══ ACHIEVERS ═══ */
.bp-p-achiever-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.bp-p-atab{background:var(--p-surface);border:1px solid var(--p-border);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;color:var(--p-muted);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;-webkit-tap-highlight-color:transparent}
.bp-p-atab.active{background:linear-gradient(135deg,var(--p-accent),var(--p-accent2));color:#fff;border-color:transparent}
.bp-p-achiever-panel{display:none}
.bp-p-achiever-panel.show{display:block}
.bp-p-achiever-cats{display:flex;flex-direction:column;gap:12px}
.bp-p-ach-cat-block{background:var(--p-card);border:1px solid var(--p-border);border-radius:var(--p-radius);overflow:hidden}
.bp-p-ach-cat-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--p-muted);padding:10px 14px;border-bottom:1px solid var(--p-border)}
.bp-p-ach-row{display:flex;align-items:center;gap:9px;padding:9px 14px;border-bottom:1px solid var(--p-border)}
.bp-p-ach-row:last-child{border-bottom:none}
.bp-p-ach-row.top-row{background:rgba(245,158,11,.04)}
.bp-p-ach-medal-s{font-size:15px;flex-shrink:0;width:20px;text-align:center}
.bp-p-ach-info{flex:1;min-width:0}
.bp-p-ach-name-s{font-weight:700;font-size:13px;color:var(--p-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bp-p-ach-pos-s{font-size:11px;color:var(--p-muted)}

/* ═══ EXPORT ═══ */
.bp-export-portal-grid{display:grid;grid-template-columns:1fr;gap:10px}
.bp-export-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--p-muted);margin:16px 0 8px;padding-bottom:6px;border-bottom:1px solid var(--p-border)}
.bp-export-btn-row{display:flex;gap:8px;flex-wrap:wrap}
.bp-export-btn{display:inline-flex;align-items:center;gap:6px;background:var(--p-card);border:1px solid var(--p-border);border-radius:9px;padding:10px 14px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:var(--p-text);cursor:pointer;text-decoration:none;transition:all .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.bp-export-btn:hover,.bp-export-btn:active{border-color:var(--p-accent);color:var(--p-accent)}
.bp-export-btn.primary{background:linear-gradient(135deg,var(--p-accent),var(--p-accent2));color:#fff;border-color:transparent}
.bp-date-filter-bar{background:var(--p-card);border:1px solid var(--p-border);border-radius:var(--p-radius);padding:14px;margin-bottom:14px}
.bp-date-filter-bar label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--p-muted);display:block;margin-bottom:7px}
.bp-date-filter-options{display:flex;gap:6px;flex-wrap:wrap}
.bp-date-opt{background:none;border:1px solid var(--p-border);border-radius:7px;padding:5px 11px;font-size:12px;font-weight:600;color:var(--p-muted);cursor:pointer;transition:all .15s}
.bp-date-opt.active{background:rgba(var(--p-accent-rgb),.15);border-color:var(--p-accent);color:var(--p-accent)}
.bp-export-summary-card{background:var(--p-card);border:1px solid var(--p-border);border-radius:var(--p-radius);padding:14px;margin-bottom:12px}
.bp-export-summary-title{font-size:13px;font-weight:700;color:var(--p-text);margin-bottom:8px}
.bp-export-summary-stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.bp-exp-stat{font-size:12px;color:var(--p-muted)}
.bp-exp-stat strong{color:var(--p-text)}
.bp-receipt-list{margin-top:10px}
.bp-receipt-item{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--p-border);gap:8px}
.bp-receipt-item:last-child{border-bottom:none}
.bp-receipt-name{font-weight:600;font-size:13px;color:var(--p-text)}
.bp-receipt-meta{font-size:11px;color:var(--p-muted);margin-top:2px}
.bp-receipt-btn{background:rgba(var(--p-accent-rgb),.12);color:var(--p-accent);border:1px solid rgba(var(--p-accent-rgb),.25);padding:5px 11px;border-radius:8px;font-size:12px;font-weight:700;text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent;display:inline-block}

/* ═══ PROFILE ═══ */
.bp-profile-card{background:var(--p-card);border:1px solid var(--p-border);border-radius:var(--p-radius);padding:18px}
.bp-profile-avatar-wrap{text-align:center;margin-bottom:14px}
.bp-profile-avatar{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:900;color:#fff;margin:0 auto;overflow:hidden;border:3px solid var(--p-border)}
.bp-profile-avatar img{width:72px;height:72px;object-fit:cover;border-radius:50%}
.bp-profile-name{text-align:center;font-family:'Playfair Display',serif;font-size:18px;font-weight:900;color:var(--p-text)}
.bp-profile-pos{text-align:center;font-size:13px;color:var(--p-accent);font-weight:600;margin:3px 0 14px}
.bp-profile-section-head{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--p-muted);padding:12px 0 6px;border-top:1px solid var(--p-border);margin-top:4px}
.bp-profile-section-head:first-of-type{border-top:none;padding-top:0;margin-top:0}
.bp-profile-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--p-border);font-size:13px;gap:10px}
.bp-profile-row:last-child{border-bottom:none}
.bp-profile-label{color:var(--p-muted);font-size:12px;flex-shrink:0}
.bp-profile-val{font-weight:600;color:var(--p-text);text-align:right;word-break:break-word}

/* ═══ ADMIN PORTAL TABLES ═══ */
.bp-admin-table{width:100%;border-collapse:collapse;font-size:12px;min-width:500px}
.bp-admin-table thead tr{background:var(--p-card);border-bottom:2px solid var(--p-border)}
.bp-admin-table th{padding:9px 10px;text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--p-muted);font-weight:700;white-space:nowrap}
.bp-admin-table td{padding:9px 10px;border-bottom:1px solid var(--p-border);vertical-align:middle;color:var(--p-text)}
.bp-admin-table tr:hover td{background:rgba(var(--p-accent-rgb),.03)}
.bp-admin-table tr:last-child td{border-bottom:none}
.bp-admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;background:var(--p-surface);border:1px solid var(--p-border);border-radius:var(--p-radius)}
.bp-admin-search-row{margin-bottom:12px}
.bp-admin-btn{background:none;border:1px solid var(--p-border);border-radius:7px;padding:4px 9px;font-size:11px;font-weight:600;color:var(--p-accent);cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap}
.bp-admin-btn:hover{background:rgba(var(--p-accent-rgb),.1)}

/* ═══ ADD FORM ═══ */
.bp-form-card{background:var(--p-surface);border:1px solid var(--p-border);border-radius:var(--p-radius);overflow:hidden;margin-bottom:12px}
.bp-form-card-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--p-border);font-size:13px;font-weight:700;color:var(--p-text)}
.bp-form-card-body{padding:14px}
.bp-icon-btn{background:none;border:none;color:var(--p-muted);cursor:pointer;font-size:16px;padding:2px;-webkit-tap-highlight-color:transparent}
.bp-portal-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bp-pf-field{display:flex;flex-direction:column;gap:4px}
.bp-pf-field.bp-pf-full{grid-column:1/-1}
.bp-pf-field label{font-size:11px;font-weight:600;color:var(--p-muted);text-transform:uppercase;letter-spacing:.4px}
.bp-portal-input{width:100%;background:var(--p-input-bg);border:1px solid var(--p-input-border);border-radius:9px;color:var(--p-text);font-family:'DM Sans',sans-serif;font-size:13px;padding:9px 11px;outline:none;-webkit-appearance:none}
.bp-portal-input:focus{border-color:var(--p-accent);box-shadow:0 0 0 3px rgba(var(--p-accent-rgb),.1)}
.bp-portal-input::placeholder{color:var(--p-muted)}
select.bp-portal-input option{background:var(--p-surface);color:var(--p-text)}
textarea.bp-portal-input{resize:vertical}

/* ═══ MODAL ═══ */
.bp-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-end;justify-content:center}
.bp-modal-sheet{background:var(--p-surface);border-radius:16px 16px 0 0;padding:18px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:slideUpModal .25s ease}
@keyframes slideUpModal{from{transform:translateY(100%)}to{transform:none}}
.bp-modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.bp-modal-head h3{font-family:'Playfair Display',serif;font-size:17px;font-weight:900;color:var(--p-text);margin:0}
.bp-modal-close-btn{background:none;border:none;color:var(--p-muted);font-size:18px;cursor:pointer;padding:4px;-webkit-tap-highlight-color:transparent}

/* ═══ COMMON ═══ */
.bp-loading{color:var(--p-muted);text-align:center;padding:22px;font-size:13px}
.bp-empty{color:var(--p-muted);text-align:center;padding:22px;font-size:13px}
.bp-view-all{display:block;text-align:center;margin-top:8px;font-size:13px;color:var(--p-accent);text-decoration:none;font-weight:600;cursor:pointer;background:none;border:none;padding:0;width:100%;-webkit-tap-highlight-color:transparent}
.bp-badge{display:inline-block;padding:2px 7px;border-radius:20px;font-size:11px;font-weight:700}
.bp-badge-active{background:rgba(16,185,129,.15);color:#10b981}
.bp-badge-inactive{background:rgba(239,68,68,.15);color:#ef4444}

/* ═══ DESKTOP UPGRADES ═══ */
@media(min-width:768px){
  .bp-topbar{display:none}
  .bp-sidebar{position:sticky;top:0;height:100vh;transform:none!important;flex-shrink:0}
  .bp-sidebar-close-wrap{display:none}
  .bp-sidebar-overlay{display:none!important}
  .bp-main{padding:22px 26px}
  .bp-stat-row{grid-template-columns:repeat(4,1fr)}
  .bp-overview-grid{grid-template-columns:1fr 1fr}
  .bp-biz-grid{grid-template-columns:repeat(3,1fr)}
  .bp-visit-info-grid{grid-template-columns:repeat(3,1fr)}
  .bp-portal-form-grid{grid-template-columns:repeat(3,1fr)}
  .bp-page-header h2{font-size:24px}
  .bp-p-achiever-cats{flex-direction:row;flex-wrap:wrap}
  .bp-p-ach-cat-block{flex:1;min-width:200px}
  .bp-export-portal-grid{grid-template-columns:1fr 1fr}
  .bp-modal-overlay{align-items:center}
  .bp-modal-sheet{border-radius:16px;max-width:660px}
  /* Site visits desktop table layout */
  .bp-visits-desktop{display:block}
  .bp-visits-cards{display:none}
}
@media(max-width:767px){
  .bp-visits-desktop{display:none}
  .bp-visits-cards{display:block}
  .bp-portal-form-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .bp-portal-form-grid{grid-template-columns:1fr}
  .bp-biz-dates{grid-template-columns:1fr 1fr}
  .bp-pf-field.bp-pf-full{grid-column:1/-1}
}

/* ═══════════════════════════════
   NEW ELEMENTS — v9.1
═══════════════════════════════ */

/* Achiever count badge */
.bp-p-ach-cnt{font-size:13px;font-weight:800;color:var(--p-gold,#fbbf24);min-width:48px;text-align:right;flex-shrink:0;}
.bp-p-ach-row{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--p-border);}
.bp-p-ach-row.top-row{background:rgba(251,191,36,.08);border-left:3px solid var(--p-gold,#fbbf24);}

/* Business download bar */
.bp-biz-dl-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 0;margin-bottom:10px;border-bottom:1px solid var(--p-border);}
.bp-biz-actions{display:flex;flex-wrap:wrap;gap:8px;padding:10px 14px;background:rgba(var(--p-accent-rgb),.04);border-top:1px solid var(--p-border);border-radius:0 0 10px 10px;}

/* Visits download bar */
.bp-visits-dl-bar{background:var(--p-surface);border:1px solid var(--p-border);border-radius:10px;padding:12px 14px;margin-bottom:12px;}
.bp-visits-exp-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 0;margin-bottom:10px;border-bottom:1px solid var(--p-border);}

/* Profile editable sections */
.bp-profile-section-head{display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--p-muted);padding:12px 0 6px;border-top:1px solid var(--p-border);margin-top:8px;}
.bp-profile-section-head:first-of-type{border-top:none;margin-top:0;}
.bp-profile-edit-btn{font-size:11px;padding:3px 10px;border-radius:20px;background:rgba(var(--p-accent-rgb),.12);color:var(--p-accent);border:1px solid rgba(var(--p-accent-rgb),.3);cursor:pointer;font-weight:600;}
.bp-profile-edit-btn:hover{background:rgba(var(--p-accent-rgb),.25);}

/* Toggle switches */
.bp-toggle-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:4px;}
.bp-toggle-row{display:flex;justify-content:space-between;align-items:center;background:var(--p-surface);border:1px solid var(--p-border);border-radius:10px;padding:12px 14px;}
.bp-toggle-label{font-size:13px;font-weight:600;color:var(--p-text);}
.bp-toggle-desc{font-size:11px;color:var(--p-muted);margin-top:2px;}
.bp-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0;}
.bp-switch input{opacity:0;width:0;height:0;}
.bp-switch-slider{position:absolute;cursor:pointer;inset:0;background:#ccc;border-radius:24px;transition:.3s;}
.bp-switch-slider:before{content:'';position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;}
.bp-switch input:checked+.bp-switch-slider{background:var(--p-accent);}
.bp-switch input:checked+.bp-switch-slider:before{transform:translateX(20px);}

/* Settings section titles */
.bp-settings-section-title{font-size:13px;font-weight:700;color:var(--p-text);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--p-accent);}

/* Admin export sections */
.bp-export-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--p-border);}
.bp-export-section:last-child{border-bottom:none;}
.bp-export-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--p-muted);margin-bottom:8px;}
.bp-export-btn-row{display:flex;flex-wrap:wrap;gap:8px;}
.bp-export-btn{padding:8px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--p-border);background:var(--p-surface);color:var(--p-text);}
.bp-export-btn.primary{background:var(--p-accent);color:#fff;border-color:var(--p-accent);}
.bp-export-btn:hover{opacity:.85;}

/* Date quick-select */
.bp-date-opt{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--p-border);background:var(--p-surface);color:var(--p-muted);}
.bp-date-opt.active{background:var(--p-accent);color:#fff;border-color:var(--p-accent);}

/* Receipt print button */
.bp-receipt-btn{font-size:11px;padding:4px 12px;border-radius:20px;background:rgba(var(--p-accent-rgb),.1);color:var(--p-accent);border:1px solid rgba(var(--p-accent-rgb),.3);cursor:pointer;text-decoration:none;font-weight:600;display:inline-block;}
.bp-receipt-btn.primary{background:var(--p-accent);color:#fff;}
.bp-receipt-btn:hover{opacity:.8;}
