/* TMI City Leads — shared stylesheet — mobile first */
@import url('https://fonts.googleapis.com/css2?family=Barlow:wght@300;400;500;600;700;800&display=swap');

:root {
  --bg:#f5f5f7;--surface:#fff;--ink:#1a1a1a;--ink-2:#505060;--muted:#86868b;
  --line:rgba(0,0,0,0.07);--line-strong:rgba(0,0,0,0.13);
  --chart:#E4FF97;--chart-dark:#D0FF6A;
  --red:#ef4444;--green:#22c55e;--blue:#3b82f6;--amber:#f59e0b;--purple:#8b5cf6;
  --serif:"Barlow",system-ui,sans-serif;
  --sans:"Neue Haas Grotesk Display","Neue Haas Grotesk",system-ui,-apple-system,sans-serif;
  --sidebar-w:220px;--topbar-h:52px;--bottom-nav-h:60px;
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --r:8px;--r-sm:5px;--r-lg:12px;
}
*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;height:100%;}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
button,input,select,textarea{font-family:inherit;}
p{margin:0;}

/* ── Layout (mobile: stack, desktop: sidebar+main) ── */
.layout{display:flex;height:100vh;overflow:hidden;}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;}

/* ── Sidebar (hidden on mobile, shown desktop) ── */
.sidebar{display:none;width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);flex-direction:column;height:100vh;overflow-y:auto;}
.sb-brand{padding:0 20px;height:var(--topbar-h);display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);flex-shrink:0;}
.sb-brand img{height:22px;}
.sb-brand-label{font-size:13px;font-weight:700;color:var(--ink);line-height:1.1;}
.sb-brand-sub{font-size:10px;color:var(--muted);letter-spacing:0.15em;text-transform:uppercase;line-height:1;}
.sb-nav{flex:1;padding:12px 8px;}
.sb-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-sm);font-size:13px;color:var(--ink-2);transition:background 0.12s,color 0.12s;cursor:pointer;margin-bottom:1px;white-space:nowrap;}
.sb-item:hover{background:var(--bg);color:var(--ink);}
.sb-item.active{background:var(--chart);color:var(--ink);font-weight:600;}
.sb-item svg{width:15px;height:15px;flex-shrink:0;}
.sb-sep{height:1px;background:var(--line);margin:8px 12px;}
.sb-foot{padding:10px 8px;border-top:1px solid var(--line);flex-shrink:0;}
.sb-logout{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-sm);font-size:13px;color:var(--muted);cursor:pointer;transition:color 0.12s,background 0.12s;background:none;border:none;width:100%;}
.sb-logout:hover{color:var(--red);background:#fef2f2;}
.sb-group-label{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);padding:10px 12px 4px;font-weight:600;}
.sb-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--chart);color:var(--ink);font-size:10px;font-weight:700;line-height:1;margin-left:auto;}

/* ── Topbar ── */
.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 16px;gap:12px;flex-shrink:0;}
.topbar-crumb{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px;flex:1;min-width:0;}
.topbar-crumb .page{color:var(--ink);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.topbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}

/* ── Content area ── */
.content{flex:1;overflow-y:auto;padding:16px 16px calc(var(--bottom-nav-h) + var(--safe-bottom) + 16px) 16px;}

/* ── Bottom nav (primary on mobile) ── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--line);z-index:150;padding-bottom:var(--safe-bottom);}
.bottom-nav-inner{display:flex;height:var(--bottom-nav-h);}
.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:9px;letter-spacing:0.05em;text-transform:uppercase;font-weight:600;color:var(--muted);cursor:pointer;background:none;border:none;font-family:inherit;text-decoration:none;transition:color 0.15s;position:relative;padding:0;}
.bn-item.active{color:var(--ink);}
.bn-item svg{width:22px;height:22px;}
.bn-badge{position:absolute;top:6px;right:calc(50% - 20px);background:var(--chart);color:var(--ink);font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:999px;display:none;align-items:center;justify-content:center;padding:0 3px;line-height:1;}

/* ── More sheet (slide up from bottom) ── */
.more-sheet-overlay{display:none;position:fixed;inset:0;z-index:200;}
.more-sheet-overlay.open{display:block;}
.more-sheet-bg{position:absolute;inset:0;background:rgba(0,0,0,0.45);}
.more-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--surface);border-radius:18px 18px 0 0;padding-bottom:var(--safe-bottom);max-height:85vh;overflow-y:auto;transform:translateY(100%);transition:transform 0.3s cubic-bezier(.2,.8,.2,1);}
.more-sheet-overlay.open .more-sheet{transform:translateY(0);}
.more-sheet-grip{width:36px;height:4px;background:var(--line-strong);border-radius:2px;margin:12px auto 4px;}
.more-sheet-group{padding:0 12px 8px;}
.more-sheet-group-label{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);padding:10px 8px 4px;font-weight:600;display:block;}
.more-sheet-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--r-sm);font-size:14px;color:var(--ink-2);text-decoration:none;transition:background 0.1s,color 0.1s;}
.more-sheet-item:hover,.more-sheet-item:active{background:var(--bg);color:var(--ink);}
.more-sheet-item.active{background:var(--chart);color:var(--ink);font-weight:600;}
.more-sheet-item svg{width:18px;height:18px;flex-shrink:0;opacity:0.6;}
.more-sheet-item.active svg{opacity:1;}
.more-sheet-logout{display:flex;align-items:center;gap:12px;padding:14px 20px;font-size:14px;color:var(--muted);cursor:pointer;background:none;border:none;border-top:1px solid var(--line);width:100%;font-family:inherit;margin-top:4px;}
.more-sheet-logout:hover{color:var(--red);}

/* ── Stats ── */
.stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;}
.stat-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;}
.stat-label{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;}
.stat-val{font-family:var(--serif);font-size:28px;font-weight:700;color:var(--ink);line-height:1;margin-bottom:2px;}
.stat-delta{font-size:12px;color:var(--muted);}
.stat-delta.pos{color:#16a34a;}
.stat-delta.neg{color:var(--red);}

/* ── Cards ── */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);}
.card-head{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;}
.card-title{font-size:13px;font-weight:600;color:var(--ink);}
.card-sub{font-size:12px;color:var(--muted);}

/* ── Section header ── */
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:8px;}
.sec-head h1{font-family:var(--serif);font-size:24px;font-weight:400;margin:0;letter-spacing:-0.02em;}
.sec-head-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}

/* ── Tables ── */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
table{width:100%;border-collapse:collapse;}
thead th{padding:10px 14px;text-align:left;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);font-weight:500;white-space:nowrap;}
tbody td{padding:12px 14px;font-size:13px;color:var(--ink-2);border-bottom:1px solid var(--line);}
tbody tr:last-child td{border-bottom:none;}
tbody tr{cursor:pointer;transition:background 0.1s;}
tbody tr:hover td{background:#fafafa;color:var(--ink);}
.td-name{font-weight:500;color:var(--ink) !important;}
.td-muted{color:var(--muted) !important;font-size:12px !important;}
.td-action{text-align:right;}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:0.04em;white-space:nowrap;text-transform:capitalize;}
/* Pipeline stage badges */
.badge-seed{background:#f3f4f6;color:#6b7280;}
.badge-met_owner,.badge-met-owner{background:#dbeafe;color:#1d4ed8;}
.badge-second_visit,.badge-second-visit{background:#ede9fe;color:#6d28d9;}
.badge-problem_identified,.badge-problem-identified{background:#fef9c3;color:#854d0e;}
.badge-warm{background:#ffedd5;color:#c2410c;}
.badge-audit_booked,.badge-audit-booked{background:#fce7f3;color:#9d174d;}
.badge-proposal_sent,.badge-proposal-sent{background:#e0f2fe;color:#0369a1;}
.badge-closed{background:#dcfce7;color:#15803d;}
.badge-build_live,.badge-build-live{background:#d1fae5;color:#065f46;}
.badge-support_active,.badge-support-active{background:#d1fae5;color:#065f46;}
.badge-expansion{background:var(--chart);color:var(--ink);}
/* Score badges */
.badge-hot{background:#fee2e2;color:#b91c1c;}
.badge-warm-score{background:#fef9c3;color:#854d0e;}
.badge-cold{background:#f3f4f6;color:#6b7280;}
/* Standard */
.badge-new{background:#dbeafe;color:#1d4ed8;}
.badge-contacted{background:#ede9fe;color:#6d28d9;}
.badge-active{background:#dcfce7;color:#15803d;}
.badge-won{background:#dcfce7;color:#15803d;}
.badge-lost{background:#f3f4f6;color:#6b7280;}
.badge-pending{background:#fef9c3;color:#854d0e;}
.badge-paid{background:#dcfce7;color:#15803d;}
.badge-draft{background:#f3f4f6;color:#6b7280;}

/* ── Buttons (44px min touch target) ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 18px;border-radius:var(--r-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all 0.15s;border:none;line-height:1;white-space:nowrap;min-height:44px;}
.btn-primary{background:var(--chart);color:var(--ink);}
.btn-primary:hover{background:var(--chart-dark);}
.btn-ghost{background:none;border:1px solid var(--line-strong);color:var(--ink-2);}
.btn-ghost:hover{background:var(--bg);color:var(--ink);border-color:var(--ink-2);}
.btn-danger{background:#fee2e2;color:#b91c1c;}
.btn-danger:hover{background:#fecaca;}
.btn-sm{padding:8px 14px;font-size:12px;min-height:36px;}
.btn-lg{padding:14px 24px;font-size:15px;min-height:52px;}
.btn-full{width:100%;justify-content:center;}
.btn svg{width:15px;height:15px;}
.btn-fab{position:fixed;bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 16px);right:16px;width:56px;height:56px;border-radius:50%;background:var(--chart);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,0.2);z-index:100;transition:transform 0.15s,background 0.15s;}
.btn-fab:hover{transform:scale(1.05);background:var(--chart-dark);}
.btn-fab svg{width:24px;height:24px;}

/* ── Filter bar ── */
.filter-bar{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.filter-row{display:flex;gap:8px;align-items:center;}
.search-wrap{position:relative;flex:1;}
.search-wrap input{padding:10px 12px 10px 36px;border:1px solid var(--line-strong);border-radius:var(--r-sm);font-size:14px;outline:none;background:var(--surface);width:100%;color:var(--ink);min-height:44px;}
.search-wrap input:focus{border-color:var(--ink);}
.search-wrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--muted);pointer-events:none;}
.filter-select{padding:10px 28px 10px 12px;border:1px solid var(--line-strong);border-radius:var(--r-sm);font-size:13px;outline:none;background:var(--surface);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%2386868b' d='M8 10.5L3 5.5h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:14px;cursor:pointer;color:var(--ink-2);min-height:44px;}
.filter-count{font-size:13px;color:var(--muted);white-space:nowrap;}

/* ── Forms ── */
.form-group{margin-bottom:16px;}
.form-label{display:block;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:6px;}
.form-input{width:100%;padding:11px 12px;border:1px solid var(--line-strong);border-radius:var(--r-sm);font-size:15px;color:var(--ink);background:var(--surface);transition:border-color 0.15s,box-shadow 0.15s;outline:none;min-height:44px;}
.form-input:focus{border-color:#666;box-shadow:0 0 0 3px rgba(0,0,0,0.05);}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%2386868b' d='M8 10.5L3 5.5h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px;padding-right:32px;cursor:pointer;}
textarea.form-input{resize:vertical;min-height:100px;line-height:1.6;}
.form-row{display:grid;grid-template-columns:1fr;gap:12px;}
.form-hint{font-size:11px;color:var(--muted);margin-top:4px;}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:300;opacity:0;pointer-events:none;transition:opacity 0.2s;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--surface);border-radius:20px 20px 0 0;padding:24px 20px calc(24px + var(--safe-bottom)) 20px;width:100%;max-width:100%;max-height:92vh;overflow-y:auto;transform:translateY(10px);transition:transform 0.25s cubic-bezier(.2,.8,.2,1);}
.modal-overlay.open .modal{transform:translateY(0);}
.modal-grip{width:36px;height:4px;background:var(--line-strong);border-radius:2px;margin:0 auto 20px;}
.modal-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.modal-title{font-family:var(--serif);font-size:22px;font-weight:400;margin:0;}
.modal-x{background:none;border:none;font-size:24px;cursor:pointer;color:var(--muted);padding:0;line-height:1;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg);}
.modal-x:hover{color:var(--ink);}
.modal-ft{display:flex;flex-direction:column;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line);}

/* ── Slide panel (full screen on mobile) ── */
.panel-overlay{position:fixed;inset:0;z-index:250;display:none;}
.panel-overlay.open{display:block;}
.panel-bg{position:absolute;inset:0;background:rgba(0,0,0,0.3);}
.panel{position:absolute;top:0;right:0;bottom:0;width:100%;max-width:100%;background:var(--surface);overflow-y:auto;transform:translateX(100%);transition:transform 0.25s cubic-bezier(.2,.8,.2,1);}
.panel-overlay.open .panel{transform:translateX(0);}
.panel-hd{padding:16px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--surface);z-index:1;}
.panel-title{font-family:var(--serif);font-size:20px;font-weight:400;margin:0;}
.panel-actions{display:flex;gap:8px;}
.panel-body{padding:16px;}
.panel-sep{height:1px;background:var(--line);margin:16px 0;}
.panel-sec-label{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px;}
.detail-label{font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);margin-bottom:3px;}
.detail-val{font-size:14px;color:var(--ink);}

/* ── Toast ── */
#toast-root{position:fixed;bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 12px);right:12px;left:12px;z-index:999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.toast{padding:12px 18px;border-radius:var(--r-sm);font-size:13px;font-weight:500;box-shadow:0 4px 20px rgba(0,0,0,0.15);transform:translateY(8px);opacity:0;transition:all 0.25s;pointer-events:none;text-align:center;}
.toast.visible{transform:translateY(0);opacity:1;}
.toast.success{background:var(--ink);color:#fff;}
.toast.error{background:#b91c1c;color:#fff;}
.toast.info{background:#1d4ed8;color:#fff;}

/* ── Empty state ── */
.empty-state{padding:48px 20px;text-align:center;}
.empty-icon{font-size:40px;margin-bottom:12px;}
.empty-state h3{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--ink-2);margin:0 0 8px;}
.empty-state p{font-size:14px;color:var(--muted);margin:0 0 20px;}

/* ── Login ── */
.login-page{min-height:100vh;display:flex;align-items:flex-end;justify-content:center;background:var(--bg);padding:0 0 0 0;}
.login-card{background:var(--surface);border-radius:20px 20px 0 0;padding:36px 24px calc(36px + var(--safe-bottom)) 24px;width:100%;max-width:480px;}
.login-logo{display:flex;flex-direction:column;gap:4px;margin-bottom:32px;}
.login-wordmark{font-size:22px;font-weight:800;color:var(--ink);letter-spacing:-0.02em;font-family:var(--sans);}
.login-logo-sub{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);}
.demo-btn{width:100%;padding:12px;border:1px dashed var(--line-strong);border-radius:var(--r);background:none;font-size:13px;color:var(--muted);cursor:pointer;margin-top:12px;transition:all 0.15s;font-family:var(--sans);}
.demo-btn:hover{border-color:var(--ink-2);color:var(--ink);background:var(--bg);}
.login-title{font-family:var(--serif);font-size:28px;font-weight:400;margin:0 0 6px;}
.login-sub{font-size:14px;color:var(--muted);margin:0 0 28px;line-height:1.5;}
.login-error{background:#fee2e2;color:#b91c1c;padding:12px 14px;border-radius:var(--r-sm);font-size:13px;margin-bottom:16px;display:none;}

/* ── Kanban board ── */
.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;align-items:flex-start;-webkit-overflow-scrolling:touch;}
.kanban-col{flex:0 0 200px;background:var(--bg);border-radius:var(--r);border:1px solid var(--line);}
.kanban-col-head{padding:10px 12px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;}
.kanban-col-title{font-size:11px;font-weight:600;color:var(--ink-2);text-transform:uppercase;letter-spacing:0.1em;}
.kanban-count{font-size:11px;color:var(--muted);background:var(--surface);padding:2px 7px;border-radius:999px;border:1px solid var(--line);}
.kanban-cards{padding:8px;display:flex;flex-direction:column;gap:8px;min-height:60px;}
.kanban-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:12px;cursor:pointer;transition:box-shadow 0.15s;}
.kanban-card:hover{box-shadow:0 2px 10px rgba(0,0,0,0.08);}
.kanban-card-name{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:4px;}
.kanban-card-meta{font-size:11px;color:var(--muted);}
.kanban-card-val{font-size:12px;color:var(--ink-2);margin-top:6px;font-weight:600;}

/* ── Timeline ── */
.tl-list{list-style:none;margin:0;padding:0;position:relative;}
.tl-list::before{content:'';position:absolute;left:7px;top:8px;bottom:8px;width:1px;background:var(--line);}
.tl-item{display:flex;gap:16px;padding:0 0 20px;position:relative;}
.tl-item:last-child{padding-bottom:0;}
.tl-dot{width:15px;height:15px;border-radius:50%;background:var(--surface);border:2px solid var(--line);flex-shrink:0;margin-top:2px;position:relative;z-index:1;}
.tl-dot.chart{background:var(--chart);border-color:var(--chart);}
.tl-dot.blue{background:var(--blue);border-color:var(--blue);}
.tl-dot.green{background:var(--green);border-color:var(--green);}
.tl-dot.red{background:var(--red);border-color:var(--red);}
.tl-body{flex:1;min-width:0;}
.tl-title{font-size:13px;font-weight:500;color:var(--ink);line-height:1.3;margin-bottom:2px;}
.tl-text{font-size:12px;color:var(--ink-2);line-height:1.5;}
.tl-time{font-size:11px;color:var(--muted);margin-top:4px;}

/* ── Business list item (swipeable) ── */
.biz-list{list-style:none;margin:0;padding:0;}
.biz-item{background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;transition:background 0.1s;text-decoration:none;}
.biz-item:first-child{border-radius:var(--r) var(--r) 0 0;}
.biz-item:last-child{border-bottom:none;border-radius:0 0 var(--r) var(--r);}
.biz-item:hover,.biz-item:active{background:var(--bg);}
.biz-avatar{width:40px;height:40px;border-radius:10px;background:var(--bg);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:var(--ink-2);flex-shrink:0;}
.biz-body{flex:1;min-width:0;}
.biz-name{font-size:14px;font-weight:500;color:var(--ink);line-height:1.2;margin-bottom:2px;}
.biz-meta{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.biz-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;}

/* ── Score dot ── */
.score-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.score-dot.hot{background:#ef4444;}
.score-dot.warm{background:#f59e0b;}
.score-dot.cold{background:#d1d5db;}

/* ── Quick capture (mobile hero component) ── */
.capture-card{background:var(--surface);border-radius:16px;border:1px solid var(--line);overflow:hidden;margin-bottom:16px;}
.capture-hero{background:var(--ink);padding:20px 16px;display:flex;align-items:center;gap:12px;}
.capture-hero-icon{width:44px;height:44px;background:var(--chart);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.capture-hero-icon svg{width:22px;height:22px;color:var(--ink);}
.capture-hero-text{color:#fff;}
.capture-hero-title{font-size:15px;font-weight:600;line-height:1.2;}
.capture-hero-sub{font-size:12px;opacity:0.6;margin-top:2px;}
.capture-body{padding:16px;}
.capture-tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;}
.capture-tag{padding:8px 14px;border:1px solid var(--line-strong);border-radius:999px;font-size:13px;cursor:pointer;transition:all 0.12s;color:var(--ink-2);background:none;min-height:36px;}
.capture-tag.active{background:var(--ink);color:#fff;border-color:var(--ink);}

/* ── Map container ── */
.map-container{width:100%;height:calc(100vh - var(--topbar-h) - var(--bottom-nav-h) - var(--safe-bottom));background:#e8ecef;}
.map-search-bar{position:absolute;top:calc(var(--topbar-h) + 12px);left:12px;right:12px;z-index:10;background:var(--surface);border-radius:var(--r);border:1px solid var(--line);display:flex;align-items:center;gap:8px;padding:0 12px;box-shadow:0 2px 12px rgba(0,0,0,0.15);}
.map-search-bar input{flex:1;border:none;outline:none;font-size:14px;padding:12px 0;background:transparent;color:var(--ink);}

/* ── Relationship heat card ── */
.heat-card{background:var(--surface);border-radius:var(--r);border:1px solid var(--line);padding:14px;display:flex;align-items:center;gap:12px;margin-bottom:8px;cursor:pointer;transition:background 0.1s;}
.heat-card:hover,.heat-card:active{background:var(--bg);}
.heat-bar{width:4px;border-radius:2px;height:40px;flex-shrink:0;}
.heat-bar.hot{background:#ef4444;}
.heat-bar.warm{background:#f59e0b;}
.heat-bar.cold{background:#d1d5db;}
.heat-body{flex:1;min-width:0;}
.heat-name{font-size:14px;font-weight:500;color:var(--ink);}
.heat-meta{font-size:12px;color:var(--muted);margin-top:2px;}
.heat-days{font-size:12px;font-weight:600;flex-shrink:0;}
.heat-days.hot{color:#ef4444;}
.heat-days.warm{color:#f59e0b;}
.heat-days.cold{color:var(--muted);}

/* ── Commission calculator ── */
.calc-result{background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:24px;margin-top:20px;text-align:center;}
.calc-result-label{font-size:12px;letter-spacing:0.15em;text-transform:uppercase;opacity:0.6;margin-bottom:8px;}
.calc-result-val{font-family:var(--serif);font-size:48px;font-weight:700;color:var(--chart);line-height:1;}
.calc-result-sub{font-size:13px;opacity:0.6;margin-top:8px;}

/* ── Leaderboard ── */
.lb-item{background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;padding:14px 16px;}
.lb-rank{width:28px;text-align:center;font-size:14px;font-weight:700;color:var(--muted);flex-shrink:0;}
.lb-rank.first{color:var(--amber);}
.lb-rank.second{color:var(--ink-2);}
.lb-rank.third{color:#cd7c2e;}
.lb-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--ink-2);flex-shrink:0;}
.lb-body{flex:1;min-width:0;}
.lb-name{font-size:14px;font-weight:500;color:var(--ink);}
.lb-city{font-size:12px;color:var(--muted);}
.lb-val{font-size:16px;font-weight:700;color:var(--ink);flex-shrink:0;}

/* ── Chat ── */
.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - var(--topbar-h) - var(--bottom-nav-h) - var(--safe-bottom));}
.chat-messages{flex:1;overflow-y:auto;padding:16px;}
.chat-bubble-wrap{display:flex;gap:8px;margin-bottom:12px;align-items:flex-end;}
.chat-bubble-wrap.me{flex-direction:row-reverse;}
.chat-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;}
.chat-bubble{max-width:75%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.4;}
.chat-bubble.them{background:var(--surface);border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:4px;}
.chat-bubble.me{background:var(--ink);color:#fff;border-bottom-right-radius:4px;}
.chat-time{font-size:10px;color:var(--muted);margin-top:4px;text-align:center;}
.chat-input-bar{padding:10px 12px calc(10px + var(--safe-bottom)) 12px;border-top:1px solid var(--line);background:var(--surface);display:flex;gap:8px;align-items:flex-end;}
.chat-input-bar textarea{flex:1;border:1px solid var(--line-strong);border-radius:20px;padding:10px 14px;font-size:14px;outline:none;resize:none;min-height:40px;max-height:120px;line-height:1.4;background:var(--bg);}

/* ── Playbook ── */
.playbook-section{margin-bottom:24px;}
.playbook-section-title{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--ink);margin:0 0 12px;letter-spacing:-0.01em;}
.playbook-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px;margin-bottom:8px;}
.playbook-card-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px;}
.playbook-card-body{font-size:14px;color:var(--ink-2);line-height:1.6;}
.playbook-tag{display:inline-flex;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;background:var(--chart);color:var(--ink);margin-bottom:8px;}

/* ── Follow-up card ── */
.fu-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px;margin-bottom:10px;}
.fu-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px;}
.fu-biz{font-size:14px;font-weight:600;color:var(--ink);}
.fu-due{font-size:11px;color:var(--muted);}
.fu-message{font-size:14px;color:var(--ink-2);line-height:1.5;background:var(--bg);border-radius:var(--r-sm);padding:12px;margin-bottom:12px;}
.fu-actions{display:flex;gap:8px;}

/* ── AI chat ── */
.ai-msg{background:var(--surface);border:1px solid var(--line);border-radius:12px;border-bottom-left-radius:3px;padding:14px;margin-bottom:10px;font-size:14px;color:var(--ink-2);line-height:1.6;}
.user-msg{background:var(--ink);color:#fff;border-radius:12px;border-bottom-right-radius:3px;padding:14px;margin-bottom:10px;font-size:14px;line-height:1.5;align-self:flex-end;max-width:85%;}

/* ── Owner lookup result ── */
.lookup-result{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-top:16px;}
.lookup-result-header{background:var(--ink);padding:16px;color:#fff;}
.lookup-result-name{font-size:18px;font-weight:600;margin-bottom:2px;}
.lookup-result-biz{font-size:13px;opacity:0.7;}
.lookup-result-body{padding:16px;}
.lookup-field{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);}
.lookup-field:last-child{border-bottom:none;}
.lookup-field svg{width:16px;height:16px;color:var(--muted);flex-shrink:0;}
.lookup-field-val{font-size:14px;color:var(--ink);}

/* ── Desktop overrides (sidebar shows, bottom nav hides) ── */
@media(min-width:769px){
  .sidebar{display:flex;}
  .bottom-nav{display:none;}
  .content{padding:28px 32px;}
  .btn-fab{bottom:24px;}
  #toast-root{bottom:24px;right:24px;left:auto;width:auto;}
  .toast{text-align:left;}
  .modal{border-radius:var(--r-lg);padding:32px;max-width:560px;max-height:88vh;}
  .modal-overlay{align-items:center;}
  .modal-grip{display:none;}
  .modal-ft{flex-direction:row;justify-content:flex-end;}
  .panel{width:480px;}
  .filter-bar{flex-direction:row;align-items:center;}
  .filter-row{flex:1;}
  .form-row{grid-template-columns:1fr 1fr;}
  .stats-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
  .stat-val{font-size:34px;}
  .kanban-col{flex:0 0 240px;}
  .topbar{padding:0 28px;}
  .sec-head h1{font-size:28px;}
}
@media(min-width:769px) and (max-width:1024px){
  .stats-row{grid-template-columns:repeat(2,1fr);}
}
