/* ============================================================
   CRM — Single Entity Edition | stylesheet (no frameworks)
   ============================================================ */
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
     font-size:14px;color:#0f172a;background:#f1f5f9}
a{color:#0369a1}

/* ---- App shell ---- */
.app{display:flex;min-height:100vh}
.sidebar{width:220px;background:#0f172a;flex-shrink:0;display:flex;flex-direction:column}
.brand{padding:18px 16px;font-weight:700;color:#fff;font-size:16px}
.sidebar nav{display:flex;flex-direction:column;padding:0 8px}
.sidebar nav a{padding:8px 12px;margin:2px 0;border-radius:8px;color:#cbd5e1;
               text-decoration:none;font-size:14px}
.sidebar nav a:hover{background:#1e293b;color:#fff}
.navlabel{padding:16px 16px 4px;font-size:10px;text-transform:uppercase;
          color:#64748b;letter-spacing:1px}
main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;justify-content:space-between;align-items:center;
        padding:10px 20px;background:#fff;border-bottom:1px solid #e2e8f0}
.topbar-right{display:flex;align-items:center;gap:14px}
.bell{position:relative;font-size:18px;text-decoration:none}
.bell .dot{position:absolute;top:-6px;right:-12px;background:#dc2626;color:#fff;
           border-radius:10px;font-size:10px;padding:1px 5px;font-weight:700}
.who small{color:#64748b}
.page{padding:20px;max-width:1400px;width:100%;margin:0 auto}

/* ---- Typography / layout blocks ---- */
h1{font-size:22px;margin:0 0 14px}
h2{font-size:15px;margin:0 0 12px;color:#334155}
h3{font-size:12px;margin:18px 0 8px;color:#475569;text-transform:uppercase;letter-spacing:.5px}
.page-head{display:flex;justify-content:space-between;align-items:center;
           gap:10px;flex-wrap:wrap;margin-bottom:14px}
.page-head h1,.page-head h2{margin:0}
.card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;
      padding:16px;margin-bottom:16px}
.card.narrow{max-width:640px}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:1000px){.cols{grid-template-columns:1fr}}

/* ---- Stats ---- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
       gap:12px;margin-bottom:16px}
.stat{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px}
.stat-num{font-size:19px;font-weight:700;white-space:nowrap}
.stat-lbl{font-size:12px;color:#64748b;margin-top:2px}

/* ---- Tables ---- */
table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;font-size:11px;text-transform:uppercase;color:#64748b;
   padding:8px;border-bottom:2px solid #e2e8f0}
td{padding:8px;border-bottom:1px solid #f1f5f9;vertical-align:middle}
tbody tr:hover td{background:#f8fafc}
table.kv th{width:130px;text-transform:none;font-size:13px;color:#475569;
            border:0;vertical-align:top;padding:5px 8px}
table.kv td{border:0;padding:5px 8px}
.ta-r{text-align:right}
code{background:#f1f5f9;padding:1px 5px;border-radius:4px;font-size:12px}

/* ---- Buttons ---- */
.btn{display:inline-block;padding:8px 14px;border-radius:8px;border:1px solid #cbd5e1;
     background:#fff;color:#0f172a;font-size:13px;cursor:pointer;text-decoration:none;
     font-family:inherit;line-height:1.2}
.btn:hover{background:#f1f5f9}
.btn.primary{background:#0ea5e9;border-color:#0ea5e9;color:#fff}
.btn.primary:hover{background:#0284c7}
.btn.danger{border-color:#fca5a5;color:#dc2626}
.btn.danger:hover{background:#fef2f2}
.btn.ghost{background:transparent}
.btn-sm{padding:4px 9px;font-size:12px}
.wide{width:100%}
.btn-row{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0}
.chk{width:26px;height:26px;border-radius:50%;border:1px solid #cbd5e1;background:#fff;
     cursor:pointer;font-size:12px;flex-shrink:0}
.chk:hover{background:#dcfce7;border-color:#16a34a}

/* ---- Forms ---- */
label{display:block;font-size:12px;color:#475569;margin:10px 0 4px}
input,select,textarea{width:100%;padding:9px 10px;border:1px solid #cbd5e1;
     border-radius:8px;font:inherit;background:#fff;color:#0f172a}
input:focus,select:focus,textarea:focus{outline:2px solid #bae6fd;border-color:#0ea5e9}
input[type=checkbox]{width:auto;padding:0}
input[type=color]{padding:2px;height:36px}
label.check{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:13px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
@media(max-width:700px){.grid2{grid-template-columns:1fr}}
.actions{margin-top:16px;display:flex;gap:8px;align-items:center}
.filters{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.filters input,.filters select{width:auto}
.inline{display:inline}
.inline-row{display:flex;gap:8px;align-items:center}
.inline-row input{width:auto;flex:1}
.grid-note{display:grid;grid-template-columns:110px 1fr auto;gap:8px;margin-bottom:14px}
.grid-note input,.grid-note select{margin:0}

/* ---- Badges / tags / flash ---- */
.badge{padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.b-gray{background:#e2e8f0;color:#334155}
.b-blue{background:#e0f2fe;color:#0369a1}
.b-amber{background:#fef3c7;color:#b45309}
.b-green{background:#dcfce7;color:#15803d}
.b-red{background:#fee2e2;color:#b91c1c}
.tag{background:#f1f5f9;border-radius:6px;padding:1px 7px;font-size:11px;
     color:#475569;text-decoration:none;white-space:nowrap}
.flash{padding:10px 14px;border-radius:8px;margin:12px 20px 0}
.f-ok{background:#dcfce7;color:#14532d}
.f-err{background:#fee2e2;color:#7f1d1d}
.muted{color:#64748b}
.overdue{color:#dc2626;font-weight:600}

/* ---- Timeline / task rows ---- */
.task-row{display:flex;align-items:center;gap:10px;padding:7px 0;
          border-bottom:1px solid #f1f5f9}
.task-row>span{flex:1}
.feed-row{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid #f1f5f9;
          align-items:baseline;flex-wrap:wrap}
.feed-row>span:nth-child(2){flex:1;min-width:200px}
.feed-type{font-size:10px;text-transform:uppercase;padding:2px 6px;border-radius:4px;
           background:#e2e8f0;color:#334155;flex-shrink:0}
.t-call{background:#e0f2fe;color:#0369a1}
.t-email{background:#fef3c7;color:#b45309}
.t-meeting{background:#ede9fe;color:#6d28d9}
.t-system{background:#f1f5f9;color:#94a3b8}

/* ---- Bar charts ---- */
.bar-row{display:flex;align-items:center;gap:10px;margin:8px 0}
.bar-lbl{width:150px;font-size:13px;flex-shrink:0}
.bar-track{flex:1;background:#f1f5f9;border-radius:6px;height:16px;overflow:hidden}
.bar{height:100%;border-radius:6px;background:#0ea5e9;min-width:2px}
.bar-val{width:130px;text-align:right;font-size:12px;color:#475569;flex-shrink:0}

/* ---- Kanban ---- */
.board{display:flex;gap:12px;overflow-x:auto;padding-bottom:10px;align-items:flex-start}
.col{min-width:250px;width:250px;background:#e9eef5;border-radius:10px;flex-shrink:0}
.col.over{outline:2px dashed #0ea5e9;outline-offset:-2px}
.col-head{padding:10px 12px;display:flex;justify-content:space-between;align-items:baseline;
          background:#fff;border-radius:10px 10px 0 0;border-bottom:1px solid #e2e8f0;gap:6px}
.col-body{padding:10px;min-height:70px;display:flex;flex-direction:column;gap:8px}
.deal-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:10px;cursor:grab}
.deal-card.dragging{opacity:.5}
.deal-card a{color:#0f172a;text-decoration:none;font-weight:600;font-size:13px}
.deal-amt{color:#0369a1;font-weight:700;font-size:13px;margin:3px 0}
.stage-pill{color:#fff;padding:3px 10px;border-radius:14px;font-size:12px;
            vertical-align:middle;white-space:nowrap}

/* ---- Misc ---- */
.pager{display:flex;gap:10px;align-items:center;justify-content:center;margin:14px 0}
.totals{margin:14px 0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.totals .grand{font-size:16px}
pre.snippet{background:#0f172a;color:#e2e8f0;padding:12px;border-radius:8px;
            overflow-x:auto;font-size:12px;line-height:1.5}

/* ---- Auth page ---- */
.auth-body{background:#0f172a;display:flex;align-items:center;justify-content:center;
           min-height:100vh}
.auth-card{background:#1e293b;padding:32px;border-radius:14px;width:360px;color:#e2e8f0}
.auth-card h1{color:#fff;font-size:20px;margin-bottom:4px}
.auth-card label{color:#94a3b8}
.auth-card input{background:#0f172a;border-color:#334155;color:#e2e8f0}
.auth-card .flash{margin:0 0 12px}
.auth-card .btn{margin-top:16px}
