/* ============================================================
   Runwell Sales UI - Shared Design System
   Used by: Sales Dashboard + Internal Studio
   ============================================================ */

/* THEME TOKENS */
:root {
  --t: #FF6B35; --t-dim: #CC5529; --t-glow: rgba(255,107,53,.10); --t-glow2: rgba(255,107,53,.18);
  --b: #4A7CFF; --b-dim: #3A63CC; --b-glow: rgba(74,124,255,.10);
  --g: #F5C542; --g-dim: #C49E35; --g-glow: rgba(245,197,66,.12);
  --bg: #F9F8F7; --surf: #FFFFFF; --raised: #F3F1F6; --border: #E5E2EB;
  --tx: #1C1726; --tx2: #6B6578; --tx3: #9B95A8;
  --shadow: 0 1px 3px rgba(0,0,0,.06); --shadow-h: 0 4px 12px rgba(0,0,0,.1);
  --rad: 8px; --rad-lg: 12px;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: 'SF Mono', 'Fira Code', monospace;
  --topbar: 46px;
}
[data-theme="dark"] {
  --bg: #121018; --surf: #1C1726; --raised: #252031; --border: #332D40;
  --tx: #F2F0F5; --tx2: #9B95A8; --tx3: #6B6578;
  --t-glow: rgba(255,107,53,.15); --t-glow2: rgba(255,107,53,.25);
  --shadow: none; --shadow-h: none;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);background:var(--bg);color:var(--tx);line-height:1.6;overflow:hidden}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* TOPBAR */
.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar);background:var(--surf);border-bottom:1px solid var(--border);display:flex;align-items:stretch;z-index:200;padding:0}
.tb-brand{display:flex;align-items:center;padding:0 16px;gap:8px;font-size:12.5px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;color:var(--tx);border-right:1px solid var(--border);box-sizing:border-box;flex-shrink:0}
.tb-logo{flex-shrink:0;border-radius:50%;box-shadow:0 0 0 1px var(--border)}
.tb-label{word-spacing:-1px}
.tb-label span{color:var(--t)}
.tab-nav{display:flex;align-items:stretch;flex:1;overflow-x:auto}
.tab-nav::-webkit-scrollbar{height:0}
.tab-btn{display:flex;align-items:center;font-size:12px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;padding:0 18px;border:none;background:none;color:var(--tx3);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;font-family:var(--font);transition:color .12s,border-color .12s;margin-bottom:-1px;text-decoration:none}
.tab-btn:hover{color:var(--tx)}
.tab-btn.active{color:var(--t);border-bottom-color:var(--t)}
.tb-actions{display:flex;align-items:center;gap:8px;padding:0 16px;border-left:1px solid var(--border)}
.tb-search{padding:5px 11px;border-radius:20px;border:1px solid var(--border);background:var(--raised);font-size:12px;color:var(--tx);font-family:var(--font);outline:none;width:190px;transition:border-color .12s}
.tb-search:focus{border-color:var(--t)}
.tb-search::placeholder{color:var(--tx3)}
.theme-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:7px;border:1px solid var(--border);background:var(--raised);color:var(--tx2);cursor:pointer;font-size:15px;transition:all .12s;flex-shrink:0}
.theme-btn:hover{border-color:var(--t);color:var(--t)}

/* PAGES */
.page{position:fixed;top:var(--topbar);left:0;right:0;bottom:0;display:none;overflow:hidden}
.page.active{display:flex;flex-direction:column}

/* SHARED: PILLS / FILTERS */
.pill-row{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.pill{font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:4px 11px;border:1px solid var(--border);border-radius:20px;cursor:pointer;color:var(--tx3);background:none;font-family:var(--font);transition:background .12s,color .12s,border-color .12s;white-space:nowrap}
.pill:hover{color:var(--tx);border-color:var(--tx3)}
.pill.active{background:var(--t);color:#fff;border-color:var(--t)}

/* SHARED: STAT PILLS */
.stat-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.stat-pill{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--surf);border:1px solid var(--border);border-radius:20px;font-size:12.5px;box-shadow:var(--shadow)}
.stat-pill strong{color:var(--t);font-weight:700}

/* SHARED: BADGES */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:4px 10px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.badge-proven{background:rgba(74,190,152,.12);color:#1a8f64;border:1px solid rgba(74,190,152,.25)}
.badge-primed{background:var(--t-glow);color:var(--t);border:1px solid rgba(255,107,53,.3)}
.badge-experimental{background:var(--g-glow);color:var(--g);border:1px solid rgba(245,197,66,.3)}
.badge-untested{background:var(--raised);color:var(--tx3);border:1px solid var(--border)}

/* SHARED: CARDS */
.card{background:var(--surf);border:1px solid var(--border);border-radius:var(--rad-lg);padding:18px;cursor:pointer;transition:all .14s;box-shadow:var(--shadow)}
.card:hover{border-color:var(--t-dim);box-shadow:var(--shadow-h);transform:translateY(-1px)}
.card-title{font-size:14px;font-weight:700;margin-bottom:4px}
.card-meta{font-size:12px;color:var(--tx3)}
.card-desc{font-size:12px;color:var(--tx3);margin-top:6px;line-height:1.5}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:10px}

/* SHARED: SPINNER */
.spin{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--t);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* SHARED: EMPTY STATE */
.empty-state{padding:60px;text-align:center;color:var(--tx3);font-size:13px}

/* SHARED: OVERLAY + SLIDE PANEL */
.slide-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:none}
.slide-overlay.open{display:block}
.slide-panel{position:fixed;top:var(--topbar);right:0;bottom:0;width:460px;max-width:100vw;background:var(--surf);border-left:1px solid var(--border);z-index:301;transform:translateX(100%);transition:transform .2s ease;overflow-y:auto;display:flex;flex-direction:column}
.slide-panel.open{transform:translateX(0)}
.slide-panel-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.slide-panel-close{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--raised);color:var(--tx2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .1s}
.slide-panel-close:hover{border-color:var(--t);color:var(--t)}
.slide-panel-title{font-size:13px;font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.slide-panel-body{flex:1;overflow-y:auto;padding:16px}

/* SHARED: SECTION HEADERS */
.section-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--tx3);line-height:1}
.section-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}

/* SHARED: DETAIL SECTIONS (used in panels) */
.detail-section{margin-bottom:16px}
.detail-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--tx3);margin-bottom:6px}
.detail-row{display:flex;gap:8px;padding:4px 0;font-size:12px}
.detail-label{color:var(--tx3);min-width:80px;flex-shrink:0}
.detail-value{color:var(--tx);font-weight:500}

/* SHARED: TAG CHIPS */
.tag-chip{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;background:var(--raised);color:var(--tx3);border:1px solid var(--border);display:inline-block;margin:1px}

/* SHARED: COLOR-CODED TAGS */
.tag{font-size:9px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;padding:1px 6px;border-radius:3px}
.tag-p0{background:rgba(239,68,68,.12);color:#ef4444;border:1px solid rgba(239,68,68,.25)}
.tag-p1{background:var(--g-glow);color:var(--g-dim);border:1px solid rgba(245,197,66,.25)}
.tag-p2{background:var(--raised);color:var(--tx3);border:1px solid var(--border)}
.tag-src{background:var(--b-glow);color:var(--b);border:1px solid rgba(74,124,255,.2)}
.tag-cat{background:var(--raised);color:var(--tx3);border:1px solid var(--border)}
.tag-stale{background:rgba(239,68,68,.12);color:#ef4444;border:1px solid rgba(239,68,68,.25)}

/* ============================================================
   LEAD SCOUT TAB
   ============================================================ */
#page-leadscout{flex-direction:column;overflow:hidden}
.ls-topbar{flex-shrink:0;padding:10px 24px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;align-items:center;gap:12px}
.ls-run-selector{display:flex;align-items:center;gap:8px}
.ls-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--tx3);line-height:1}
.ls-actions{margin-left:auto;display:flex;gap:8px}
.ls-export-btn{font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:5px 14px;border:1px solid var(--t);border-radius:20px;background:none;color:var(--t);cursor:pointer;font-family:var(--font);transition:all .12s}
.ls-export-btn:hover,.ls-export-btn.active{background:var(--t);color:#fff}
.ls-dashboard{flex:1;overflow-y:auto;padding:0 24px 48px}
.ls-empty{padding:60px;text-align:center;color:var(--tx3);font-size:13px}

/* Lead Scout: Funnel */
.ls-funnel{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin:18px 0}
.ls-funnel-step{display:flex;flex-direction:column;align-items:center;padding:10px 16px;background:var(--surf);border:1px solid var(--border);border-radius:var(--rad);min-width:80px;box-shadow:var(--shadow)}
.ls-funnel-val{font-size:20px;font-weight:800;font-family:var(--mono);color:var(--t)}
.ls-funnel-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3);margin-top:2px}
.ls-funnel-arrow{color:var(--tx3);font-size:12px}

/* Lead Scout: Stats */
.ls-stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.ls-stat{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--surf);border:1px solid var(--border);border-radius:20px;font-size:12px;box-shadow:var(--shadow)}
.ls-stat strong{color:var(--t);font-weight:700;font-family:var(--mono)}

/* Lead Scout: Campaign Section */
.ls-camp-section{margin-bottom:18px;border:1px solid var(--border);border-radius:var(--rad-lg);overflow:hidden;background:var(--surf)}
.ls-camp-head{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;transition:background .12s;user-select:none}
.ls-camp-head:hover{background:var(--raised)}
.ls-camp-title{font-size:13px;font-weight:700;flex:1}
.ls-camp-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;background:var(--raised);color:var(--tx2)}
.ls-camp-chevron{font-size:10px;color:var(--tx3);transition:transform .18s}
.ls-camp-section.open .ls-camp-chevron{transform:rotate(90deg)}
.ls-camp-body{display:none;border-top:1px solid var(--border);overflow-x:auto}
.ls-camp-section.open .ls-camp-body{display:block}
.ls-camp-table{width:100%;border-collapse:collapse;font-size:11px}
.ls-camp-table th{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:7px 10px;border-bottom:1px solid var(--border);text-align:left;color:var(--tx3);white-space:nowrap}
.ls-camp-table td{padding:6px 10px;border-bottom:1px solid var(--border);color:var(--tx2);white-space:nowrap}
.ls-camp-table tr:last-child td{border-bottom:none}

/* Lead Scout: Filter Bar */
.ls-filter-bar{flex-shrink:0;padding:8px 24px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;flex-direction:column;gap:4px}
.ls-filter-bar:empty{display:none}
.filter-toggle-btn{font-size:9px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:2px 8px;border:none;border-radius:4px;cursor:pointer;color:var(--tx3);background:none;font-family:var(--font);align-self:flex-end;margin:-2px 0}
.filter-toggle-btn:hover{color:var(--t)}
.filter-collapsible{display:flex;flex-direction:column;gap:4px}
.ls-filter-row{display:flex;gap:4px;flex-wrap:wrap;align-items:center;line-height:1;padding:0;margin:0}
.ls-pill{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:2px 9px;border:1px solid var(--border);border-radius:20px;cursor:pointer;color:var(--tx3);background:none;font-family:var(--font);transition:all .12s;white-space:nowrap;line-height:1;box-sizing:border-box}
.ls-pill:hover{color:var(--tx);border-color:var(--tx3)}
.ls-pill.active{background:var(--t);color:#fff;border-color:var(--t)}
.ls-score-range{display:flex;align-items:center;gap:6px}
.ls-score-range input[type=range]{width:100px;accent-color:var(--t)}
.ls-score-val{font-size:10px;font-weight:700;font-family:var(--mono);color:var(--t);min-width:24px}
.ls-view-count{font-size:10px;color:var(--tx3);margin-left:auto;font-weight:600;letter-spacing:.3px}

/* Lead Scout: Column Headers */
.ls-col-headers{position:sticky;top:0;z-index:10;border-bottom:1px solid var(--border);margin:0 -24px;padding:0 24px;background:var(--bg)}
.ls-col-hdr{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 8px;color:var(--tx3);cursor:pointer;user-select:none;white-space:nowrap;transition:color .1s;display:inline-flex;align-items:center;gap:3px;line-height:1}
.ls-col-hdr:hover{color:var(--t)}
.ls-col-hdr.sorted{color:var(--t)}
.ls-col-hdr .sort-arrow{font-size:8px;opacity:.5}
.ls-col-hdr.sorted .sort-arrow{opacity:1}

/* Lead Scout: Table */
.ls-table{width:100%;border-collapse:collapse;table-layout:fixed}
.ls-table td{padding:5px 8px;border-bottom:1px solid var(--border);font-size:11px;color:var(--tx2);white-space:nowrap}
.ls-table tr{cursor:pointer;transition:background .08s}
.ls-table tr:hover{background:var(--raised)}
.ls-table tr.ls-active{background:var(--t-glow)}
.ls-table tr.ls-chain{opacity:.35}
.ls-table tr.ls-hidden{display:none}

/* Lead Scout: Prospect Cell */
.ls-prospect-cell{display:flex;align-items:center;gap:5px}
.ls-pv{font-size:13px;font-weight:800;font-family:var(--mono)}
.ls-tier{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:1px 5px;border-radius:3px}
.ls-tier-hot{color:var(--t);background:var(--t-glow);border:1px solid var(--t)}
.ls-tier-warm{color:var(--g-dim);background:var(--g-glow);border:1px solid var(--g-dim)}
.ls-tier-cold{color:var(--tx3);background:var(--raised);border:1px solid var(--border)}
.ls-qual{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;font-size:10px;font-weight:800;font-family:var(--mono)}
.ls-qual-high{color:#1a8f64;border:2px solid #1a8f64;background:rgba(26,143,100,.08)}
.ls-qual-mid{color:var(--g-dim);border:2px solid var(--g-dim);background:var(--g-glow)}
.ls-qual-low{color:#ef4444;border:2px solid #ef4444;background:rgba(239,68,68,.08)}

/* Lead Scout: Badges */
.ls-badge{font-size:9px;font-weight:600;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px}
.ls-badge-market{background:var(--b-glow);color:var(--b);border:1px solid rgba(74,124,255,.2)}
.ls-badge-vertical{background:var(--raised);color:var(--tx2);border:1px solid var(--border)}

/* Lead Scout: Signals */
.ls-sig{font-size:9px;font-weight:700;text-transform:uppercase;padding:1px 5px;border-radius:3px;letter-spacing:.2px;white-space:nowrap}
.ls-sig-red{background:rgba(239,68,68,.1);color:#ef4444}
.ls-sig-yellow{background:rgba(245,197,66,.12);color:var(--g-dim)}
.ls-sig-green{background:rgba(26,143,100,.1);color:#1a8f64}
.ls-sig-gold{background:rgba(245,197,66,.15);color:#c49e35}

/* Lead Scout: Panel */
.ls-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:none}
.ls-overlay.open{display:block}
.ls-panel{position:fixed;top:var(--topbar);right:0;bottom:0;width:860px;max-width:100vw;background:var(--surf);border-left:1px solid var(--border);z-index:301;transform:translateX(100%);transition:transform .2s ease;overflow-y:hidden;display:flex;flex-direction:column}
.ls-panel.open{transform:translateX(0)}
.ls-panel-columns{display:flex;flex:1;overflow:hidden;min-height:0}
.ls-panel-col{flex:1;overflow-y:auto;padding:16px;min-width:0}
.ls-panel-col-left{border-right:1px solid var(--border)}
.ls-panel-col-hd{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--tx3);margin-bottom:4px}
.ls-panel-col-sub{font-size:10px;color:var(--tx3);margin-bottom:12px;font-style:italic}
.ls-collapsible-hd{cursor:pointer;user-select:none;display:flex;align-items:center;gap:6px}
.ls-collapsible-hd:hover{opacity:0.8}
.ls-collapsible-arrow{transition:transform .15s;font-size:8px;color:var(--tx3)}
.ls-collapsible-arrow.open{transform:rotate(90deg)}
.ls-panel-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.ls-panel-nav{display:flex;gap:4px}
.ls-panel-nav button{width:24px;height:24px;border-radius:5px;border:1px solid var(--border);background:var(--raised);color:var(--tx2);cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;transition:all .1s}
.ls-panel-nav button:hover{border-color:var(--t);color:var(--t)}
.ls-panel-title{font-size:13px;font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ls-panel-close{width:26px;height:26px;border-radius:6px;border:1px solid var(--border);background:var(--raised);color:var(--tx2);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s}
.ls-panel-close:hover{color:var(--t);border-color:var(--t)}
.ls-panel-body{padding:16px;flex:1;overflow-y:auto}

/* Lead Scout: Panel Score Boxes */
.ls-score-boxes{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.ls-score-box{text-align:center;padding:14px;border-radius:var(--rad);border:1px solid var(--border);background:var(--raised)}
.ls-score-box-val{font-size:28px;font-weight:800;font-family:var(--mono)}
.ls-score-box-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--tx3);margin-top:4px}
.ls-info-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}

/* Lead Scout: Breakdown Bars */
.ls-breakdown{margin-bottom:16px}
.ls-breakdown-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--tx3);margin-bottom:8px}
.ls-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.ls-bar-label{font-size:10px;color:var(--tx2);width:110px;flex-shrink:0;text-align:right}
.ls-bar-track{flex:1;height:6px;background:var(--raised);border-radius:3px;overflow:hidden}
.ls-bar-fill{height:100%;border-radius:3px;background:var(--t);transition:width .3s}
.ls-bar-val{font-size:9px;font-weight:700;font-family:var(--mono);color:var(--tx3);width:36px;flex-shrink:0}

/* Lead Scout: Panel Sections */
.ls-section{margin-bottom:16px}
.ls-section-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--tx3);margin-bottom:6px;display:flex;align-items:center;gap:6px}
.ls-section-count{font-size:9px;font-weight:600;padding:1px 6px;border-radius:8px;background:var(--raised);color:var(--tx3)}
.ls-pill-list{display:flex;flex-wrap:wrap;gap:4px}
.ls-pill-red{font-size:10px;padding:3px 8px;border-radius:4px;background:rgba(239,68,68,.08);color:#ef4444;border:1px solid rgba(239,68,68,.2)}
.ls-pill-green{font-size:10px;padding:3px 8px;border-radius:4px;background:rgba(26,143,100,.08);color:#1a8f64;border:1px solid rgba(26,143,100,.2)}
.ls-pill-amber{font-size:10px;padding:3px 8px;border-radius:4px;background:rgba(245,158,11,.08);color:#D97706;border:1px solid rgba(245,158,11,.2)}
.ls-pill-blue{font-size:10px;padding:3px 8px;border-radius:4px;background:rgba(59,130,246,.08);color:#3B82F6;border:1px solid rgba(59,130,246,.2)}

/* Lead Scout: Contacts */
.ls-contact{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:11px}
.ls-contact:last-child{border-bottom:none}
.ls-contact-icon{font-size:14px;flex-shrink:0}
.ls-contact-val{flex:1;font-family:var(--mono);font-size:11px;color:var(--tx);word-break:break-all}
.ls-contact-badges{display:flex;gap:4px;flex-shrink:0}
.ls-contact-badge{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:1px 5px;border-radius:3px}
.ls-contact-badge-personal{background:rgba(74,124,255,.1);color:var(--b)}
.ls-contact-badge-hunter{background:rgba(255,107,53,.1);color:var(--t)}
.ls-contact-badge-name{background:rgba(74,124,255,.08);color:var(--tx2)}
.ls-contact-badge-conf{background:var(--raised);color:var(--tx3)}
.ls-copy-btn{font-size:9px;font-weight:700;padding:2px 8px;border:1px solid var(--border);border-radius:4px;background:var(--raised);color:var(--tx2);cursor:pointer;font-family:var(--font);transition:all .1s;flex-shrink:0}
.ls-copy-btn:hover{border-color:var(--t);color:var(--t)}

/* Lead Scout: Outreach */
.ls-outreach{background:var(--raised);border:1px solid var(--border);border-radius:var(--rad);padding:12px;margin-top:8px}
.ls-outreach-template{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--t);margin-bottom:6px}
.ls-outreach-subject{font-size:12px;font-weight:600;margin-bottom:8px}
.ls-outreach-body{font-size:11px;color:var(--tx2);line-height:1.6;white-space:pre-wrap;max-height:200px;overflow-y:auto;margin-bottom:8px}
.ls-outreach-actions{display:flex;gap:6px}

/* Lead Scout: Panel columns responsive */
@media(max-width:900px){.ls-panel-columns{flex-direction:column}.ls-panel-col-left{border-right:none;border-bottom:1px solid var(--border)}}

/* Lead Scout: Toast */
.ls-toast{position:fixed;bottom:24px;right:24px;background:var(--tx);color:var(--bg);padding:8px 16px;border-radius:var(--rad);font-size:11px;font-weight:600;z-index:500;opacity:0;transition:opacity .2s;pointer-events:none}
.ls-toast.show{opacity:1}

@media(max-width:800px){
  .ls-col-market,.ls-col-vertical{display:none}
  .ls-panel{width:100%}
}
@media(max-width:600px){
  .ls-topbar{padding:8px 12px;gap:8px;flex-wrap:wrap}
  .ls-dashboard{padding:0 12px 48px}
  .ls-filter-bar{padding:6px 12px}
  .ls-score-range input[type=range]{width:70px}
  .ls-funnel{gap:2px;margin:12px 0}
  .ls-funnel-step{padding:8px 6px;min-width:50px}
  .ls-funnel-val{font-size:16px}
  .ls-funnel-lbl{font-size:7px}
  .ls-stats{gap:4px}
  .ls-stat{padding:6px 10px;font-size:11px}
  .ls-col-headers{margin:0 -12px;padding:0 12px}
  .ls-table td{padding:8px 6px;font-size:12px}
  .ls-camp-table td,.ls-camp-table th{padding:8px 6px}
  .ls-bar-label{width:70px;font-size:9px}
  .ls-toast{bottom:env(safe-area-inset-bottom,12px);right:12px;left:12px}
  .ls-funnel{display:grid;grid-template-columns:1fr 1fr;gap:6px}
  .ls-funnel-arrow{display:none}
  .ls-table td{white-space:normal;font-size:13px;padding:10px 8px}
}

/* ============================================================
   CRM TAB
   ============================================================ */
#page-crm{flex-direction:column;overflow:hidden}
.crm-topbar{flex-shrink:0;padding:10px 24px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;align-items:center;gap:12px}
.crm-toggle{display:flex;border:1px solid var(--border);border-radius:20px;overflow:hidden}
.crm-toggle-btn{font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:5px 16px;border:none;background:none;color:var(--tx3);cursor:pointer;font-family:var(--font);transition:all .12s;white-space:nowrap}
.crm-toggle-btn:hover{color:var(--tx)}
.crm-toggle-btn.active{background:var(--t);color:#fff}
.crm-view-toggle{display:flex;border:1px solid var(--border);border-radius:20px;overflow:hidden;margin-left:auto}
.crm-view-btn{font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:5px 14px;border:none;background:none;color:var(--tx3);cursor:pointer;font-family:var(--font);transition:all .12s;white-space:nowrap}
.crm-view-btn:hover{color:var(--tx)}
.crm-view-btn.active{background:var(--b);color:#fff}

/* CRM: Filter Bar */
.crm-filter-bar{flex-shrink:0;padding:8px 24px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;flex-direction:column;gap:4px}
.crm-filter-bar:empty{display:none}
.crm-filter-row{display:flex;gap:4px;flex-wrap:wrap;align-items:center}

/* CRM: Metrics */
.crm-metrics{display:flex;flex-wrap:wrap;gap:8px;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}
.crm-metric{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--surf);border:1px solid var(--border);border-radius:20px;font-size:12px;box-shadow:var(--shadow)}
.crm-metric strong{font-weight:700;font-family:var(--mono)}
.crm-metric-t{color:var(--t)}
.crm-metric-b{color:var(--b)}
.crm-metric-g{color:var(--g-dim)}
.crm-metric-green{color:#10b981}
.crm-metric-red{color:#ef4444}

/* CRM: Content */
.crm-content{flex:1;overflow-y:auto;padding:18px 24px 48px}
.crm-empty{padding:60px;text-align:center;color:var(--tx3);font-size:13px}

/* CRM: Kanban Board */
.crm-board{display:flex;gap:12px;align-items:flex-start;min-height:200px}
.crm-col{flex:1;min-width:140px;max-width:260px}
.crm-col-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--tx3);margin-bottom:8px;padding-bottom:6px;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:6px}
.crm-col-count{border-radius:10px;padding:1px 7px;font-size:9px;background:var(--raised);color:var(--tx3)}
.crm-col-cards{display:flex;flex-direction:column;gap:6px}
.crm-card{background:var(--surf);border:1px solid var(--border);border-radius:var(--rad);padding:10px 12px;transition:border-color .12s,box-shadow .12s;box-shadow:var(--shadow);cursor:pointer}
.crm-card:hover{border-color:var(--t-dim);box-shadow:var(--shadow-h)}
.crm-card-name{font-size:12px;font-weight:600;color:var(--tx);line-height:1.35;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.crm-card-info{font-size:10.5px;color:var(--tx2);line-height:1.45;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.crm-card-tags{display:flex;gap:3px;flex-wrap:wrap}
.crm-card-stale{border-left:3px solid #ef4444}
.crm-card-warning{border-left:3px solid var(--g-dim)}

/* CRM: Funnel */
.crm-funnel{display:flex;align-items:stretch;gap:0;margin:0 0 18px;min-height:100px}
.crm-funnel-step{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:14px 8px;background:var(--surf);border:1px solid var(--border);position:relative;min-width:60px}
.crm-funnel-step:first-child{border-radius:var(--rad) 0 0 var(--rad)}
.crm-funnel-step:last-child{border-radius:0 var(--rad) var(--rad) 0}
.crm-funnel-step+.crm-funnel-step{border-left:none}
.crm-funnel-val{font-size:22px;font-weight:800;font-family:var(--mono);color:var(--t)}
.crm-funnel-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3);margin-top:2px;text-align:center}
.crm-funnel-pct{font-size:9px;font-weight:700;font-family:var(--mono);color:var(--b);margin-top:4px}
.crm-funnel-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--t);opacity:.4;border-radius:0 0 0 var(--rad)}
.crm-funnel-step:last-child .crm-funnel-bar{border-radius:0 0 var(--rad) 0}

/* CRM: Table */
.crm-table{width:100%;border-collapse:collapse}
.crm-table th{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:7px 10px;border-bottom:1px solid var(--border);text-align:left;color:var(--tx3);white-space:nowrap;cursor:pointer;user-select:none}
.crm-table th:hover{color:var(--t)}
.crm-table td{padding:6px 10px;border-bottom:1px solid var(--border);font-size:11px;color:var(--tx2);white-space:nowrap}
.crm-table tr{cursor:pointer;transition:background .08s}
.crm-table tr:hover{background:var(--raised)}
.crm-table tr.crm-active{background:var(--t-glow)}

/* CRM: Detail Panel */
.crm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:none}
.crm-overlay.open{display:block}
.crm-panel{position:fixed;top:var(--topbar);right:0;bottom:0;width:460px;max-width:100vw;background:var(--surf);border-left:1px solid var(--border);z-index:301;transform:translateX(100%);transition:transform .2s ease;overflow-y:auto;display:flex;flex-direction:column}
.crm-panel.open{transform:translateX(0)}
.crm-panel-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.crm-panel-nav{display:flex;gap:4px}
.crm-panel-nav button{width:24px;height:24px;border-radius:5px;border:1px solid var(--border);background:var(--raised);color:var(--tx2);cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;transition:all .1s}
.crm-panel-nav button:hover{border-color:var(--t);color:var(--t)}
.crm-panel-title{font-size:13px;font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.crm-panel-close{width:26px;height:26px;border-radius:6px;border:1px solid var(--border);background:var(--raised);color:var(--tx2);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s}
.crm-panel-close:hover{color:var(--t);border-color:var(--t)}
.crm-panel-body{padding:16px;flex:1;overflow-y:auto}
.crm-panel-section{margin-bottom:16px}
.crm-panel-section-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--tx3);margin-bottom:6px}
.crm-panel-row{display:flex;justify-content:space-between;padding:4px 0;font-size:11px;border-bottom:1px solid var(--border)}
.crm-panel-row:last-child{border-bottom:none}
.crm-panel-label{color:var(--tx3);font-weight:600}
.crm-panel-val{color:var(--tx);font-weight:500}

/* CRM: Stage Badges */
.crm-stage-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:2px 8px;border-radius:10px;display:inline-block}
.crm-stage-active{background:var(--t-glow);color:var(--t);border:1px solid var(--t)}
.crm-stage-won{background:rgba(16,185,129,.1);color:#10b981;border:1px solid rgba(16,185,129,.3)}
.crm-stage-lost{background:rgba(239,68,68,.08);color:#ef4444;border:1px solid rgba(239,68,68,.2)}
.crm-stage-churned{background:rgba(239,68,68,.08);color:#ef4444;border:1px solid rgba(239,68,68,.2)}

/* CRM: Priority Variants */
.crm-priority-high{color:var(--t);font-weight:700}
.crm-priority-medium{color:var(--g-dim);font-weight:600}
.crm-priority-low{color:var(--tx3);font-weight:500}

@media(max-width:800px){
  .crm-board{flex-direction:column}
  .crm-col{max-width:none}
  .crm-panel{width:100%}
  .crm-funnel{flex-wrap:wrap}
  .crm-funnel-step{min-width:80px}
}
@media(max-width:600px){
  .crm-topbar{padding:8px 12px;gap:8px;flex-wrap:wrap}
  .crm-filter-bar{padding:6px 12px}
  .crm-metrics{padding:10px 12px;gap:4px}
  .crm-metric{padding:6px 10px;font-size:11px}
  .crm-content{padding:12px 12px 48px}
  .crm-funnel-step{padding:10px 4px;min-width:50px}
  .crm-funnel-val{font-size:18px}
  .crm-funnel-lbl{font-size:7px;letter-spacing:.3px}
  .crm-table td{padding:8px 6px;font-size:12px}
  .crm-table th{padding:8px 6px}
  .crm-card{padding:12px}
  .crm-card-name{font-size:14px;white-space:normal}
  .crm-card-info{font-size:12px}
  .crm-funnel{display:grid;grid-template-columns:1fr 1fr;gap:6px}
}

/* ============================================================
   DOCUMENTS TAB (shared: IS + SD)
   ============================================================ */
#page-docs{flex-direction:column}
.pill-label{font-size:9.5px;color:var(--tx3);font-weight:700;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;margin-right:2px}
.proj-select{font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:4px 24px 4px 11px;border:1px solid var(--border);border-radius:20px;cursor:pointer;color:var(--tx3);background:var(--bg);font-family:var(--font);outline:none;transition:all .12s;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239B95A8'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}
.proj-select:hover{color:var(--tx);border-color:var(--tx3)}
.proj-select:focus{border-color:var(--t);color:var(--t)}
.proj-select option{text-transform:none;font-weight:400;background:var(--surf);color:var(--tx)}
.doc-filters{flex-shrink:0;padding:10px 24px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;flex-direction:column;gap:6px}
.doc-split{flex:1;overflow:hidden;display:flex;flex-direction:row}
.docs-tree-panel{width:260px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column;background:var(--surf)}
.docs-tree-top{padding:12px 14px 8px;border-bottom:1px solid var(--border)}
.docs-tree-controls{display:flex;gap:6px;margin-top:6px}
.tree-ctrl-btn{flex:1;padding:3px 0;font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;border:1px solid var(--border);border-radius:4px;background:none;color:var(--tx3);cursor:pointer;font-family:var(--font);transition:color .12s,border-color .12s}
.tree-ctrl-btn:hover{color:var(--t);border-color:var(--t)}
.doc-ctrl{width:100%;padding:6px 10px;border-radius:var(--rad);border:1px solid var(--border);background:var(--bg);font-size:12px;color:var(--tx);font-family:var(--font);outline:none;transition:border-color .12s;margin-bottom:6px}
.doc-ctrl:focus{border-color:var(--t)}
.doc-ctrl::placeholder{color:var(--tx3)}
.doc-ctrl option{background:var(--surf)}
.root-count{opacity:.7;font-weight:400;margin-left:2px}
.doc-tree-scroll{flex:1;overflow-y:auto;padding:6px 8px 12px}
.tree-arrow{font-size:8px;opacity:.7}

/* Sidebar tree nodes */
.doc-cat-section{margin-bottom:4px}
.doc-cat-head{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:10px 6px 4px;display:flex;align-items:center;gap:5px;cursor:pointer;user-select:none;color:var(--tx);font-family:var(--font)}
.doc-cat-head .tree-arrow{font-size:8px;transition:transform .15s;color:var(--tx3)}
.doc-cat-head .doc-type-count{margin-left:auto}
.doc-cat-section .doc-cat-body{display:none}
.doc-cat-section.open .doc-cat-body{display:block}
.doc-cat-section.open > .doc-cat-head .tree-arrow{transform:rotate(90deg)}
.doc-nest-sub{margin-left:4px;margin-bottom:1px}
.doc-nest-sub-head{font-size:11.5px;font-weight:600;color:var(--tx);padding:2px 6px 1px;cursor:pointer;display:flex;align-items:center;gap:4px;user-select:none;letter-spacing:0}
.doc-nest-sub-head:hover{color:var(--tx)}
.doc-nest-sub-head.subcat{color:#555;font-size:11px;font-weight:600;margin-top:6px}
.doc-nest-sub-head.subcat:first-child{margin-top:2px}
.doc-nest-sub > .doc-nest-sub-files{display:none;margin-left:4px}
.doc-nest-sub.open > .doc-nest-sub-files{display:block}
.doc-nest-sub.open > .doc-nest-sub-head .tree-arrow{transform:rotate(90deg)}
.doc-link-wrap{margin-bottom:0}
.doc-link{display:block;font-size:11.5px;color:var(--tx2);padding:2px 10px;border-radius:5px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background .1s,color .1s;margin-left:2px;font-weight:500;line-height:1.4}
.doc-link:hover{background:var(--raised);color:var(--tx)}
.doc-link.active{background:var(--t-glow);color:var(--t);font-weight:600}
.doc-type-count{font-size:8px;font-weight:600;background:var(--raised);border:1px solid var(--border);border-radius:8px;padding:0 5px;color:var(--tx3);margin-left:auto}

/* Content panel */
.docs-content-panel{flex:1;overflow-y:auto;padding:36px 52px 60px}
.docs-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60%;color:var(--tx3);text-align:center;gap:10px}
.docs-placeholder .big{font-size:52px}
.docs-placeholder p{font-size:11px;text-transform:uppercase;letter-spacing:1px}
.docs-content-panel h1{font-size:26px;font-weight:800;margin-bottom:12px;letter-spacing:-.2px}
.docs-content-panel h2{font-size:18px;font-weight:700;margin:24px 0 8px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.docs-content-panel h3{font-size:14px;font-weight:700;margin:16px 0 6px}
.docs-content-panel h4{font-size:13px;font-weight:600;margin:12px 0 4px;color:var(--tx2)}
.docs-content-panel p{font-size:13.5px;color:var(--tx2);margin-bottom:10px;line-height:1.7}
.docs-content-panel ul,.docs-content-panel ol{padding-left:20px;margin-bottom:10px;color:var(--tx2);font-size:13.5px}
.docs-content-panel li{margin-bottom:3px;line-height:1.6}
.docs-content-panel code{font-family:var(--mono);font-size:11px;background:var(--raised);padding:1px 5px;border-radius:3px;color:var(--t)}
.docs-content-panel pre{background:var(--raised);border:1px solid var(--border);padding:12px 16px;border-radius:var(--rad);overflow-x:auto;margin-bottom:12px}
.docs-content-panel pre code{background:none;padding:0;color:var(--tx);font-size:11.5px}
.docs-content-panel blockquote{border-left:3px solid var(--t);padding-left:12px;color:var(--tx3);margin-bottom:10px;font-style:italic}
.docs-content-panel table{width:100%;border-collapse:collapse;margin-bottom:12px;font-size:12.5px}
.docs-content-panel th{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:6px 10px;border-bottom:1px solid var(--border);text-align:left;color:var(--tx3)}
.docs-content-panel td{padding:6px 10px;border-bottom:1px solid var(--border);color:var(--tx2)}
.docs-content-panel strong{color:var(--tx);font-weight:700}
.docs-content-panel a{color:var(--b)}
.docs-content-panel hr{border:none;border-top:1px solid var(--border);margin:18px 0}
.docs-empty{padding:60px;text-align:center;color:var(--tx3);font-size:13px}

/* Doc cards */
.doc-group-title{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;margin:32px 0 14px;padding-bottom:0;display:flex;align-items:center;gap:12px;color:var(--tx)}
.doc-group-title:first-child{margin-top:0}
.doc-group-title .bar{height:2px;flex:1;border-radius:2px;opacity:.3;transition:opacity .3s}
.doc-group-title:hover .bar{opacity:.6}
.doc-subcat-title{font-size:12px;font-weight:700;letter-spacing:.3px;margin:20px 0 8px;padding:6px 12px;display:flex;align-items:center;gap:8px;color:#555;border-left:3px solid var(--border)}
.doc-subcat-title:first-child{margin-top:0}
.doc-subcat-title .subcat-count{font-size:10px;font-weight:400;opacity:.5}
.doc-card{margin-bottom:10px;border:1px solid var(--border);border-radius:var(--rad);overflow:hidden;background:var(--surf);box-shadow:var(--shadow);transition:border-color .2s,box-shadow .2s}
.doc-card:hover{border-color:var(--tx3);box-shadow:var(--shadow-h)}
.doc-card.expanded{border-color:var(--t);box-shadow:var(--shadow-h)}
.doc-card.glow{animation:cardGlow 2.5s ease-in-out 1}
.doc-card-head{display:flex;align-items:center;gap:10px;padding:11px 16px;cursor:pointer;user-select:none;transition:background .15s;border-bottom:1px solid transparent;position:relative}
.doc-card-head::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--t),var(--g));transform:scaleX(0);transform-origin:left;transition:transform .35s}
.doc-card.expanded .doc-card-head::after{transform:scaleX(1)}
.doc-card-head:hover{background:var(--raised)}
.doc-card.expanded .doc-card-head{border-bottom-color:var(--border)}
.doc-card-head .card-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;transition:transform .15s,box-shadow .15s}
.doc-card-head:hover .card-dot{transform:scale(1.4);box-shadow:0 0 6px currentColor}
.doc-card-head .card-title{font-size:13px;font-weight:600;flex:1;letter-spacing:.01em;color:var(--tx)}
.doc-card-head .card-file{font-family:var(--mono);font-size:9px;font-weight:600;padding:2px 8px;border-radius:10px;background:var(--raised);color:var(--tx3);white-space:nowrap;letter-spacing:.05em;text-transform:uppercase;border:1px solid var(--border)}
.doc-card-head .card-caret{color:var(--tx3);font-size:9px;transition:transform .2s,color .15s;flex-shrink:0}
.doc-card-head:hover .card-caret{color:var(--t)}
.doc-card.expanded .card-caret{transform:rotate(90deg);color:var(--t)}
.source-badge{font-family:var(--mono);font-size:8px;font-weight:700;padding:1px 6px;border-radius:8px;white-space:nowrap;letter-spacing:.05em;text-transform:uppercase;border:1px solid;flex-shrink:0}
.card-date{font-family:var(--mono);font-size:9px;font-weight:500;color:var(--tx3);white-space:nowrap;flex-shrink:0;letter-spacing:.03em}
.card-star{background:none;border:none;font-size:14px;cursor:pointer;color:var(--tx3);opacity:.3;padding:0 2px;flex-shrink:0;transition:all .15s;font-family:inherit;line-height:1}
.card-star:hover{opacity:.7;color:#EAB308}
.card-star.active{opacity:1;color:#EAB308}
.doc-card-body{padding:24px 20px;display:none;position:relative}
.doc-card-body.expanded{display:block;animation:fadeInUp .3s ease}
.doc-card-body h1{font-size:22px;font-weight:800;margin:24px 0 10px;letter-spacing:-.2px}
.doc-card-body h2{font-size:16px;font-weight:700;margin:20px 0 8px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.doc-card-body h3{font-size:13px;font-weight:700;margin:14px 0 5px}
.doc-card-body p{font-size:13px;color:var(--tx2);margin-bottom:8px;line-height:1.7}
.doc-card-body ul,.doc-card-body ol{padding-left:18px;margin-bottom:8px;color:var(--tx2);font-size:13px}
.doc-card-body li{margin-bottom:2px;line-height:1.6}
.doc-card-body code{font-family:var(--mono);font-size:10.5px;background:var(--raised);padding:1px 5px;border-radius:3px;color:var(--t)}
.doc-card-body pre{background:var(--raised);border:1px solid var(--border);padding:10px 14px;border-radius:var(--rad);overflow-x:auto;margin-bottom:10px}
.doc-card-body pre code{background:none;padding:0;color:var(--tx);font-size:11px}
.doc-card-body blockquote{border-left:3px solid var(--t);padding-left:10px;color:var(--tx3);margin-bottom:8px;font-style:italic}
.doc-card-body table{width:100%;border-collapse:collapse;margin-bottom:10px;font-size:12px}
.doc-card-body th{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:5px 8px;border-bottom:1px solid var(--border);text-align:left;color:var(--tx3)}
.doc-card-body td{padding:5px 8px;border-bottom:1px solid var(--border);color:var(--tx2)}
.doc-card-body strong{color:var(--tx);font-weight:700}
.doc-card-body a{color:var(--b)}
.doc-card-body hr{border:none;border-top:1px solid var(--border);margin:14px 0}
.doc-card-loading{text-align:center;padding:20px;color:var(--tx3);font-size:11px}
.doc-meta-header{padding:10px 14px;background:var(--raised);border-bottom:1px solid var(--border);margin:-24px -20px 12px;border-radius:8px 8px 0 0}
.doc-meta-title{font-weight:600;font-size:14px;color:var(--tx);margin-bottom:4px}
.doc-meta-pills{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:4px}
.doc-meta-pill{font-size:11px;padding:1px 8px;border-radius:10px;background:var(--t)18;color:var(--t)}
.doc-meta-details{font-size:11px;color:var(--tx3)}
.doc-meta-link{font-size:11px;color:var(--t);margin-top:4px;display:inline-block}
.doc-refs{margin-top:16px;padding-top:12px;border-top:1px solid var(--border)}
.doc-refs-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--tx3);margin-bottom:8px}
.doc-refs-list{display:flex;flex-wrap:wrap;gap:6px}
.doc-ref-link{font-size:11px;font-weight:500;padding:3px 10px;border-radius:8px;background:var(--raised);color:var(--tx2);border:1px solid var(--border);cursor:pointer;text-decoration:none;transition:background .15s,border-color .15s}
.doc-ref-link:hover{background:var(--t);color:#fff;border-color:var(--t)}
.doc-ref-link .ref-type{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;opacity:.6;margin-right:4px}
.load-more-btn{display:block;width:100%;padding:14px;margin:16px 0;border:1px dashed var(--border);border-radius:12px;background:transparent;color:var(--tx2);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}
.load-more-btn:hover{background:var(--raised);border-color:var(--t);color:var(--t)}
@keyframes cardGlow{0%{box-shadow:var(--shadow)}40%{box-shadow:0 0 12px var(--t-glow2)}100%{box-shadow:var(--shadow)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   ADMIN TAB
   ============================================================ */
#page-admin{flex-direction:column;overflow:hidden;padding:24px}
.admin-content{flex:1;overflow-y:auto;padding:0 24px 48px}
.admin-header{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding:0 24px}
.admin-title{font-size:18px;font-weight:800;color:var(--tx)}
.admin-btn{font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:7px 18px;border:none;border-radius:20px;cursor:pointer;font-family:var(--font);transition:all .12s}
.admin-btn-primary{background:var(--t);color:#fff}
.admin-btn-primary:hover{background:var(--t-dim)}
.admin-btn-danger{background:none;border:1px solid #ef4444;color:#ef4444}
.admin-btn-danger:hover{background:#ef4444;color:#fff}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:8px 12px;border-bottom:2px solid var(--border);text-align:left;color:var(--tx3)}
.admin-table td{padding:8px 12px;border-bottom:1px solid var(--border);font-size:12px;color:var(--tx2)}
.admin-table tr:hover{background:var(--raised)}
.admin-role-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:2px 8px;border-radius:10px}
.admin-role-admin{background:var(--t-glow);color:var(--t);border:1px solid rgba(255,107,53,.3)}
.admin-role-salesperson{background:var(--b-glow);color:var(--b);border:1px solid rgba(74,124,255,.2)}
.admin-role-director{background:#f0fdf4;color:#15803d;border:1px solid rgba(21,128,61,.2)}
.admin-role-viewer{background:rgba(99,102,241,.1);color:#6366F1;border:1px solid rgba(99,102,241,.25)}
.admin-status-active{color:#10b981}
.admin-status-banned{color:#ef4444}

/* ============================================================
   GTM TAB
   ============================================================ */
.gtm-wrapper{padding:24px;overflow-y:auto;height:calc(100vh - var(--topbar))}
.gtm-header{margin-bottom:24px}
.gtm-title{font-size:18px;font-weight:800;color:var(--tx);margin-bottom:16px}

/* GTM: State funnel cards */
.gtm-funnel{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.gtm-funnel-card{flex:1;min-width:120px;padding:14px 16px;background:var(--surf);border-radius:var(--rad);border:1px solid var(--border);border-left:3px solid var(--border);box-shadow:var(--shadow);transition:box-shadow .12s}
.gtm-funnel-card:hover{box-shadow:var(--shadow-h)}
.gtm-funnel-val{font-size:22px;font-weight:800;font-family:var(--mono);line-height:1.2}
.gtm-funnel-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--tx3);margin-top:4px}

/* GTM: Section headers */
.gtm-section{margin-bottom:24px}
.gtm-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--tx3);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}

/* GTM: Outreach card */
.gtm-outreach-card{background:var(--surf);border-radius:var(--rad);padding:14px 16px;margin-bottom:8px;border:1px solid var(--border);box-shadow:var(--shadow);transition:box-shadow .12s}
.gtm-outreach-card:hover{box-shadow:var(--shadow-h)}
.gtm-outreach-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.gtm-outreach-name{font-weight:700;font-size:13px;color:var(--tx)}
.gtm-outreach-auto{font-size:10px;color:var(--tx3)}
.gtm-outreach-touches{font-size:10px;color:var(--tx3)}

/* GTM: Status badge */
.gtm-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#fff}
.gtm-badge-draft{background:#6B7280}
.gtm-badge-approved{background:#3B82F6}
.gtm-badge-in-progress{background:#F59E0B}
.gtm-badge-completed{background:#10B981}
.gtm-badge-paused{background:#EF4444}
.gtm-badge-sent{background:#10B981}
.gtm-badge-replied{background:#3B82F6}
.gtm-badge-bounced{background:#EF4444}
.gtm-badge-pending{background:#6B7280}

/* GTM: Touch row */
.gtm-touch{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--tx2);padding:4px 0;padding-left:8px}
.gtm-touch-day{width:50px;flex-shrink:0;font-weight:600;color:var(--tx3)}
.gtm-touch-channel{width:50px;flex-shrink:0;font-weight:500}
.gtm-touch-subject{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gtm-touch-action{font-size:9px;padding:2px 8px;border:1px solid var(--border);border-radius:4px;background:none;cursor:pointer;font-family:var(--font);color:var(--tx2);transition:all .12s}
.gtm-touch-action:hover{background:var(--raised);border-color:var(--tx3)}

/* GTM: Approve button */
.gtm-btn{font-size:11px;font-weight:600;padding:5px 14px;border:none;border-radius:var(--rad);cursor:pointer;font-family:var(--font);transition:all .12s}
.gtm-btn-primary{background:var(--b);color:#fff}
.gtm-btn-primary:hover{background:var(--b-dim)}

/* GTM: Runs table */
.gtm-table{width:100%;border-collapse:collapse}
.gtm-table th{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:8px 12px;border-bottom:2px solid var(--border);text-align:left;color:var(--tx3)}
.gtm-table td{padding:8px 12px;border-bottom:1px solid var(--border);font-size:12px;color:var(--tx2)}
.gtm-table tr:hover{background:var(--raised)}
.gtm-table .hot{color:#EF4444;font-weight:700;font-family:var(--mono)}
.gtm-table .warm{color:#F59E0B;font-weight:700;font-family:var(--mono)}
.gtm-table .parked{color:var(--tx3);font-family:var(--mono)}
.gtm-table .name{font-weight:600;color:var(--tx)}
.gtm-table .date{color:var(--tx3);font-size:11px}
.gtm-table .num{font-family:var(--mono);text-align:right}

/* GTM: Route pill */
.gtm-route-pill{display:inline-block;padding:1px 8px;border-radius:10px;font-size:9px;font-weight:700;letter-spacing:.5px;border:1px solid;background:none}
/* GTM: Leads filter bar */
.gtm-leads-filters{display:flex;gap:8px;margin-bottom:12px}
.gtm-leads-filters .proj-select{font-size:12px;padding:4px 8px}

/* GTM: Empty state */
.gtm-empty{color:var(--tx3);font-size:12px;padding:16px 0;text-align:center;background:var(--raised);border-radius:var(--rad);border:1px dashed var(--border)}

/* GTM: Recent runs inline */
.gtm-recent{margin-top:16px}
.gtm-recent-item{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--tx2);padding:6px 0}
.gtm-recent-name{font-weight:600;color:var(--tx)}
.gtm-recent-count{font-family:var(--mono)}
.gtm-recent-date{color:var(--tx3)}

/* GTM: Usage guide */
.gtm-guide{margin-bottom:24px;border:1px solid var(--border);border-radius:var(--rad);background:var(--surf);overflow:hidden}
.gtm-guide[open]{box-shadow:var(--shadow)}
.gtm-guide-toggle{padding:12px 16px;font-size:12px;font-weight:700;color:var(--tx2);cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px;user-select:none;transition:color .12s}
.gtm-guide-toggle:hover{color:var(--tx)}
.gtm-guide-toggle::before{content:'';display:inline-block;width:0;height:0;border-left:5px solid var(--tx3);border-top:4px solid transparent;border-bottom:4px solid transparent;transition:transform .15s}
.gtm-guide[open] .gtm-guide-toggle::before{transform:rotate(90deg)}
.gtm-guide-toggle::-webkit-details-marker{display:none}
.gtm-guide-body{padding:0 16px 16px;border-top:1px solid var(--border)}
.gtm-guide-intro{font-size:12px;color:var(--tx2);margin:12px 0 16px;line-height:1.5}
.gtm-guide-intro code{font-family:var(--mono);font-size:11px;background:var(--raised);padding:2px 6px;border-radius:4px;color:var(--t);font-weight:600}
.gtm-guide-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:16px}
.gtm-guide-card{padding:8px 10px;background:var(--raised);border-radius:var(--rad);border:1px solid var(--border)}
.gtm-guide-cmd{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--t);margin-bottom:3px}
.gtm-guide-desc{font-size:10px;color:var(--tx2);line-height:1.4}
.gtm-guide-flow{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:12px 0 0}
.gtm-guide-step{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:4px 10px;border-radius:var(--rad);border:2px solid;background:var(--raised);color:var(--tx2)}
.gtm-guide-arrow{color:var(--tx3);font-size:14px;font-weight:300}

@media(max-width:600px){
  .gtm-wrapper{padding:12px}
  .gtm-funnel{gap:4px}
  .gtm-funnel-card{min-width:80px;padding:10px 12px}
  .gtm-funnel-val{font-size:18px}
  .gtm-table td,.gtm-table th{padding:6px 8px;font-size:11px}
  .gtm-guide-grid{grid-template-columns:1fr}
}

/* ============================================================
   LOGIN PAGE
   ============================================================ */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:20px}
.login-card{background:var(--surf);border:1px solid var(--border);border-radius:var(--rad-lg);padding:40px;width:100%;max-width:380px;box-shadow:var(--shadow-h)}
.login-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:24px}
.login-logo-text{font-size:16px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}
.login-logo-text span{color:var(--t)}
.login-title{font-size:14px;font-weight:600;color:var(--tx2);text-align:center;margin-bottom:24px}
.login-field{margin-bottom:16px}
.login-field label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3);margin-bottom:4px}
.login-field input{width:100%;padding:10px 14px;border-radius:var(--rad);border:1px solid var(--border);background:var(--raised);font-size:13px;color:var(--tx);font-family:var(--font);outline:none;transition:border-color .12s}
.login-field input:focus{border-color:var(--t)}
.login-submit{width:100%;padding:11px;border:none;border-radius:var(--rad);background:var(--t);color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font);transition:background .12s;margin-top:8px}
.login-submit:hover{background:var(--t-dim)}
.login-submit:disabled{opacity:.5;cursor:not-allowed}
.login-error{color:#ef4444;font-size:12px;text-align:center;margin-top:12px;display:none}
.login-error.visible{display:block}

/* ============================================================
   PARTNERS TAB (reuses CRM styles with different stage colors)
   ============================================================ */
#page-partners{flex-direction:column;overflow:hidden}

/* ============================================================
   DIALOGS / MODALS
   ============================================================ */
.dialog-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:400;display:none;align-items:center;justify-content:center}
.dialog-overlay.open{display:flex}
.dialog{background:var(--surf);border:1px solid var(--border);border-radius:var(--rad-lg);padding:24px;width:100%;max-width:420px;box-shadow:0 12px 40px rgba(0,0,0,.2)}
.dialog-title{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--tx)}
.dialog-field{margin-bottom:12px}
.dialog-field label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3);margin-bottom:4px}
.dialog-field input,.dialog-field select{width:100%;padding:8px 12px;border-radius:var(--rad);border:1px solid var(--border);background:var(--raised);font-size:12px;color:var(--tx);font-family:var(--font);outline:none}
.dialog-field input:focus,.dialog-field select:focus{border-color:var(--t)}
.dialog-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}

/* ============================================================
   VPS OFFLINE BANNER
   ============================================================ */
.offline-banner{padding:16px 24px;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:var(--rad);margin:12px 24px;text-align:center;color:#ef4444;font-size:12px;font-weight:600}

/* ============================================================
   MOBILE RESPONSIVE (shared: topbar, login, docs, touch)
   ============================================================ */

/* Tablet: topbar + docs sidebar */
@media(max-width:800px){
  .doc-split{flex-direction:column}
  .docs-tree-panel{width:100%;max-height:200px;border-right:none;border-bottom:1px solid var(--border)}
  .docs-content-panel{padding:20px 16px 40px}
}

/* Mobile: full layout overhaul */
@media(max-width:600px){
  :root{--topbar:84px}
  .topbar{height:var(--topbar);flex-wrap:wrap;padding:0}
  .tb-brand{padding:0 12px;height:44px;border-right:none;flex:1}
  .tb-actions{border-left:none;padding:0 12px;height:44px;flex-shrink:0}
  .tab-nav{order:3;width:100%;border-top:1px solid var(--border);-webkit-overflow-scrolling:touch}
  .tab-btn{padding:0 14px;min-height:40px;font-size:11px}

  /* Hamburger menu (Sales Dashboard only, scoped under .sd-app) */
  .sd-app{--topbar:48px}
  .sd-app .topbar{height:48px;flex-wrap:nowrap}
  .sd-app .tb-brand{height:48px;flex:0 0 auto;padding:0 4px 0 12px;border-right:none}
  .sd-app .tb-brand .tb-label{display:none}
  .sd-app .tb-actions{height:48px;padding:0 10px;gap:6px;border-left:none}
  .sd-app .hamburger-btn{display:flex}
  .sd-app .active-tab-label{display:inline}
  .sd-app .tab-nav{display:none;order:0;width:auto;border-top:none}
  .sd-app .tab-nav.mobile-open{display:flex;flex-direction:column;position:fixed;top:48px;left:0;right:0;bottom:0;background:var(--surf);z-index:199;padding:12px 0;overflow-y:auto}
  .sd-app .tab-nav.mobile-open .tab-btn{padding:14px 24px;min-height:48px;font-size:14px;width:100%;text-align:left;border-bottom:1px solid var(--border);border-left:none;justify-content:flex-start}

  /* Login */
  .login-card{padding:24px 20px;max-width:none;margin:0 12px;border-radius:var(--rad-lg)}
  .login-field input{padding:12px 14px;font-size:16px}
  .login-submit{padding:14px;font-size:14px;min-height:48px}

  /* Documents */
  .docs-tree-panel{max-height:180px}
  .docs-content-panel{padding:16px 12px 40px}
  .docs-content-panel h1{font-size:20px}
  .docs-content-panel h2{font-size:16px}
  .doc-card-head{padding:12px}
  .doc-card-head .card-file{display:none}
  .doc-filters{padding:8px 12px}

  /* Admin */
  #page-admin{padding:12px}
  .admin-table td,.admin-table th{padding:8px 6px;font-size:11px}

  /* Dialogs */
  .dialog{margin:12px;max-width:none;padding:20px}

  /* Touch: enlarge interactive targets */
  .pill{min-height:36px;display:inline-flex;align-items:center;padding:6px 14px;font-size:11px}
  .ls-pill{min-height:32px;display:inline-flex;align-items:center;padding:4px 12px}
  .crm-toggle-btn,.crm-view-btn{min-height:36px;padding:6px 14px}
  .ls-export-btn{min-height:36px;padding:6px 16px}
  .ls-panel-nav button,.crm-panel-nav button{width:32px;height:32px}
  .slide-panel-close,.ls-panel-close,.crm-panel-close{width:32px;height:32px;font-size:16px}
  .theme-btn{width:36px;height:36px}

  /* Offline banner */
  .offline-banner{margin:8px 12px}

  /* Stat row */
  .stat-row{gap:4px}
  .stat-pill{padding:6px 10px;font-size:11px}

  /* Cards grid */
  .cards-grid{grid-template-columns:1fr}
}

/* Small phones */
@media(max-width:380px){
  .tb-brand .tb-label{font-size:11px}
  .tab-btn{padding:0 10px;font-size:10px;letter-spacing:.3px}
  .ls-funnel-step{padding:6px 4px;min-width:40px}
  .ls-funnel-val{font-size:14px}
  .crm-funnel-step{min-width:40px;padding:8px 2px}
  .crm-funnel-val{font-size:16px}
  .login-card{padding:20px 16px}
}

/* Touch device: active states replace hover */
@media(hover:none){
  .card:hover{transform:none;box-shadow:var(--shadow)}
  .card:active{border-color:var(--t-dim);box-shadow:var(--shadow-h)}
  .pill:active{opacity:.7}
  .ls-table tr:active{background:var(--raised)}
  .crm-card:active{border-color:var(--t-dim);box-shadow:var(--shadow-h)}
  .tab-btn:active{color:var(--tx)}
  .doc-card-head:active{background:var(--raised)}
}

/* Prevent iOS auto-zoom on input focus */
@media(max-width:600px){
  input,select,textarea{font-size:16px !important}
}

/* ============================================================
   ASSESSMENT TAB
   ============================================================ */

/* Layout */
.assm-wrapper{padding:24px;overflow-y:auto;height:calc(100vh - var(--topbar))}
.assm-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}
.assm-title{font-size:18px;font-weight:800;color:var(--tx)}
.assm-view-toggle{display:flex;gap:4px;background:var(--raised);border-radius:8px;padding:3px}
.assm-view-btn{padding:5px 14px;border-radius:6px;border:none;background:none;font-size:12px;font-weight:600;color:var(--tx3);cursor:pointer;font-family:var(--font);transition:all .15s}
.assm-view-btn.active{background:var(--surf);color:var(--tx);box-shadow:var(--shadow)}

/* Run form */
.assm-form{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;align-items:flex-end}
.assm-field{display:flex;flex-direction:column;gap:4px}
.assm-field label{font-size:11px;font-weight:600;color:var(--tx3);text-transform:uppercase;letter-spacing:0.5px}
.assm-field input,.assm-field select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--rad);font-size:13px;font-family:var(--font);background:var(--surf);color:var(--tx);min-width:0}
.assm-field input:focus,.assm-field select:focus{outline:none;border-color:var(--b)}
.assm-domain-field{flex:1;min-width:200px}
.assm-domain-field input{width:100%}
#assm-run-btn{padding:8px 20px;border:none;border-radius:var(--rad);background:var(--t);color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .15s;white-space:nowrap;display:flex;align-items:center;gap:6px}
#assm-run-btn:hover{background:var(--t-dim)}
#assm-run-btn:disabled{opacity:.6;cursor:not-allowed}

/* Loading */
.assm-loading{text-align:center;padding:48px 24px;color:var(--tx2)}
.assm-loading p{margin-top:12px;font-size:14px}
.assm-loading-sub{color:var(--tx3);font-size:12px !important;margin-top:4px !important}
.assm-loading-sm{padding:16px;color:var(--tx3);font-size:13px;display:flex;align-items:center;gap:8px}
.assm-error{padding:20px;background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.2);border-radius:var(--rad);color:#dc2626;font-size:13px}
.assm-error strong{display:block;margin-bottom:4px}

/* Result header */
.assm-result{animation:assm-fadeIn .3s ease}
@keyframes assm-fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.assm-result-header{display:flex;align-items:center;gap:20px;padding:20px;background:var(--surf);border:1px solid var(--border);border-radius:var(--rad-lg);margin-bottom:16px}
.assm-result-score{flex-shrink:0}
.assm-result-info{flex:1;min-width:0}
.assm-result-domain{font-size:18px;font-weight:700;color:var(--tx);word-break:break-all}
.assm-result-name{font-size:13px;color:var(--tx2);margin-top:2px}
.assm-result-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:8px;font-size:12px;color:var(--tx3)}
.assm-cached-badge{display:inline-block;padding:2px 8px;border-radius:4px;background:rgba(74,124,255,.08);color:var(--b);font-size:11px;font-weight:600}
.assm-partial-badge{display:inline-block;padding:2px 8px;border-radius:4px;background:rgba(249,115,22,.08);color:#F97316;font-size:11px;font-weight:600}
.assm-rescan-btn{padding:3px 10px;border:1px solid var(--border);border-radius:4px;background:none;font-size:11px;font-weight:600;color:var(--tx2);cursor:pointer;font-family:var(--font);transition:all .12s}
.assm-rescan-btn:hover{border-color:var(--t);color:var(--t)}

/* Score ring */
.assm-score-ring{display:block}

/* Pillar cards */
.assm-pillars{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:12px;margin-bottom:16px}
.assm-pillar-card{background:var(--surf);border:1px solid var(--border);border-radius:var(--rad-lg);padding:16px;transition:box-shadow .15s}
.assm-pillar-card:hover{box-shadow:var(--shadow-h)}
.assm-pillar-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.assm-pillar-icon{flex-shrink:0;display:flex;align-items:center}
.assm-pillar-info{flex:1;min-width:0}
.assm-pillar-name{font-size:14px;font-weight:700;color:var(--tx)}
.assm-pillar-grade{font-size:24px;font-weight:800;line-height:1}
.assm-pillar-score{flex-shrink:0}
.assm-pillar-gaps{margin-top:10px;font-size:11px;color:#F97316;font-weight:600}

/* Signal bars */
.assm-signals{display:flex;flex-direction:column;gap:6px}
.assm-signal-row{display:flex;align-items:center;gap:8px}
.assm-signal-name{font-size:11px;color:var(--tx2);width:120px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.assm-signal-bar{flex:1;height:6px;background:var(--raised);border-radius:3px;overflow:hidden}
.assm-signal-fill{height:100%;border-radius:3px;transition:width .4s ease}
.assm-signal-score{font-size:11px;font-weight:600;color:var(--tx2);width:24px;text-align:right;flex-shrink:0}

/* Recommendations */
.assm-recs{margin-top:4px}
.assm-recs-title{font-size:15px;font-weight:700;color:var(--tx);margin-bottom:12px}
.assm-rec-group{margin-bottom:12px}
.assm-rec-group-title{font-size:12px;font-weight:700;margin-bottom:6px}
.assm-rec-card{padding:12px;background:var(--surf);border:1px solid var(--border);border-radius:var(--rad);margin-bottom:6px}
.assm-rec-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.assm-rec-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.3px}
.assm-rec-pillar{font-size:11px;color:var(--tx3)}
.assm-rec-offering{font-size:13px;font-weight:600;color:var(--tx);margin-bottom:2px}
.assm-rec-impact{font-size:12px;color:var(--tx2);line-height:1.4}
.assm-rec-signal{font-size:11px;color:var(--tx3);margin-top:4px}

/* Errors/notes */
.assm-errors{margin-top:12px;padding:12px;background:var(--raised);border-radius:var(--rad)}
.assm-errors-title{font-size:12px;font-weight:700;color:var(--tx2);margin-bottom:6px}
.assm-error-item{font-size:12px;color:var(--tx3);padding:2px 0}

/* Stats pills */
.assm-stats-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.assm-stat-pill{display:flex;flex-direction:column;align-items:center;padding:10px 16px;background:var(--surf);border:1px solid var(--border);border-radius:var(--rad);min-width:80px}
.assm-stat-val{font-size:20px;font-weight:800;color:var(--tx)}
.assm-stat-label{font-size:10px;font-weight:600;color:var(--tx3);text-transform:uppercase;letter-spacing:0.5px;margin-top:2px}

/* History filter bar */
.assm-filter-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.assm-source-filter{padding:4px 12px;border-radius:20px;border:1px solid var(--border);background:none;font-size:12px;font-weight:500;color:var(--tx2);cursor:pointer;font-family:var(--font);transition:all .12s}
.assm-source-filter.active{background:var(--b);color:#fff;border-color:var(--b)}
.assm-source-filter:hover:not(.active){border-color:var(--tx3);color:var(--tx)}
.assm-search-input{padding:6px 12px;border:1px solid var(--border);border-radius:var(--rad);font-size:12px;font-family:var(--font);background:var(--surf);color:var(--tx);min-width:180px}
.assm-search-input:focus{outline:none;border-color:var(--b)}

/* History grid */
.assm-history-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));gap:10px}
.assm-history-card{background:var(--surf);border:1px solid var(--border);border-radius:var(--rad);padding:14px;cursor:pointer;transition:all .15s}
.assm-history-card:hover{box-shadow:var(--shadow-h);border-color:var(--b)}
.assm-history-top{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.assm-history-score{font-size:22px;font-weight:800;flex-shrink:0}
.assm-history-domain{font-size:14px;font-weight:600;color:var(--tx);word-break:break-all;line-height:1.3}
.assm-history-name{font-size:12px;color:var(--tx2);margin-bottom:6px;margin-left:42px}
.assm-history-pillars{display:flex;gap:10px;margin-bottom:8px;margin-left:42px}
.assm-mini-pillar{font-size:11px;color:var(--tx2);display:flex;align-items:center;gap:3px}
.assm-mini-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.assm-history-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.assm-source-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;background:var(--raised);color:var(--tx2)}
.assm-history-date{font-size:11px;color:var(--tx3)}

/* Pagination */
.assm-pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px;padding:12px 0}
.assm-page-info{font-size:12px;color:var(--tx3)}

/* Mobile */
@media(max-width:600px){
  .assm-form{flex-direction:column}
  .assm-field{width:100%}
  .assm-domain-field{min-width:0}
  #assm-run-btn{width:100%;justify-content:center}
  .assm-result-header{flex-direction:column;text-align:center;gap:12px}
  .assm-pillars{grid-template-columns:1fr}
  .assm-signal-name{width:90px;font-size:10px}
  .assm-history-grid{grid-template-columns:1fr}
  .assm-header{flex-direction:column;align-items:flex-start}
}

/* ============ Unified Audits Tab ============ */
#page-audits{flex-direction:column;overflow:hidden}
.aud-topbar{flex-shrink:0;padding:10px 24px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;align-items:center;gap:12px}
.aud-topbar-title{font-size:14px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:var(--tx)}
.aud-dashboard{flex:1;overflow-y:auto;padding:0 24px 48px}

/* Source badges */
.aud-source-badge{font-size:9px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;display:inline-block}
.aud-source-scouting{background:var(--b-glow);color:var(--b);border:1px solid rgba(74,124,255,.2)}
.aud-source-website{background:rgba(16,185,129,.1);color:#10B981;border:1px solid rgba(16,185,129,.25)}
.aud-source-manual{background:var(--raised);color:var(--tx3);border:1px solid var(--border)}

/* Method badges */
.aud-method-badge{font-size:9px;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;display:inline-block}
.aud-method-auto{background:rgba(74,124,255,.06);color:var(--b);border:1px solid rgba(74,124,255,.15)}
.aud-method-manual{background:var(--raised);color:var(--tx3);border:1px solid var(--border)}

/* Mini pillar scores in table */
.aud-pillar-mini{font-size:11px;font-weight:700;font-family:var(--mono)}

/* Lead link icon */
.aud-lead-link{cursor:pointer;font-size:14px;opacity:.6;transition:opacity .12s}
.aud-lead-link:hover{opacity:1}

/* Run Audit Modal */
.aud-run-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:9990;display:none}
.aud-run-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surf);border-radius:12px;padding:24px;width:400px;max-width:90vw;z-index:9991;box-shadow:0 8px 32px rgba(0,0,0,.2);display:none}
.aud-run-modal h3{margin:0 0 16px;font-size:15px;font-weight:700}
.aud-run-field{margin-bottom:12px}
.aud-run-field label{display:block;font-size:11px;font-weight:600;color:var(--tx3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.aud-run-field input,.aud-run-field select{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--rad);font-size:13px;font-family:var(--font);background:var(--surf);color:var(--tx)}
.aud-run-field input:focus,.aud-run-field select:focus{outline:none;border-color:var(--b)}
.aud-run-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}

@media(max-width:600px){
  .aud-topbar{padding:8px 12px;gap:8px;flex-wrap:wrap}
  .aud-dashboard{padding:0 12px 48px}
  .aud-run-modal{width:calc(100vw - 32px)}
}

/* Reader overlay (reusable) */
.reader-overlay{display:none;position:fixed;inset:0;z-index:250;background:var(--bg);flex-direction:column}
.reader-overlay.open{display:flex}
.reader-topbar{height:48px;display:flex;align-items:center;padding:0 16px;gap:12px;border-bottom:1px solid var(--border);background:var(--surf);flex-shrink:0}
.reader-title{font-size:13px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.reader-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.reader-body iframe{width:100%;border:none;display:block}

/* iOS safe areas */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .slide-panel,.ls-panel,.crm-panel{padding-bottom:env(safe-area-inset-bottom)}
  .ls-dashboard,.crm-content,.docs-content-panel,.admin-content,.assm-wrapper,.aud-dashboard{padding-bottom:calc(48px + env(safe-area-inset-bottom))}
}
