/* Call & Voicemail Hub ("office brain") dashboard. Dark-mode via body.dark-mode. */

.ch-header { padding: 16px 20px 0; }
.ch-toolbar {
    display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
    margin-top: 12px; padding-bottom: 12px;
}
.ch-field, .ch-check { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--text-secondary); }
.ch-select, .ch-search {
    background: var(--bg-input); color: var(--text);
    border: 1px solid var(--border); border-radius: 8px; padding: 6px 10px; font-size: 13px;
}
.ch-search { min-width: 240px; flex: 1 1 240px; }
.ch-btn {
    background: var(--bg-input); color: var(--text); border: 1px solid var(--border);
    border-radius: 8px; padding: 6px 12px; font-size: 13px; cursor: pointer;
}
.ch-btn:hover { border-color: var(--apple-blue); }
.ch-status-msg { font-size: 12px; color: var(--text-secondary); }
.ch-status-msg[data-error="1"] { color: #ff6b6b; }

.ch-container { display: grid; grid-template-columns: minmax(280px, 360px) 1fr; gap: 16px; padding: 0 20px 24px; }
@media (max-width: 800px) { .ch-container { grid-template-columns: 1fr; } }

.ch-list { display: flex; flex-direction: column; gap: 8px; }
.ch-row {
    text-align: left; width: 100%; cursor: pointer;
    background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px;
    padding: 12px; display: flex; flex-direction: column; gap: 6px; color: var(--text);
}
.ch-row:hover { border-color: var(--apple-blue); }
.ch-row-active { border-color: var(--apple-blue); box-shadow: 0 0 0 1px var(--apple-blue); }
.ch-row-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.ch-row-who { font-weight: 600; }
.ch-row-want { font-size: 13px; color: var(--text-secondary); }
.ch-row-meta { display: flex; gap: 10px; flex-wrap: wrap; font-size: 12px; color: var(--text-secondary); }

.ch-pill { font-size: 11px; padding: 2px 8px; border-radius: 999px; border: 1px solid var(--border); white-space: nowrap; }
.ch-pill-new { background: rgba(0,122,255,.15); color: var(--apple-blue); }
.ch-pill-needs-review { background: rgba(255,159,10,.18); color: #ff9f0a; }
.ch-pill-action-needed { background: rgba(255,107,107,.15); color: #ff6b6b; }
.ch-pill-reviewed { background: rgba(255,255,255,.06); }
.ch-pill-done { background: rgba(52,199,89,.15); color: #34c759; }

.ch-btn-primary { background: var(--apple-blue); color: #fff; border-color: var(--apple-blue); }
.ch-hint { font-weight: 400; font-size: 11px; color: var(--text-secondary); }

/* Tuning + discards panels */
.ch-settings-panel { padding: 0 20px 4px; }
.ch-settings-hint { font-size: 13px; color: var(--text-secondary); margin: 0 0 12px; }
.ch-settings-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; }
.ch-settings-grid label { display: flex; flex-direction: column; gap: 4px; font-size: 12px; color: var(--text-secondary); }
.ch-settings-grid input, .ch-settings-grid select { background: var(--bg-input); color: var(--text); border: 1px solid var(--border); border-radius: 8px; padding: 6px 10px; font-size: 13px; }
.ch-settings-actions { margin-top: 14px; }

/* Key details grid (click-to-copy) */
.ch-detail-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 8px; }
.ch-detail-copy { text-align: left; cursor: pointer; background: var(--bg-input); border: 1px solid var(--border); border-radius: 8px; padding: 8px 10px; display: flex; flex-direction: column; gap: 2px; color: var(--text); }
.ch-detail-copy:hover { border-color: var(--apple-blue); }
.ch-detail-label { font-size: 11px; color: var(--text-secondary); }
.ch-detail-value { font-size: 14px; font-weight: 600; word-break: break-word; }

/* Discards audit */
.ch-discards-list { display: flex; flex-direction: column; gap: 6px; }
.ch-discard-row { display: flex; align-items: center; gap: 12px; font-size: 13px; color: var(--text-secondary); padding: 6px 0; border-bottom: 1px solid var(--border); }
.ch-discard-row:last-child { border-bottom: none; }
.ch-discard-reason { font-size: 11px; padding: 2px 8px; border-radius: 999px; border: 1px solid var(--border); }
.ch-discard-personal { background: rgba(255,255,255,.06); }
.ch-discard-low_confidence { background: rgba(255,159,10,.18); color: #ff9f0a; }
.ch-discard-id { font-family: ui-monospace, monospace; font-size: 12px; }

.ch-resolved.is-yes { color: #34c759; }
.ch-resolved.is-no { color: var(--text-secondary); }
.ch-warn { color: #ff6b6b; }

.ch-detail { background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px; padding: 16px; }
.ch-detail-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.ch-detail-head h3 { margin: 0 0 4px; }
.ch-status-set { display: inline-flex; flex-direction: column; gap: 4px; font-size: 12px; color: var(--text-secondary); }
.ch-card { border-top: 1px solid var(--border); padding-top: 12px; margin-top: 12px; }
.ch-card h4 { margin: 0 0 8px; font-size: 13px; color: var(--text-secondary); }
.ch-card-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.ch-card-head h4 { margin: 0; }
.ch-card p { margin: 4px 0; font-size: 14px; }
.ch-narrative { font-size: 14px; line-height: 1.5; margin: 0 0 10px; }
.ch-keypoints { margin: 0 0 10px; padding-left: 18px; }
.ch-keypoints li { font-size: 13px; color: var(--text-secondary); margin: 2px 0; }

.ch-loop { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 8px 0; border-bottom: 1px solid var(--border); }
.ch-loop:last-child { border-bottom: none; }
.ch-loop-main { display: flex; flex-direction: column; gap: 2px; }
.ch-loop-wait { font-size: 12px; color: var(--text-secondary); }
.ch-loop-status { background: var(--bg-input); color: var(--text); border: 1px solid var(--border); border-radius: 6px; padding: 4px 8px; font-size: 12px; }

.ch-transcript { white-space: pre-wrap; word-break: break-word; font-size: 13px; color: var(--text); background: var(--bg-input); border-radius: 8px; padding: 12px; max-height: 320px; overflow: auto; }
.ch-empty { color: var(--text-secondary); font-size: 14px; padding: 24px 12px; text-align: center; }
.ch-empty[data-error="1"] { color: #ff6b6b; }
