/**
 * CI DARA Frontend — dark professional stylesheet
 * Matches dara.crucibleinsight.com SaaS aesthetic
 * IBM Plex Sans + IBM Plex Mono · Dark government-tech
 */

/* ── Reset & base ─────────────────────────────────────────────────────────── */
.ci-dara-frontend *, .ci-dara-frontend *::before, .ci-dara-frontend *::after { box-sizing: border-box; }
.ci-dara-frontend { font-family: 'IBM Plex Sans', system-ui, sans-serif; -webkit-font-smoothing: antialiased; }
.ci-dara-frontend a { text-decoration: none; }
.ci-dara-frontend a:hover { text-decoration: none; }
.ci-dara-frontend button { cursor: pointer; font-family: inherit; }
.ci-dara-frontend input, .ci-dara-frontend select, .ci-dara-frontend textarea { font-family: inherit; font-size: 13px; }
.ci-dara-frontend ::-webkit-scrollbar { width: 4px; height: 4px; }
.ci-dara-frontend ::-webkit-scrollbar-track { background: transparent; }
.ci-dara-frontend ::-webkit-scrollbar-thumb { background: #1e2a3c; border-radius: 2px; }
.ci-dara-frontend ::placeholder { color: #475569; }

/* ── Layout ───────────────────────────────────────────────────────────────── */
.ci-dara-frontend {
	background: #080c18;
	color: #f1f5f9;
	min-height: 100vh;
	font-size: 13px;
	line-height: 1.5;
}
/* App shell: sidebar + main */
.ci-fe-layout {
	display: flex;
	min-height: 100vh;
}

/* ── Sidebar ──────────────────────────────────────────────────────────────── */
.ci-fe-sidebar {
	width: 220px;
	flex-shrink: 0;
	background: #0c1220;
	border-right: 1px solid #1e2a3c;
	display: flex;
	flex-direction: column;
	position: sticky;
	top: 0;
	height: 100vh;
	overflow-y: auto;
	z-index: 100;
}
.ci-fe-sidebar-logo {
	padding: 18px 16px 14px;
	border-bottom: 1px solid #1e2a3c;
	display: flex;
	align-items: center;
	gap: 9px;
	text-decoration: none;
}
.ci-fe-sidebar-logo:hover { text-decoration: none; }
.ci-fe-sidebar-logo img { width: 28px; height: 28px; object-fit: contain; }
.ci-fe-sidebar-logo-name { font-size: 14px; font-weight: 700; color: #f1f5f9; letter-spacing: -.01em; line-height: 1; }
.ci-fe-sidebar-logo-sub  { font-size: 9px; color: #2563eb; font-family: 'IBM Plex Mono', monospace; letter-spacing: .08em; text-transform: uppercase; margin-top: 2px; }

.ci-fe-sidebar-user {
	padding: 10px 14px;
	border-bottom: 1px solid #1e2a3c;
	display: flex;
	align-items: center;
	gap: 9px;
}
.ci-fe-sidebar-user-avatar {
	width: 30px; height: 30px;
	background: linear-gradient(135deg, #1d4ed8, #7c3aed);
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-size: 12px; font-weight: 700; color: #fff; flex-shrink: 0;
}
.ci-fe-sidebar-user-name { font-size: 12px; font-weight: 600; color: #e2e8f0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1; min-width: 0; }
.ci-fe-sidebar-user-role { font-size: 10px; color: #475569; }

.ci-fe-sidebar-nav { flex: 1; overflow-y: auto; padding: 10px 8px; }
.ci-fe-nav-section-label {
	font-size: 9px; color: #475569;
	font-family: 'IBM Plex Mono', monospace;
	letter-spacing: .1em; text-transform: uppercase;
	padding: 12px 8px 6px;
}
.ci-fe-nav-item {
	display: flex; align-items: center; gap: 9px;
	padding: 8px 10px; border-radius: 7px; cursor: pointer;
	margin-bottom: 2px; color: #8b9aad;
	transition: background .15s, color .15s;
	text-decoration: none;
	font-size: 13px; font-weight: 500;
}
.ci-fe-nav-item:hover { background: rgba(255,255,255,.05); color: #f1f5f9; text-decoration: none; }
.ci-fe-nav-item.active { background: rgba(59,110,240,.15); color: #f1f5f9; }
.ci-fe-nav-item-icon { font-size: 14px; width: 16px; text-align: center; flex-shrink: 0; line-height: 1; }

.ci-fe-sidebar-support {
	display: flex; align-items: center; gap: 9px;
	padding: 10px 18px;
	border-top: 1px solid #1e2a3c;
	font-size: 12px; color: #475569;
	text-decoration: none;
	transition: background .15s, color .15s;
}
.ci-fe-sidebar-support:hover { background: #111d2e; color: #8b9aad; text-decoration: none; }

/* ── Main content ─────────────────────────────────────────────────────────── */
.ci-fe-main {
	flex: 1;
	overflow-y: auto;
	background: #080c18;
	min-width: 0;
}
.ci-wrap {
	padding: 28px 32px;
	color: #f1f5f9;
	min-height: 100vh;
}
.ci-wrap * { box-sizing: border-box; }

/* ── Page header ──────────────────────────────────────────────────────────── */
.ci-page-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 20px;
	margin-bottom: 24px;
}
.ci-page-header h1 {
	font-size: 22px;
	font-weight: 700;
	color: #f8faff;
	letter-spacing: -.03em;
	margin-bottom: 4px;
	line-height: 1.2;
}
.ci-page-header p { font-size: 13px; color: #8b9aad; margin: 0; }

/* ── Breadcrumb ───────────────────────────────────────────────────────────── */
.ci-breadcrumb {
	display: flex; align-items: center; gap: 6px;
	font-size: 12px; color: #475569; margin-bottom: 18px;
}
.ci-breadcrumb a { color: #8b9aad; text-decoration: none; }
.ci-breadcrumb a:hover { color: #f1f5f9; }
.ci-breadcrumb .sep { color: #1e2a3c; }
.ci-breadcrumb .current { color: #e2e8f0; font-weight: 600; }

/* ── Cards ────────────────────────────────────────────────────────────────── */
.ci-card {
	background: #0f1729;
	border: 1px solid #1e2a3c;
	border-radius: 10px;
	margin-bottom: 16px;
}
.ci-card-header {
	padding: 14px 18px;
	border-bottom: 1px solid #1e2a3c;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}
.ci-card-title {
	font-size: 13px;
	font-weight: 700;
	color: #f1f5f9;
	margin: 0;
}
.ci-card-body { padding: 18px 20px; }

/* ── Stats grid ───────────────────────────────────────────────────────────── */
.ci-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	margin-bottom: 24px;
}
.ci-stat-card {
	background: #0f1729;
	border: 1px solid #1e2a3c;
	border-radius: 10px;
	padding: 18px 20px;
	border-top: 3px solid #1e2a3c;
}
.ci-stat-label {
	font-size: 10px;
	color: #475569;
	font-family: 'IBM Plex Mono', monospace;
	letter-spacing: .08em;
	text-transform: uppercase;
	margin-bottom: 8px;
}
.ci-stat-value {
	font-size: 30px;
	font-weight: 700;
	line-height: 1;
	margin-bottom: 4px;
}
.ci-stat-sub { font-size: 11px; color: #475569; }

/* ── Tables ───────────────────────────────────────────────────────────────── */
.ci-table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.ci-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
}
.ci-table thead tr { background: #0c1220; }
.ci-table th {
	text-align: left;
	padding: 10px 14px;
	font-size: 10px;
	color: #475569;
	font-weight: 600;
	font-family: 'IBM Plex Mono', monospace;
	letter-spacing: .06em;
	text-transform: uppercase;
	white-space: nowrap;
	border-bottom: 1px solid #1e2a3c;
}
.ci-table td {
	padding: 12px 14px;
	border-top: 1px solid #1e2a3c;
	color: #e2e8f0;
	vertical-align: middle;
}
.ci-table tbody tr { transition: background .1s; }
.ci-table tbody tr:hover { background: #111d2e; }
.ci-table a { color: #f1f5f9; font-weight: 600; text-decoration: none; }
.ci-table a:hover { color: #2563eb; }
.ci-col-mono { font-family: 'IBM Plex Mono', monospace; font-size: 11px; color: #475569; }
.ci-col-num  { text-align: center; font-size: 13px; font-weight: 700; color: #8b9aad; }
.ci-muted    { font-size: 11px; color: #475569; }

/* ── Criteria table ───────────────────────────────────────────────────────── */
.ci-criteria-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.ci-criteria-table th {
	text-align: left; padding: 9px 12px;
	font-size: 10px; color: #475569; font-weight: 600;
	font-family: 'IBM Plex Mono', monospace;
	letter-spacing: .06em; text-transform: uppercase;
	border-bottom: 1px solid #1e2a3c; background: #0c1220;
}
.ci-criteria-table td { padding: 10px 12px; border-bottom: 1px solid #1e2a3c; color: #e2e8f0; }
.crit-name   { font-size: 12px; font-weight: 600; color: #f1f5f9; }
.crit-desc   { font-size: 11px; color: #475569; margin-top: 2px; }
.crit-weight { font-size: 12px; font-weight: 700; color: #8b9aad; font-family: 'IBM Plex Mono', monospace; }

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.ci-btn {
	display: inline-flex; align-items: center; gap: 7px;
	padding: 9px 16px; border-radius: 8px;
	font-weight: 600; font-size: 13px; border: none;
	transition: opacity .15s; white-space: nowrap; text-decoration: none;
	cursor: pointer; font-family: inherit;
}
.ci-btn:hover { opacity: .88; text-decoration: none; }
.ci-btn-primary  { background: #2563eb; color: #fff; }
.ci-btn-secondary, .ci-btn-outline { background: #0f1729; border: 1px solid #1e2a3c; color: #8b9aad; }
.ci-btn-secondary:hover, .ci-btn-outline:hover { color: #f1f5f9; }
.ci-btn-danger   { background: rgba(239,68,68,.15); border: 1px solid rgba(239,68,68,.3); color: #ef4444; }
.ci-btn-sm       { padding: 6px 12px; font-size: 11px; border-radius: 6px; }

/* ── Badges ───────────────────────────────────────────────────────────────── */
.ci-badge {
	display: inline-flex; align-items: center;
	font-size: 9px; font-weight: 700;
	padding: 3px 8px; border-radius: 4px;
	font-family: 'IBM Plex Mono', monospace;
	white-space: nowrap; text-transform: uppercase; letter-spacing: .04em;
}
.ci-badge-running, .ci-badge-processing { background: rgba(59,130,246,.15); color: #60a5fa; }
.ci-badge-complete { background: rgba(16,185,129,.15); color: #10b981; }
.ci-badge-pending  { background: rgba(245,158,11,.12); color: #f59e0b; }
.ci-badge-failed   { background: rgba(239,68,68,.12);  color: #ef4444; }

/* ── Notices / flash ──────────────────────────────────────────────────────── */
.ci-notice {
	padding: 12px 16px; border-radius: 8px;
	font-size: 13px; margin-bottom: 18px;
	display: flex; align-items: center; gap: 10px;
}
.ci-notice-success { background: rgba(16,185,129,.12);  border: 1px solid rgba(16,185,129,.25); color: #10b981; }
.ci-notice-error   { background: rgba(239,68,68,.1);   border: 1px solid rgba(239,68,68,.25);  color: #ef4444; }
.ci-notice-info, .ci-notice-warning { background: rgba(59,130,246,.1); border: 1px solid rgba(59,130,246,.25); color: #60a5fa; }

/* ── Forms ────────────────────────────────────────────────────────────────── */
.ci-form-section { max-width: 620px; }
.ci-form-grid {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: 8px 16px;
	align-items: center;
}
.ci-form-grid dt, .ci-form-grid label {
	font-size: 11px; font-weight: 600; color: #8b9aad;
	letter-spacing: .04em; text-transform: uppercase;
}
.ci-form-grid dd { margin: 0; }
.ci-form-grid dd input,
.ci-form-grid dd select,
.ci-form-grid dd textarea {
	width: 100%;
	background: #111d2e;
	border: 1px solid #1e2a3c;
	border-radius: 8px;
	padding: 9px 13px;
	color: #f1f5f9;
	outline: none;
	transition: border-color .15s;
	font-family: inherit;
	font-size: 13px;
}
.ci-form-grid dd input:focus,
.ci-form-grid dd select:focus,
.ci-form-grid dd textarea:focus { border-color: #2563eb; }
.ci-divider { border: none; border-top: 1px solid #1e2a3c; margin: 20px 0; }
.ci-flex    { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ci-mono    { font-family: 'IBM Plex Mono', monospace; }
.ci-link    { color: #2563eb; font-size: 12px; font-weight: 600; text-decoration: none; }
.ci-link:hover { color: #60a5fa; }

/* ── Tab bar ──────────────────────────────────────────────────────────────── */
.ci-tab-bar {
	display: flex;
	border-bottom: 1px solid #1e2a3c;
	margin-bottom: 20px;
	gap: 2px;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}
.ci-tab {
	padding: 9px 16px;
	font-size: 12px; font-weight: 600;
	border-bottom: 2px solid transparent;
	color: #8b9aad; text-decoration: none;
	display: flex; align-items: center; gap: 6px;
	white-space: nowrap;
	transition: color .15s;
}
.ci-tab:hover { color: #f1f5f9; text-decoration: none; }
.ci-tab.active { border-bottom-color: #2563eb; color: #f1f5f9; }
.ci-tab-badge {
	background: #1e2a3c; color: #8b9aad;
	font-size: 9px; font-weight: 700; padding: 2px 6px;
	border-radius: 10px; font-family: 'IBM Plex Mono', monospace;
}
.ci-tab-content { min-height: 200px; }

/* ── Workflow strip ───────────────────────────────────────────────────────── */
.ci-workflow-strip { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.ci-workflow-step {
	font-size: 10px; font-weight: 600; padding: 5px 10px; border-radius: 5px;
	white-space: nowrap; font-family: 'IBM Plex Mono', monospace;
	background: #111d2e; border: 1px solid #1e2a3c; color: #475569;
}
.ci-workflow-step.done  { background: rgba(16,185,129,.12); border-color: rgba(16,185,129,.3); color: #10b981; }
.ci-workflow-step.warn  { background: rgba(59,130,246,.1); border-color: rgba(59,130,246,.3); color: #2563eb; }
.ci-workflow-step.ready { background: rgba(59,130,246,.15); border-color: rgba(59,130,246,.4); color: #2563eb; }

/* ── Template bar ─────────────────────────────────────────────────────────── */
.ci-template-bar {
	display: flex; align-items: center; gap: 10px;
	margin-bottom: 14px; flex-wrap: wrap;
	background: #0f1729; border: 1px solid #1e2a3c;
	border-radius: 8px; padding: 10px 14px;
}
.ci-template-bar label { font-size: 12px; font-weight: 600; color: #8b9aad; white-space: nowrap; }
.ci-template-bar select {
	flex: 1; background: #111d2e; border: 1px solid #1e2a3c;
	border-radius: 6px; padding: 7px 10px; color: #f1f5f9;
	font-family: inherit; font-size: 12px; outline: none;
}

/* ── Expander (add criterion) ─────────────────────────────────────────────── */
.ci-expander-btn {
	background: none; border: 1px dashed #1e2a3c; border-radius: 8px;
	color: #8b9aad; font-size: 12px; font-weight: 600;
	padding: 10px 16px; width: 100%; text-align: left;
	cursor: pointer; font-family: inherit; margin-top: 10px;
	transition: background .15s, border-color .15s, color .15s;
}
.ci-expander-btn:hover { background: #111d2e; border-color: #2563eb; color: #f1f5f9; }
.ci-expander-body { display: none; background: #0f1729; border: 1px solid #1e2a3c; border-radius: 8px; padding: 16px; margin-top: 8px; }
.ci-expander-body.open { display: block; }
.ci-expander-body .ci-form-grid dd input,
.ci-expander-body .ci-form-grid dd select {
	background: #111d2e; border-color: #1e2a3c; color: #f1f5f9;
}

/* ── Offeror cards ────────────────────────────────────────────────────────── */
.ci-offeror-card {
	background: #0f1729; border: 1px solid #1e2a3c; border-radius: 10px;
	margin-bottom: 12px; overflow: hidden;
}
.ci-offeror-card.has-error { border-color: rgba(239,68,68,.4); }
.ci-offeror-header {
	padding: 12px 16px; display: flex; align-items: center; gap: 12px;
	flex-wrap: wrap; gap: 10px;
}
.ci-offeror-avatar {
	width: 36px; height: 36px; border-radius: 8px;
	display: flex; align-items: center; justify-content: center;
	font-size: 12px; font-weight: 800; flex-shrink: 0;
}
.ci-offeror-name  { font-size: 13px; font-weight: 600; color: #f1f5f9; }
.ci-offeror-sub   { font-size: 11px; color: #8b9aad; margin-top: 2px; }
.ci-offeror-sub.error { color: #ef4444; }
.ci-offeror-files { padding: 0 16px; background: #0c1220; border-top: 1px solid #1e2a3c; }
.ci-offeror-form  { padding: 10px 16px; border-top: 1px solid #1e2a3c; }
.ci-file-row {
	display: flex; align-items: center; gap: 10px;
	padding: 8px 0; border-bottom: 1px solid #1e2a3c;
	font-size: 11px; color: #8b9aad;
}
.ci-file-ok   { color: #10b981; font-weight: 700; width: 14px; }
.ci-file-fail { color: #ef4444; font-weight: 700; width: 14px; }

.ci-add-offeror-row {
	display: flex; align-items: center; gap: 10px;
	margin-bottom: 10px;
}
.ci-add-offeror-row input {
	flex: 1; background: #111d2e; border: 1px solid #1e2a3c;
	border-radius: 8px; padding: 9px 13px; color: #f1f5f9;
	font-family: inherit; font-size: 13px; outline: none;
}
.ci-add-offeror-row input:focus { border-color: #2563eb; }

/* ── Evaluation result cards ──────────────────────────────────────────────── */
.ci-criterion-card {
	background: #0f1729; border: 1px solid #1e2a3c; border-radius: 10px;
	margin-bottom: 10px; overflow: hidden;
}
.ci-criterion-card.issues { border-color: rgba(239,68,68,.4); }
.ci-criterion-card.ok     { border-color: rgba(16,185,129,.3); }
.ci-criterion-header {
	padding: 12px 16px; background: #0c1220;
	display: flex; align-items: center; justify-content: space-between;
	flex-wrap: wrap; gap: 8px; cursor: pointer;
}
.ci-criterion-num {
	width: 28px; height: 28px;
	background: #1e2a3c; color: #8b9aad;
	border-radius: 7px; display: flex; align-items: center; justify-content: center;
	font-size: 11px; font-weight: 800; flex-shrink: 0;
	font-family: 'IBM Plex Mono', monospace;
}
.ci-criterion-num.issues { background: rgba(239,68,68,.2); color: #ef4444; }
.ci-criterion-name { font-size: 13px; font-weight: 700; color: #f1f5f9; margin-left: 8px; }
.ci-criterion-meta { display: flex; align-items: center; gap: 8px; }
.ci-criterion-type {
	background: #1e2a3c; color: #8b9aad;
	font-size: 10px; font-weight: 600; padding: 2px 8px;
	border-radius: 3px; font-family: 'IBM Plex Mono', monospace;
}
.ci-criterion-weight {
	font-size: 10px; font-weight: 700; color: #8b9aad;
	font-family: 'IBM Plex Mono', monospace;
}
.ci-issues-flag {
	background: rgba(239,68,68,.15); color: #ef4444;
	font-size: 9px; font-weight: 700; padding: 2px 8px;
	border-radius: 3px; font-family: 'IBM Plex Mono', monospace;
}
.ci-result-head {
	display: grid; grid-template-columns: 140px 130px 55px 1fr;
	padding: 7px 16px; background: #0c1220; border-top: 1px solid #1e2a3c;
	font-size: 9px; font-weight: 700; color: #475569; text-transform: uppercase;
	letter-spacing: .06em; font-family: 'IBM Plex Mono', monospace;
}
.ci-result-row {
	display: grid; grid-template-columns: 140px 130px 55px 1fr;
	padding: 11px 16px; border-top: 1px solid #1e2a3c; align-items: start;
	font-size: 12px;
}
.ci-result-persona { font-size: 12px; font-weight: 600; color: #e2e8f0; }
.ci-result-conf    { font-size: 11px; color: #8b9aad; font-family: 'IBM Plex Mono', monospace; }
.ci-result-rationale { font-size: 12px; color: #8b9aad; line-height: 1.6; }
.ci-result-rationale strong { color: #f1f5f9; }
.ci-finding-compliant     { color: #10b981; font-weight: 700; }
.ci-finding-non-compliant { color: #ef4444; font-weight: 700; }
.ci-finding-acceptable    { color: #60a5fa; font-weight: 700; }

/* ── Progress (evaluation running) ───────────────────────────────────────── */
.ci-progress-wrap {
	background: #0f1729; border: 1px solid #1e2a3c; border-radius: 10px;
	padding: 18px 20px; margin-bottom: 20px;
	display: flex; align-items: center; gap: 20px;
}
.ci-progress-label { font-size: 12px; font-weight: 600; color: #8b9aad; margin-bottom: 8px; }
.ci-progress-track { height: 6px; background: #1e2a3c; border-radius: 3px; overflow: hidden; }
.ci-progress-fill  { height: 100%; background: #2563eb; border-radius: 3px; transition: width .3s; }
.ci-progress-sub   { font-size: 11px; color: #475569; margin-top: 5px; }
.ci-progress-pct   { font-size: 28px; font-weight: 700; color: #2563eb; line-height: 1; }

/* ── Section label ────────────────────────────────────────────────────────── */
.ci-section-label {
	font-size: 10px; font-weight: 700; color: #475569;
	font-family: 'IBM Plex Mono', monospace;
	letter-spacing: .08em; text-transform: uppercase;
	margin-bottom: 12px;
}

/* ── Suggestions ──────────────────────────────────────────────────────────── */
.ci-suggestions-area {
	display: none; padding: 14px 16px;
	border-top: 1px solid #1e2a3c; background: #0a1220;
}
.ci-suggestions-area.open { display: block; }
.ci-suggestions-loading { font-size: 12px; color: #475569; font-style: italic; }
.ci-suggestions-error   { font-size: 12px; color: #ef4444; }
.ci-suggestions-md      { font-size: 12px; color: #8b9aad; line-height: 1.7; }
.ci-suggestions-md strong { color: #f1f5f9; }

/* ── Matrix table ─────────────────────────────────────────────────────────── */
.ci-matrix-summary-grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 14px;
}
.ci-req-status-select {
	font-size: 11px; background: #111d2e; border: 1px solid #1e2a3c;
	border-radius: 4px; padding: 3px 6px; color: #f1f5f9;
	font-family: inherit; width: 100%;
}

/* ── Login gate ───────────────────────────────────────────────────────────── */
.ci-login-gate {
	display: flex; align-items: center; justify-content: center;
	min-height: 100vh; background: #080c18; padding: 40px 20px;
}
.ci-login-card {
	background: #0c1220; border: 1px solid #1e2a3c; border-radius: 12px;
	padding: 40px 36px; text-align: center; max-width: 380px; width: 100%;
}
.ci-login-card h2 { color: #f8faff; margin: 0 0 8px; font-size: 22px; font-weight: 700; }
.ci-login-card p  { color: #8b9aad; margin-bottom: 24px; font-size: 13px; }

/* ── Empty states ─────────────────────────────────────────────────────────── */
.ci-empty {
	padding: 48px 20px; text-align: center;
	color: #475569; font-size: 14px;
}
.ci-empty h2 { font-size: 16px; font-weight: 700; color: #8b9aad; margin-bottom: 8px; }

/* ── Support page (docs inside shell) ────────────────────────────────────── */
.ci-dara-frontend .doc-layout { display: block !important; min-height: unset; }
.ci-dara-frontend .doc-sidebar { display: none !important; }
.ci-dara-frontend .doc-main { padding: 0 !important; max-width: 100% !important; }

/* ── Responsive: tablet ───────────────────────────────────────────────────── */
@media (max-width: 960px) {
	.ci-wrap { padding: 20px 16px; }
	.ci-page-header { flex-direction: column; align-items: flex-start; gap: 12px; }
	.ci-stats { grid-template-columns: repeat(2, 1fr) !important; }
	.ci-matrix-summary-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ── Responsive: mobile ───────────────────────────────────────────────────── */
@media (max-width: 640px) {
	.ci-fe-sidebar { width: 0; overflow: hidden; position: fixed; }
	.ci-wrap { padding: 14px 12px; }
	.ci-stats { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
	.ci-result-head { display: none; }
	.ci-result-row  { grid-template-columns: 1fr !important; gap: 4px; }
	.ci-form-grid   { grid-template-columns: 1fr !important; }
	.ci-add-offeror-row { flex-direction: column; align-items: stretch; }
}

/* ── Print ────────────────────────────────────────────────────────────────── */
@media print {
	.ci-fe-sidebar { display: none; }
	.ci-wrap { padding: 0; }
	.ci-btn  { display: none; }
	.ci-dara-frontend { background: #fff; color: #000; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   THEME OVERRIDE BLOCK — higher specificity to beat WP theme resets
   ═══════════════════════════════════════════════════════════════════════════ */

/* Card backgrounds */
.ci-dara-frontend .ci-card,
.ci-dara-frontend .ci-card .ci-card-header,
.ci-dara-frontend .ci-card .ci-card-body { background-color: #0f1729 !important; }

/* Table headers — never white */
.ci-dara-frontend .ci-table thead tr,
.ci-dara-frontend .ci-table thead { background: #0c1220 !important; }
.ci-dara-frontend .ci-table th { background: #0c1220 !important; color: #475569 !important; border-color: #1e2a3c !important; }

/* Table cells — dark on dark */
.ci-dara-frontend .ci-table td { background: transparent !important; color: #e2e8f0 !important; border-color: #1e2a3c !important; }

/* Row hover — dark, never white */
.ci-dara-frontend .ci-table tbody tr:hover { background-color: #111d2e !important; }
.ci-dara-frontend .ci-table tbody tr:hover td { background-color: #111d2e !important; color: #f1f5f9 !important; }

/* Links inside tables */
.ci-dara-frontend .ci-table a,
.ci-dara-frontend .ci-table td a { color: #f1f5f9 !important; font-weight: 600; text-decoration: none !important; }
.ci-dara-frontend .ci-table td a:hover { color: #2563eb !important; }

/* Muted text in tables must stay readable */
.ci-dara-frontend .ci-table .ci-muted,
.ci-dara-frontend .ci-muted { color: #475569 !important; }

/* Numeric cells */
.ci-dara-frontend .ci-col-num { color: #8b9aad !important; font-weight: 700; }
.ci-dara-frontend .ci-col-mono { color: #475569 !important; font-family: 'IBM Plex Mono', monospace !important; font-size: 11px !important; }

/* Page background */
.ci-dara-frontend .ci-fe-main { background-color: #080c18 !important; }
.ci-dara-frontend .ci-wrap    { background-color: #080c18 !important; color: #f1f5f9 !important; }

/* Card header text */
.ci-dara-frontend .ci-card-header .ci-card-title { color: #f1f5f9 !important; }
.ci-dara-frontend .ci-card-header .ci-link       { color: #2563eb !important; }

/* Stat cards */
.ci-dara-frontend .ci-stat-card { background-color: #0f1729 !important; border-color: #1e2a3c !important; }
.ci-dara-frontend .ci-stat-label { color: #475569 !important; }
.ci-dara-frontend .ci-stat-sub   { color: #475569 !important; }

/* Secondary text under primary in table cells */
.ci-dara-frontend .ci-table td > div:last-child:not(:first-child) { color: #475569 !important; font-size: 11px !important; }


/* ── Criterion cards — result rows & rationale ───────────────────────────── */
.ci-dara-frontend .ci-criterion-card,
.ci-dara-frontend .ci-criterion-card .ci-result-row,
.ci-dara-frontend .ci-criterion-card .ci-result-head { background-color: #0f1729 !important; color: #e2e8f0 !important; border-color: #1e2a3c !important; }
.ci-dara-frontend .ci-criterion-card .ci-criterion-header { background-color: #0c1220 !important; }
.ci-dara-frontend .ci-criterion-card .ci-result-rationale { color: #8b9aad !important; }
.ci-dara-frontend .ci-criterion-card .ci-result-rationale strong { color: #f1f5f9 !important; }
.ci-dara-frontend .ci-criterion-card .ci-result-rationale p { background: transparent !important; color: #8b9aad !important; }
.ci-dara-frontend .ci-criterion-card p,
.ci-dara-frontend .ci-criterion-card div,
.ci-dara-frontend .ci-criterion-card ol,
.ci-dara-frontend .ci-criterion-card ul,
.ci-dara-frontend .ci-criterion-card li { background: transparent !important; color: inherit; }

/* Override any inline white/light backgrounds on the rationale section */
.ci-dara-frontend .ci-result-row * { background-color: transparent !important; }
.ci-dara-frontend .ci-result-rationale * { background-color: transparent !important; }

/* Tab bar on dark */
.ci-dara-frontend .ci-tab-bar { background: transparent !important; border-color: #1e2a3c !important; }
.ci-dara-frontend .ci-tab { color: #8b9aad !important; background: transparent !important; }
.ci-dara-frontend .ci-tab:hover { color: #f1f5f9 !important; }
.ci-dara-frontend .ci-tab.active { color: #f1f5f9 !important; border-bottom-color: #2563eb !important; }
.ci-dara-frontend .ci-tab-badge { background: #1e2a3c !important; color: #8b9aad !important; }

/* Suggestions / improvement area */
.ci-dara-frontend .ci-suggestions-area { background-color: #0a1220 !important; border-color: #1e2a3c !important; }
.ci-dara-frontend .ci-suggestions-md,
.ci-dara-frontend .ci-suggestions-md * { background: transparent !important; color: #8b9aad !important; }
.ci-dara-frontend .ci-suggestions-md strong { color: #f1f5f9 !important; }

/* Progress wrap */
.ci-dara-frontend .ci-progress-wrap { background-color: #0f1729 !important; border-color: #1e2a3c !important; }
.ci-dara-frontend .ci-progress-track { background-color: #1e2a3c !important; }

/* Offeror cards */
.ci-dara-frontend .ci-offeror-card { background-color: #0f1729 !important; border-color: #1e2a3c !important; }
.ci-dara-frontend .ci-offeror-header { background-color: #0f1729 !important; }
.ci-dara-frontend .ci-offeror-files { background-color: #0c1220 !important; border-color: #1e2a3c !important; }
.ci-dara-frontend .ci-file-row { border-color: #1e2a3c !important; color: #8b9aad !important; }
.ci-dara-frontend .ci-offeror-form { background-color: #0f1729 !important; border-color: #1e2a3c !important; }
.ci-dara-frontend .ci-offeror-name { color: #f1f5f9 !important; }
.ci-dara-frontend .ci-offeror-sub  { color: #8b9aad !important; }

/* Form inputs */
.ci-dara-frontend input[type="text"],
.ci-dara-frontend input[type="password"],
.ci-dara-frontend input[type="email"],
.ci-dara-frontend input[type="number"],
.ci-dara-frontend select,
.ci-dara-frontend textarea {
	background-color: #111d2e !important;
	border-color: #1e2a3c !important;
	color: #f1f5f9 !important;
}
.ci-dara-frontend input:focus,
.ci-dara-frontend select:focus,
.ci-dara-frontend textarea:focus { border-color: #2563eb !important; outline: none !important; box-shadow: none !important; }

/* Buttons */
.ci-dara-frontend .ci-btn-primary  { background-color: #2563eb !important; color: #fff !important; border: none !important; }
.ci-dara-frontend .ci-btn-secondary { background-color: #0f1729 !important; border-color: #1e2a3c !important; color: #8b9aad !important; }
.ci-dara-frontend .ci-btn-secondary:hover { color: #f1f5f9 !important; }
.ci-dara-frontend .ci-btn-danger { background-color: rgba(239,68,68,.15) !important; border-color: rgba(239,68,68,.3) !important; color: #ef4444 !important; }

/* Section label */
.ci-dara-frontend .ci-section-label { color: #475569 !important; }

/* Page header text */
.ci-dara-frontend .ci-page-header h1 { color: #f8faff !important; }
.ci-dara-frontend .ci-page-header p  { color: #8b9aad !important; }


/* ── Workflow strip — dark theme ─────────────────────────────────────────── */
.ci-dara-frontend .ci-workflow-step {
	background: #111d2e !important;
	border-color: #1e2a3c !important;
	color: #475569 !important;
}
.ci-dara-frontend .ci-workflow-step.done {
	background: rgba(16,185,129,.12) !important;
	border-color: rgba(16,185,129,.3) !important;
	color: #10b981 !important;
}
.ci-dara-frontend .ci-workflow-step.warn {
	background: rgba(59,130,246,.1) !important;
	border-color: rgba(59,130,246,.3) !important;
	color: #2563eb !important;
}
.ci-dara-frontend .ci-workflow-step.ready {
	background: rgba(59,130,246,.15) !important;
	border-color: rgba(59,130,246,.4) !important;
	color: #2563eb !important;
}

/* ── Matrix summary stat cards — brighter text ───────────────────────────── */
.ci-dara-frontend .ci-matrix-summary-grid .ci-stat-card { background-color: #0f1729 !important; border-color: #1e2a3c !important; }
.ci-dara-frontend .ci-matrix-summary-grid .ci-stat-label { color: #8b9aad !important; }
.ci-dara-frontend .ci-matrix-summary-grid .ci-stat-value { color: #f1f5f9 !important; }
.ci-dara-frontend .ci-matrix-summary-grid .ci-stat-sub   { color: #8b9aad !important; }

/* Type list & assumptions inside matrix stat cards */
.ci-dara-frontend .ci-matrix-summary-grid div[style] { color: #8b9aad !important; }
.ci-dara-frontend .ci-matrix-summary-grid span[style*="font-size:11px"] { color: #8b9aad !important; }
.ci-dara-frontend .ci-matrix-summary-grid span[style*="font-weight:700"] { color: #f1f5f9 !important; }

/* ── Matrix table text — ensure readability ──────────────────────────────── */
.ci-dara-frontend #ci-fe-matrix-table td,
.ci-dara-frontend table[id*="matrix"] td { color: #e2e8f0 !important; background: transparent !important; }
.ci-dara-frontend #ci-fe-matrix-table th { color: #475569 !important; background: #0c1220 !important; }
.ci-dara-frontend #ci-fe-matrix-table tr:hover td { background: #111d2e !important; }

/* ── Matrix search/filter inputs ─────────────────────────────────────────── */
.ci-dara-frontend #ci-fe-matrix-search,
.ci-dara-frontend #ci-fe-matrix-type,
.ci-dara-frontend #ci-fe-matrix-status {
	background-color: #111d2e !important;
	border-color: #1e2a3c !important;
	color: #f1f5f9 !important;
}

/* ── Tab badge brighter ──────────────────────────────────────────────────── */
.ci-dara-frontend .ci-tab-badge { background: #1e2a3c !important; color: #8b9aad !important; }

/* ── Any inline style with white/light bg ────────────────────────────────── */
/* Force any remaining element that has background:#fff or background:white */
.ci-dara-frontend .ci-wrap [style*="background:#fff"],
.ci-dara-frontend .ci-wrap [style*="background: #fff"],
.ci-dara-frontend .ci-wrap [style*="background:white"],
.ci-dara-frontend .ci-wrap [style*="background: white"] {
	background-color: #0f1729 !important;
}
.ci-dara-frontend .ci-wrap [style*="background:#f"] {
	background-color: transparent !important;
}
/* Force any remaining element with dark text that would be invisible */
.ci-dara-frontend .ci-wrap [style*="color:#374151"],
.ci-dara-frontend .ci-wrap [style*="color: #374151"],
.ci-dara-frontend .ci-wrap [style*="color:#0c2340"],
.ci-dara-frontend .ci-wrap [style*="color:#1a2332"] {
	color: #e2e8f0 !important;
}
.ci-dara-frontend .ci-wrap [style*="color:#9ca3af"],
.ci-dara-frontend .ci-wrap [style*="color:#6b7280"] {
	color: #8b9aad !important;
}
.ci-dara-frontend .ci-wrap [style*="color:#d1d5db"] {
	color: #475569 !important;
}
