:root {
  --bg:        #faf7f2;
  --sidebar:   #f2efe8;
  --card:      #ffffff;
  --card-2:    #f7f4ef;
  --border:    #e8e4dd;
  --border-2:  #dbd7d0;
  --text-1:    #1a1a1a;
  --text-2:    #555555;
  --text-3:    #888888;
  --green:     #10a37f;
  --green-dim: rgba(16,163,127,0.08);
  --amber:     #b45309;
  --amber-dim: rgba(180,83,9,0.10);
  --red:       #ef4444;
  --red-dim:   rgba(239,68,68,0.12);
  --blue:      #3b82f6;
  --blue-dim:  rgba(59,130,246,0.12);
  --purple:    #0d8a6a;
  --accent:    #10a37f;
  --accent-dim:rgba(16,163,127,0.10);
  --radius:    8px;
  --gap:       14px;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text-1);height:100vh;display:flex;overflow:hidden;font-size:13px;}

/* ── SIDEBAR ── */
.sidebar{width:210px;flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
.sidebar-brand{padding:18px 16px 14px;border-bottom:1px solid var(--border);}
.brand-logo{display:flex;align-items:center;gap:8px;margin-bottom:2px;}
.brand-icon{width:28px;height:28px;background:linear-gradient(135deg,#10a37f,#1bc47d);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0;}
.brand-name{font-size:14px;font-weight:800;color:#44403c;letter-spacing:0.3px;}
.brand-sub{font-size:10px;color:var(--text-3);margin-top:1px;}

.sidebar-section{padding:14px 10px 6px;}
.sidebar-section-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#44403c;padding:0 6px;margin-bottom:6px;}

.prop-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius);cursor:pointer;transition:background 0.15s;margin-bottom:2px;user-select:none;}
.prop-item:hover{background:rgba(0,0,0,0.03);}
.prop-item.active{background:var(--accent-dim);border:1px solid rgba(16,163,127,0.25);}
.prop-item.locked{opacity:0.4;cursor:default;}
.prop-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.prop-dot.green{background:var(--green);}
.prop-dot.grey{background:var(--text-3);}
.prop-info{flex:1;min-width:0;}
.prop-name{font-size:11px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.prop-units{font-size:9px;color:var(--text-3);margin-top:1px;}
.prop-lock{font-size:10px;color:var(--text-3);}
.prop-pm{font-size:8px;color:var(--text-3);margin-top:1px;display:flex;align-items:center;gap:3px;}

.sidebar-divider{height:1px;background:var(--border);margin:10px 16px;}

.ytd-box{margin:10px;background:var(--card);border-radius:var(--radius);padding:12px;border:1px solid var(--border);}
.ytd-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--text-3);margin-bottom:8px;}
.ytd-stat{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px;}
.ytd-stat-name{font-size:10px;color:var(--text-2);}
.ytd-stat-val{font-size:11px;font-weight:700;color:var(--text-1);}
.ytd-stat-val.green{color:var(--green);}
.ytd-rate-bar{height:4px;background:var(--border-2);border-radius:2px;margin-top:8px;overflow:hidden;}
.ytd-rate-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--green),#34d399);}

.sidebar-footer{margin-top:auto;padding:12px 16px;border-top:1px solid var(--border);}
.sidebar-footer-text{font-size:9px;color:var(--text-3);line-height:1.5;}

/* ── SECTION NAV ── */
.snav-tab{padding:8px 14px;font-size:11px;font-weight:600;color:var(--text-3);cursor:pointer;border-bottom:2px solid transparent;transition:all 0.15s;user-select:none;white-space:nowrap;}
.snav-tab:hover{color:var(--text-1);}
.snav-tab.active{color:#44403c;border-bottom-color:#44403c;}

/* ── SECTION CONTENT CARDS ── */
.sec-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--gap);}
.sec-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.sec-title{font-size:13px;font-weight:700;color:#44403c;}
.sec-sub{font-size:10px;color:var(--text-3);margin-top:2px;}
.btn-primary{padding:7px 14px;background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;}
.btn-primary:hover{background:#0b7d62;}
.btn-ghost{padding:6px 12px;background:transparent;border:1px solid var(--border-2);border-radius:6px;color:var(--text-2);font-size:11px;font-weight:600;cursor:pointer;}
.btn-ghost:hover{background:rgba(0,0,0,0.03);}
.btn-danger{padding:5px 10px;background:transparent;border:1px solid rgba(239,68,68,0.3);border-radius:5px;color:#ef4444;font-size:10px;cursor:pointer;}

/* ── DOCUMENTS ── */
.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;padding:14px 16px;}
.doc-item{background:var(--card-2);border:1px solid var(--border);border-radius:6px;padding:12px;display:flex;flex-direction:column;gap:6px;position:relative;}
.doc-item:hover{border-color:var(--border-2);}
.doc-icon{font-size:22px;line-height:1;}
.doc-name{font-size:11px;font-weight:600;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.doc-meta{font-size:9px;color:var(--text-3);}
.doc-cat{font-size:9px;font-weight:700;padding:1px 6px;border-radius:3px;width:fit-content;}
/* Document list view */
.doc-list{display:flex;flex-direction:column;padding:4px 16px 14px;}
.doc-row{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:6px;transition:background 0.15s;}
.doc-row:hover{background:var(--card-2);}
.doc-row+.doc-row{border-top:1px solid var(--border);}
.doc-row:hover+.doc-row{border-top-color:transparent;}
.doc-row-icon{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--card-2);border:1px solid var(--border);border-radius:6px;font-size:14px;}
.doc-row:hover .doc-row-icon{border-color:var(--border-2);}
.doc-row-info{flex:1;min-width:0;}
.doc-row-name{font-size:12px;font-weight:600;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.doc-row-meta{font-size:10px;color:var(--text-3);margin-top:1px;}
.doc-row-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;}
.cat-lease{background:rgba(16,185,129,0.15);color:#10b981;}
.cat-bill{background:rgba(180,83,9,0.15);color:#f59e0b;}
.cat-vendor{background:rgba(16,163,127,0.15);color:#0d8a6a;}
.cat-insurance{background:rgba(59,130,246,0.12);color:#2563eb;}
.cat-propMgmt{background:rgba(236,72,153,0.15);color:#f472b6;}
.cat-fin{background:rgba(16,163,127,0.12);color:#10a37f;}
.cat-other{background:rgba(107,114,128,0.15);color:#9ca3af;}
.drop-zone{border:2px dashed var(--border-2);border-radius:8px;padding:28px;text-align:center;cursor:pointer;transition:all 0.2s;margin:14px 16px;}
.drop-zone:hover,.drop-zone.dragover{border-color:#10a37f;background:var(--accent-dim);}
.drop-zone-text{font-size:12px;color:var(--text-3);margin-top:8px;}

/* ── ACTION ITEMS ── */
.action-item{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:12px;}
.action-item:last-child{border-bottom:none;}
.action-item:hover{background:rgba(0,0,0,0.015);}
.ai-status{width:16px;height:16px;border-radius:50%;border:2px solid var(--border-2);flex-shrink:0;margin-top:2px;cursor:pointer;}
.ai-status.open{border-color:#6b7280;}
.ai-status.in-progress{border-color:#f59e0b;background:rgba(180,83,9,0.2);}
.ai-status.done{border-color:#10b981;background:#10b981;}
.ai-title{font-size:12px;font-weight:600;color:var(--text-1);}
.ai-title.done{text-decoration:line-through;color:var(--text-3);}
.ai-meta{font-size:10px;color:var(--text-3);margin-top:2px;}
.ai-badges{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap;}
.badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;}
.badge-high{background:rgba(239,68,68,0.15);color:#ef4444;}
.badge-med{background:rgba(180,83,9,0.15);color:#f59e0b;}
.badge-low{background:rgba(107,114,128,0.15);color:#9ca3af;}
.badge-owner{background:rgba(16,163,127,0.15);color:#0d8a6a;}

/* ── NOTES ── */
.note-item{padding:14px 16px;border-bottom:1px solid var(--border);}
.note-item:last-child{border-bottom:none;}
.note-header{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.note-avatar{width:24px;height:24px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;flex-shrink:0;}
.note-author{font-size:11px;font-weight:700;color:var(--text-1);}
.note-time{font-size:10px;color:var(--text-3);}
.note-body{font-size:12px;color:var(--text-2);line-height:1.6;white-space:pre-wrap;}

/* ── PHOTOS ── */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;padding:14px 16px;}
.photo-item{border-radius:8px;overflow:hidden;background:var(--card-2);border:1px solid var(--border);position:relative;cursor:pointer;}
.photo-item img{width:100%;height:140px;object-fit:cover;display:block;}
.photo-caption{padding:8px 10px;font-size:11px;color:var(--text-2);}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:1000;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px);}
.modal{background:var(--card);border:1px solid var(--border-2);border-radius:12px;padding:24px;width:480px;max-width:95vw;max-height:90vh;overflow-y:auto;}
.modal-title{font-size:14px;font-weight:800;color:#44403c;margin-bottom:16px;}
.form-group{margin-bottom:14px;}
.form-label{font-size:11px;font-weight:600;color:var(--text-2);margin-bottom:5px;display:block;}
.form-input{width:100%;padding:8px 12px;background:#f2efe8;border:1px solid var(--border-2);border-radius:6px;color:var(--text-1);font-size:12px;outline:none;}
.form-input:focus{border-color:#10a37f;}
.form-select{width:100%;padding:8px 12px;background:#f2efe8;border:1px solid var(--border-2);border-radius:6px;color:var(--text-1);font-size:12px;outline:none;appearance:none;}
.form-textarea{width:100%;padding:8px 12px;background:#f2efe8;border:1px solid var(--border-2);border-radius:6px;color:var(--text-1);font-size:12px;outline:none;resize:vertical;min-height:80px;}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:18px;}

/* ── MAIN ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;}

/* Top bar */
.topbar{padding:0 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;height:54px;flex-shrink:0;gap:16px;}
.topbar-left{}
.topbar-title{font-size:15px;font-weight:700;color:#44403c;}
.topbar-sub{font-size:10px;color:var(--text-3);margin-top:1px;}
.month-tabs{display:flex;gap:4px;}
.mtab{padding:5px 14px;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;color:var(--text-2);background:transparent;border:1px solid transparent;transition:all 0.15s;user-select:none;}
.mtab:hover{background:rgba(0,0,0,0.03);color:var(--text-1);}
.mtab.active{background:rgba(68,64,60,0.08);color:#44403c;border-color:rgba(68,64,60,0.2);}
.mtab.partial{position:relative;}
.mtab.partial::after{content:'•';position:absolute;top:2px;right:4px;font-size:8px;color:var(--amber);}

/* Content scroll area */
.content{flex:1;overflow-y:auto;padding:16px 20px 32px;}
.content::-webkit-scrollbar{width:6px;}
.content::-webkit-scrollbar-track{background:transparent;}
.content::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:3px;}

/* Alert banner */
.alert{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-radius:var(--radius);font-size:11px;margin-bottom:var(--gap);border:1px solid;}
.alert-warn{background:rgba(180,83,9,0.06);border-color:rgba(180,83,9,0.2);color:#b45309;}
.alert-info{background:rgba(16,163,127,0.08);border-color:rgba(16,163,127,0.2);color:#0d8a6a;}
.alert-icon{flex-shrink:0;margin-top:1px;}
.alert strong{font-weight:700;}

/* KPI row */
.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--gap);margin-bottom:var(--gap);}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;position:relative;overflow:hidden;}
.kpi-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.7px;color:var(--text-3);margin-bottom:4px;}
.kpi-val{font-size:22px;font-weight:800;line-height:1;color:var(--text-1);}
.kpi-val.green{color:var(--green);}
.kpi-val.amber{color:var(--amber);}
.kpi-val.blue{color:var(--blue);}
.kpi-sub{font-size:9px;color:var(--text-3);margin-top:4px;}
.kpi-accent-bar{position:absolute;bottom:0;left:0;right:0;height:2px;}

/* Two-column: chart + table */
.row-2col{display:grid;grid-template-columns:320px 1fr;gap:var(--gap);margin-bottom:var(--gap);}

/* Chart card */
.chart-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;}
.card-title{font-size:11px;font-weight:700;color:#44403c;margin-bottom:2px;}
.card-sub{font-size:10px;color:var(--text-3);margin-bottom:14px;}
.chart-wrap{position:relative;}

/* Table card */
.table-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.table-card-header{padding:14px 16px 12px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.table-overflow{overflow-x:auto;}

table{width:100%;border-collapse:collapse;font-size:11px;}
thead th{padding:8px 12px;text-align:left;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-3);background:rgba(0,0,0,0.015);border-bottom:1px solid var(--border);cursor:pointer;user-select:none;white-space:nowrap;}
thead th:hover{color:var(--text-2);}
thead th.sort-asc::after{content:' ▲';}
thead th.sort-desc::after{content:' ▼';}
thead th.r{text-align:right;}
tbody td{padding:10px 12px;border-bottom:1px solid rgba(0,0,0,0.025);vertical-align:middle;}
tbody tr:last-child td{border-bottom:none;}
tbody tr:hover{background:rgba(0,0,0,0.02);}
tbody td.r{text-align:right;}

.unit-name{font-weight:700;color:var(--text-1);}
.unit-addr{font-size:9px;color:var(--text-3);margin-top:1px;}
.tenant-name{color:var(--text-1);}
.tenant-since{font-size:9px;color:var(--text-3);margin-top:1px;}
.lease-end{font-size:11px;}
.lease-soon{color:var(--amber);font-weight:600;}
.lease-ok{color:var(--text-3);}
.lease-mtm{color:var(--text-3);font-style:italic;}
.amt{font-variant-numeric:tabular-nums;font-weight:600;}
.amt-green{color:var(--green);}
.amt-zero{color:var(--text-3);}
.amt-red{color:var(--red);}
.bal-owed{color:var(--amber);font-weight:600;}
.bal-clear{color:var(--text-3);}
.bal-credit{color:var(--text-3);font-style:italic;font-size:9px;}
.bal-prior{font-size:9px;color:var(--amber);}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;white-space:nowrap;}
.badge-dot{width:5px;height:5px;border-radius:50%;}
.badge-paid{background:rgba(16,185,129,0.15);color:#34d399;}
.badge-paid .badge-dot{background:var(--green);}
.badge-paid-bal{background:rgba(180,83,9,0.12);color:#b45309;}
.badge-paid-bal .badge-dot{background:var(--amber);}
.badge-unpaid{background:rgba(239,68,68,0.12);color:#f87171;}
.badge-unpaid .badge-dot{background:var(--red);}
.badge-pending{background:rgba(156,163,175,0.1);color:#9ca3af;}
.badge-pending .badge-dot{background:var(--text-2);}

/* Source chips */
.chip{display:inline-flex;align-items:center;padding:1px 6px;border-radius:4px;font-size:9px;font-weight:700;letter-spacing:0.3px;}
.chip-dl{background:rgba(59,130,246,0.15);color:#93c5fd;}
.chip-zr{background:rgba(139,92,246,0.15);color:#c4b5fd;}

/* Trend chart full-width */
.trend-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:var(--gap);}
.trend-wrap{position:relative;height:160px;}

/* Month-in-progress badge */
.month-partial-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:9px;font-weight:600;background:var(--amber-dim);color:var(--amber);border:1px solid rgba(180,83,9,0.2);margin-left:8px;}

/* Summary row at bottom of table */
.table-summary td{background:rgba(0,0,0,0.025);font-weight:700;color:var(--text-1);border-top:1px solid var(--border-2)!important;}
.table-summary .amt-green{color:var(--green);}

/* Empty state */
.no-data{text-align:center;padding:40px;color:var(--text-3);font-size:12px;}

@media(max-width:1100px){
  .kpi-row{grid-template-columns:repeat(3,1fr);}
  .row-2col{grid-template-columns:1fr;}
}

/* ── P&L TABLE ── */
.pnl-table{width:100%;border-collapse:collapse;font-size:11px;}
.pnl-table thead th{padding:9px 12px;text-align:right;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-3);background:rgba(0,0,0,0.015);border-bottom:1px solid var(--border);white-space:nowrap;}
.pnl-table thead th:first-child{text-align:left;min-width:210px;}
.pnl-col-ytd{background:rgba(16,163,127,0.06)!important;color:#0d8a6a!important;}
.pnl-col-partial{color:var(--amber)!important;}
.pnl-section-hdr td{padding:9px 14px 5px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:1.2px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.pnl-income-hdr td{color:#34d399;background:rgba(16,185,129,0.05);}
.pnl-expense-hdr td{color:var(--amber);background:rgba(180,83,9,0.05);}
.pnl-debt-hdr td{color:#f87171;background:rgba(239,68,68,0.05);}
.pnl-capex-hdr td{color:#c084fc;background:rgba(192,132,252,0.05);}
.pnl-row td{padding:7px 12px;border-bottom:1px solid rgba(255,255,255,0.03);vertical-align:middle;}
.pnl-row td:first-child{padding-left:26px;color:var(--text-2);}
.pnl-row td:not(:first-child){text-align:right;}
.pnl-row:hover td{background:rgba(0,0,0,0.015);}
.pnl-ytd-cell{background:rgba(16,163,127,0.04);}
.pnl-sub td{padding:8px 12px;border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2);font-weight:700;background:rgba(0,0,0,0.02);}
.pnl-sub td:first-child{padding-left:14px;}
.pnl-sub td:not(:first-child){text-align:right;}
.pnl-sub .pnl-ytd-cell{background:rgba(16,163,127,0.08);}
.pnl-noi td{padding:11px 12px;font-weight:800;font-size:12px;background:rgba(16,163,127,0.07);border-top:2px solid rgba(16,163,127,0.35);border-bottom:2px solid rgba(16,163,127,0.35);}
.pnl-noi td:first-child{padding-left:14px;color:#0d8a6a;}
.pnl-noi td:not(:first-child){text-align:right;}
.pnl-noi .pnl-ytd-cell{background:rgba(16,163,127,0.14);}
.pnl-profit td{padding:11px 12px;font-weight:800;font-size:13px;background:rgba(16,185,129,0.07);border-top:2px solid rgba(16,185,129,0.35);border-bottom:2px solid rgba(16,185,129,0.35);}
.pnl-profit td:first-child{padding-left:14px;color:var(--green);}
.pnl-profit td:not(:first-child){text-align:right;}
.pnl-profit .pnl-ytd-cell{background:rgba(16,185,129,0.13);}
.pnl-miss{color:var(--text-3);font-size:9px;font-style:italic;}
.pnl-zero{color:var(--text-3);}
.pnl-note{font-size:9px;color:var(--text-3);margin-top:2px;font-weight:400;}

/* ── MEETING CHECKLIST ── */
.cl-section{border-top:1px solid var(--border);padding:0;}
.cl-section:first-child{border-top:none;}
.cl-section-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;}
.cl-section-title{font-size:12px;font-weight:700;color:#44403c;display:flex;align-items:center;gap:6px;}
.cl-items{padding:0 16px 14px;}
.cl-item{background:var(--card-2);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden;transition:border-color 0.15s;}
.cl-item:hover{border-color:var(--border-2);}
.cl-item-closed{opacity:0.6;}
.cl-item-closed .cl-item-title{text-decoration:line-through;color:var(--text-3);}
.cl-item-overdue{border-color:rgba(239,68,68,0.35);}
.cl-item-main{display:flex;align-items:flex-start;gap:0;}
.cl-num{width:36px;min-height:48px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:var(--text-3);background:rgba(0,0,0,0.02);border-right:1px solid var(--border);flex-shrink:0;}
.cl-item-body{flex:1;padding:10px 12px;min-width:0;}
.cl-item-top{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;}
.cl-item-title{font-size:12px;font-weight:600;color:var(--text-1);flex:1;min-width:0;}
.cl-item-controls{display:flex;align-items:center;gap:6px;flex-shrink:0;flex-wrap:wrap;}
.cl-status-select{padding:3px 8px;border-radius:4px;font-size:9px;font-weight:700;border:1px solid;cursor:pointer;outline:none;appearance:none;text-align:center;min-width:85px;}
.cl-not-started{background:rgba(107,114,128,0.1);border-color:rgba(107,114,128,0.25);color:#6b7280;}
.cl-in-progress{background:rgba(180,83,9,0.1);border-color:rgba(180,83,9,0.25);color:#b45309;}
.cl-closed{background:rgba(16,185,129,0.1);border-color:rgba(16,185,129,0.25);color:#10b981;}
.cl-due{font-size:10px;color:var(--text-3);display:flex;align-items:center;gap:3px;white-space:nowrap;}
.cl-due-overdue{color:#ef4444;font-weight:600;}
.cl-comments{padding:8px 0 4px;border-top:1px solid var(--border);margin-top:8px;}
.cl-comment{padding:3px 0;font-size:10px;display:flex;gap:6px;align-items:baseline;}
.cl-comment-meta{color:var(--text-3);font-weight:600;white-space:nowrap;font-size:9px;}
.cl-comment-text{color:var(--text-2);}
.cl-add-comment{display:flex;gap:6px;margin-top:6px;align-items:center;}
/* Contact cards */
.cl-contact-card{background:var(--card-2);border:1px solid var(--border);border-radius:8px;padding:12px 14px;}
.cl-contact-role{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-3);margin-bottom:4px;}
.cl-contact-name{font-size:12px;font-weight:700;color:var(--text-1);margin-bottom:6px;}
.cl-contact-line{font-size:10px;color:var(--text-2);margin-bottom:3px;}
/* Monthly per-month */
.cl-month-section{border:1px solid var(--border);border-radius:8px;margin:0 16px 10px;overflow:hidden;}
.cl-month-current{border-color:rgba(16,163,127,0.35);background:rgba(16,163,127,0.02);}
.cl-month-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:rgba(0,0,0,0.015);}
.cl-month-label{font-size:12px;color:var(--text-1);display:flex;align-items:center;gap:4px;}
.cl-month-badge{font-size:9px;font-weight:700;padding:2px 8px;border-radius:4px;}
.cl-month-pct{font-size:11px;font-weight:700;margin-left:4px;}
/* Collapsed past months */
.cl-month-summary{margin:0 16px 6px;border:1px solid var(--border);border-radius:8px;cursor:pointer;overflow:hidden;transition:all 0.15s;}
.cl-month-summary:hover{border-color:var(--border-2);}
.cl-month-done{opacity:0.6;}
.cl-month-done:hover{opacity:0.85;}
.cl-month-incomplete{border-color:rgba(180,83,9,0.25);background:rgba(180,83,9,0.02);}
.cl-month-bar{display:flex;align-items:center;gap:10px;padding:8px 14px;}
.cl-month-detail{display:none;padding:4px 14px 10px;border-top:1px solid var(--border);}
.cl-month-expanded .cl-month-detail{display:block;}
