/**
 * CI DARA — Theme tokens (light / dark)
 */

/* ── Light mode defaults ─────────────────────────────────────────────────── */
:root {
	--ci-surface:      #ffffff;
	--ci-surf-2:       #f9fafb;
	--ci-surf-3:       #fafafa;
	--ci-border:       #e2e5ec;
	--ci-border-2:     #f0f1f3;
	--ci-border-3:     #f5f5f6;
	--ci-border-input: #d1d5db;
	--ci-text-1:       #0c2340;
	--ci-text-2:       #374151;
	--ci-text-3:       #6b7280;
	--ci-text-4:       #9ca3af;
	--ci-accent:       #1794c1;
	--ci-shadow:       rgba(12,35,64,0.08);
}

/* ── Dark mode overrides ─────────────────────────────────────────────────── */
body.ci-dark {
	--ci-surface:      #131f38;
	--ci-surf-2:       #192c48;
	--ci-surf-3:       #0f1a2e;
	--ci-border:       #1f3254;
	--ci-border-2:     #192b47;
	--ci-border-3:     #1a2d46;
	--ci-border-input: #2a3f60;
	--ci-text-1:       #e2eaf5;
	--ci-text-2:       #b0becf;
	--ci-text-3:       #7a8ba8;
	--ci-text-4:       #506280;
	--ci-accent:       #38b2da;
	--ci-shadow:       rgba(0,0,0,0.28);
}

/* WordPress admin body background in dark mode */
body.ci-dark #wpcontent,
body.ci-dark #wpbody,
body.ci-dark #wpbody-content { background: #0d1526; }

/**
 * CI DARA — Meridian Professional Admin UI
 * Loaded only on CI DARA admin pages.
 */

/* ── Reset & base ─────────────────────────────────────────────────────────── */
#wpbody-content .ci-wrap {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	color: var(--ci-text-1);
	max-width: 1160px;
	padding: 28px 28px 48px;
	box-sizing: border-box;
}
#wpbody-content .ci-wrap * {
	box-sizing: border-box;
}

/* ── Page header ──────────────────────────────────────────────────────────── */
.ci-page-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	margin-bottom: 26px;
	gap: 20px;
}
.ci-page-header h1 {
	font-size: 22px;
	font-weight: 800;
	color: var(--ci-text-1);
	margin: 0 0 4px;
	letter-spacing: -0.02em;
	line-height: 1.2;
	padding: 0;
}
.ci-page-header p {
	font-size: 13px;
	color: var(--ci-text-3);
	margin: 0;
}

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.ci-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 9px 16px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	border: none;
	text-decoration: none;
	font-family: inherit;
	transition: opacity 0.15s;
	white-space: nowrap;
}
.ci-btn:hover { opacity: 0.88; }
.ci-btn-primary { background: #0c2340; color: #fff; }
.ci-btn-secondary { background: var(--ci-surface); color: var(--ci-text-2); border: 1px solid var(--ci-border); }
.ci-btn-secondary:hover { background: var(--ci-surf-2); }
.ci-btn-danger { background: transparent; color: #dc2626; border: none; padding: 4px 0; font-size: 12px; }
.ci-btn-sm { padding: 6px 12px; font-size: 12px; }
.ci-btn:disabled { opacity: 0.45; cursor: not-allowed; }

/* ── Stat cards ───────────────────────────────────────────────────────────── */
.ci-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	margin-bottom: 26px;
}
.ci-stat-card {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-radius: 8px;
	padding: 18px 20px;
	border-top-width: 3px;
}
.ci-stat-label {
	font-size: 10px;
	font-weight: 600;
	color: var(--ci-text-4);
	text-transform: uppercase;
	letter-spacing: 0.07em;
	margin-bottom: 8px;
}
.ci-stat-value {
	font-size: 30px;
	font-weight: 800;
	line-height: 1;
}
.ci-stat-sub {
	font-size: 11px;
	color: var(--ci-text-3);
	margin-top: 4px;
}

/* ── Cards / panels ───────────────────────────────────────────────────────── */
.ci-card {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-radius: 8px;
	overflow: hidden;
	margin-bottom: 16px;
}
.ci-card-header {
	padding: 14px 20px;
	border-bottom: 1px solid var(--ci-border-2);
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.ci-card-title {
	font-size: 14px;
	font-weight: 700;
	color: var(--ci-text-1);
	margin: 0;
}
.ci-card-body {
	padding: 18px 20px;
}

/* ── Tables ───────────────────────────────────────────────────────────────── */
.ci-table {
	width: 100%;
	border-collapse: collapse;
}
.ci-table th {
	font-size: 10px;
	font-weight: 600;
	color: var(--ci-text-4);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: 9px 20px;
	text-align: left;
	background: var(--ci-surf-2);
	border-bottom: 1px solid var(--ci-border-2);
}
.ci-table td {
	padding: 13px 20px;
	font-size: 13px;
	color: var(--ci-text-2);
	border-bottom: 1px solid var(--ci-border-3);
	vertical-align: middle;
}
.ci-table tr:last-child td { border-bottom: none; }
.ci-table tbody tr:nth-child(even) td { background: var(--ci-surf-3); }
.ci-table tbody tr:hover td { background: var(--ci-surf-2) !important; }
.ci-table a { color: var(--ci-accent); text-decoration: none; font-weight: 600; }
.ci-table a:hover { text-decoration: underline; }
.ci-table .ci-col-mono { font-family: monospace; font-size: 11px; color: var(--ci-text-3); }
.ci-table .ci-col-num { font-size: 14px; font-weight: 700; color: var(--ci-text-1); text-align: center; }

/* ── Breadcrumb ───────────────────────────────────────────────────────────── */
.ci-breadcrumb {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 14px;
	font-size: 12px;
}
.ci-breadcrumb a { color: var(--ci-accent); text-decoration: none; font-weight: 500; }
.ci-breadcrumb a:hover { text-decoration: underline; }
.ci-breadcrumb .sep { color: #d1d5db; }
.ci-breadcrumb .current { color: var(--ci-text-4); }

/* ── Workflow strip ───────────────────────────────────────────────────────── */
.ci-workflow-strip {
	display: flex;
	align-items: center;
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-radius: 6px;
	overflow: hidden;
	flex-shrink: 0;
}
.ci-workflow-step {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 7px 14px;
	border-right: 1px solid var(--ci-border);
	font-size: 11px;
	font-weight: 500;
	color: var(--ci-text-4);
}
.ci-workflow-step:last-child { border-right: none; }
.ci-workflow-step.done { color: #059669; }
.ci-workflow-step.ready { color: var(--ci-accent); font-weight: 700; }
.ci-workflow-step.warn { color: #d97706; }

/* ── Tab bar ──────────────────────────────────────────────────────────────── */
.ci-tab-bar {
	display: flex;
	border-bottom: 2px solid var(--ci-border);
	margin-bottom: 0;
}
.ci-tab {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 18px;
	font-size: 13px;
	font-weight: 400;
	color: var(--ci-text-3);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: color 0.12s;
	cursor: pointer;
}
.ci-tab:hover { color: var(--ci-text-1); text-decoration: none; }
.ci-tab.active { color: var(--ci-text-1); font-weight: 700; border-bottom-color: var(--ci-text-1); }
.ci-tab-badge {
	background: #e8f0fe;
	color: #1d4ed8;
	font-size: 10px;
	font-weight: 700;
	padding: 1px 6px;
	border-radius: 9px;
}

/* ── Tab content ──────────────────────────────────────────────────────────── */
.ci-tab-content {
	padding: 22px 0 0;
}

/* ── Status badges ────────────────────────────────────────────────────────── */
.ci-badge {
	display: inline-block;
	padding: 3px 9px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 600;
}
.ci-badge-running  { background: #dbeafe; color: #1d4ed8; }
.ci-badge-pending  { background: #fef9c3; color: #92400e; }
.ci-badge-complete { background: #dcfce7; color: #166534; }
.ci-badge-failed   { background: #fee2e2; color: #991b1b; }

/* ── Finding badges ───────────────────────────────────────────────────────── */
.ci-finding-compliant     { color: #059669; font-weight: 700; }
.ci-finding-non-compliant { color: #dc2626; font-weight: 700; }
.ci-finding-acceptable    { color: #d97706; font-weight: 700; }

/* ── Notices ──────────────────────────────────────────────────────────────── */
.ci-notice {
	padding: 11px 16px;
	border-radius: 7px;
	font-size: 13px;
	margin-bottom: 18px;
	display: flex;
	align-items: center;
	gap: 10px;
}
.ci-notice-info    { background: #eef4ff; border: 1px solid #bdd3f5; color: #1e40af; }
.ci-notice-success { background: #f0fdf4; border: 1px solid #86efac; color: #166534; }
.ci-notice-warning { background: #fffbeb; border: 1px solid #fde68a; color: #92400e; }
.ci-notice-error   { background: #fff5f5; border: 1px solid #fca5a5; color: #991b1b; }

/* ── Progress bar ─────────────────────────────────────────────────────────── */
.ci-progress-wrap {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-radius: 8px;
	padding: 16px 20px;
	display: flex;
	align-items: center;
	gap: 20px;
	margin-bottom: 22px;
}
.ci-progress-track {
	background: var(--ci-surf-2);
	border-radius: 5px;
	height: 10px;
	overflow: hidden;
	flex: 1;
}
.ci-progress-fill {
	background: linear-gradient(90deg, #1794c1, #1ab3e6);
	height: 100%;
	border-radius: 5px;
	transition: width 0.4s ease;
}
.ci-progress-pct {
	font-size: 34px;
	font-weight: 800;
	color: var(--ci-accent);
	line-height: 1;
	flex-shrink: 0;
}
.ci-progress-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--ci-text-2);
	margin-bottom: 8px;
}
.ci-progress-sub {
	font-size: 12px;
	color: var(--ci-text-3);
}

/* ── Criterion cards ──────────────────────────────────────────────────────── */
.ci-criterion-card {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-left-width: 4px;
	border-radius: 8px;
	margin-bottom: 14px;
}
.ci-criterion-card.ok     { border-left-color: #059669; }
.ci-criterion-card.issues { border-left-color: #dc2626; border-color: #fca5a5; }
.ci-criterion-card.mixed  { border-left-color: #d97706; }
.ci-criterion-header {
	padding: 12px 18px;
	background: var(--ci-surf-2);
	border-bottom: 1px solid var(--ci-border);
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-radius: 6px 6px 0 0;
}
.ci-criterion-card.issues .ci-criterion-header { background: #fff5f5; border-bottom-color: #fca5a5; }
.ci-criterion-num {
	background: #0c2340;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	padding: 2px 7px;
	border-radius: 3px;
	margin-right: 10px;
}
.ci-criterion-card.issues .ci-criterion-num { background: #dc2626; }
.ci-criterion-card.mixed .ci-criterion-num  { background: #d97706; }
.ci-criterion-name { font-size: 14px; font-weight: 700; color: var(--ci-text-1); }
.ci-criterion-meta { display: flex; align-items: center; gap: 10px; }
.ci-criterion-type { font-size: 12px; color: var(--ci-text-4); }
.ci-criterion-weight {
	background: #e8f0fe;
	color: #1d4ed8;
	font-size: 11px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 3px;
}
.ci-issues-flag {
	background: #fee2e2;
	color: #dc2626;
	font-size: 10px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 3px;
}
.ci-result-row {
	display: grid;
	grid-template-columns: 185px 150px 60px 1fr;
	padding: 10px 18px;
	border-bottom: 1px solid var(--ci-border-3);
	align-items: start;
	font-size: 12px;
}
.ci-result-row:last-child { border-bottom: none; }
.ci-result-row:nth-child(even) { background: var(--ci-surf-3); }
.ci-result-persona { font-weight: 600; color: var(--ci-text-2); }
.ci-result-conf { font-weight: 500; color: var(--ci-text-2); }
.ci-result-rationale { color: var(--ci-text-3); line-height: 1.55; }
.ci-result-head {
	display: grid;
	grid-template-columns: 185px 150px 60px 1fr;
	padding: 7px 18px;
	background: var(--ci-surf-3);
	border-bottom: 1px solid var(--ci-border-2);
}
.ci-result-head span {
	font-size: 10px;
	font-weight: 600;
	color: var(--ci-text-4);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* ── Offeror cards ────────────────────────────────────────────────────────── */
.ci-offeror-card {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-radius: 8px;
	overflow: hidden;
	margin-bottom: 12px;
}
.ci-offeror-card.has-error { border-color: #fca5a5; }
.ci-offeror-header {
	padding: 13px 18px;
	display: flex;
	align-items: center;
	gap: 12px;
	border-bottom: 1px solid var(--ci-border-3);
}
.ci-offeror-card.has-error .ci-offeror-header { border-bottom-color: #fee2e2; }
.ci-offeror-avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 700;
	flex-shrink: 0;
}
.ci-offeror-name { font-size: 14px; font-weight: 700; color: var(--ci-text-1); }
.ci-offeror-sub { font-size: 11px; color: var(--ci-text-4); margin-top: 2px; }
.ci-offeror-sub.error { color: #dc2626; }
.ci-offeror-files { padding: 10px 18px; display: flex; flex-direction: column; gap: 5px; }
.ci-file-row {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	color: var(--ci-text-2);
}
.ci-file-ok   { color: #059669; font-weight: 700; }
.ci-file-fail { color: #dc2626; font-weight: 700; }
.ci-offeror-form {
	padding: 10px 18px 14px;
	display: flex;
	align-items: center;
	gap: 8px;
}

/* ── Settings provider cards ──────────────────────────────────────────────── */
.ci-provider-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-bottom: 20px;
}
.ci-provider-card {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-radius: 8px;
	padding: 22px;
	position: relative;
}
.ci-provider-card.active { border: 2px solid var(--ci-accent); }
.ci-active-badge {
	position: absolute;
	top: 14px;
	right: 14px;
	background: #dcfce7;
	color: #166534;
	font-size: 10px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 3px;
}
.ci-provider-icon {
	width: 40px;
	height: 40px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 800;
	flex-shrink: 0;
}
.ci-form-label {
	font-size: 12px;
	font-weight: 600;
	color: var(--ci-text-3);
	display: block;
	margin-bottom: 4px;
}
.ci-form-input {
	width: 100%;
	border: 1px solid var(--ci-border-input);
	border-radius: 6px;
	padding: 8px 12px;
	font-size: 13px;
	font-family: inherit;
	color: var(--ci-text-2);
	margin-bottom: 12px;
	background: var(--ci-surface);
	transition: border-color 0.15s;
}
.ci-form-input:focus { outline: none; border-color: var(--ci-accent); box-shadow: 0 0 0 2px rgba(23,148,193,0.15); }
.ci-form-select {
	width: 100%;
	border: 1px solid var(--ci-border-input);
	border-radius: 6px;
	padding: 8px 12px;
	font-size: 13px;
	font-family: inherit;
	color: var(--ci-text-2);
	background: var(--ci-surface);
}
.ci-provider-selector {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-radius: 8px;
	padding: 20px;
	margin-bottom: 20px;
}
.ci-radio-row {
	display: flex;
	gap: 12px;
}
.ci-radio-option {
	display: flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	flex: 1;
	border: 1px solid var(--ci-border);
	border-radius: 6px;
	padding: 13px 16px;
	transition: border-color 0.15s;
}
.ci-radio-option:has(input:checked) { border: 2px solid var(--ci-accent); }
.ci-radio-option input[type=radio] { accent-color: var(--ci-text-1); width: 16px; height: 16px; flex-shrink: 0; }

/* ── Form section (create solicitation, add criterion) ───────────────────── */
.ci-form-section {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-radius: 8px;
	padding: 22px 24px;
	margin-bottom: 16px;
}
.ci-form-grid {
	display: grid;
	grid-template-columns: 160px 1fr;
	gap: 0;
}
.ci-form-grid dt {
	font-size: 13px;
	font-weight: 600;
	color: var(--ci-text-2);
	padding: 10px 0;
	display: flex;
	align-items: center;
}
.ci-form-grid dd {
	margin: 0;
	padding: 8px 0;
	display: flex;
	align-items: center;
}
.ci-form-grid dd input,
.ci-form-grid dd select,
.ci-form-grid dd textarea {
	border: 1px solid var(--ci-border-input);
	border-radius: 6px;
	padding: 8px 12px;
	font-size: 13px;
	font-family: inherit;
	color: var(--ci-text-2);
	background: var(--ci-surface);
	width: 100%;
	max-width: 480px;
}
.ci-form-grid dd textarea { resize: vertical; }
.ci-form-grid dd input:focus,
.ci-form-grid dd select:focus,
.ci-form-grid dd textarea:focus { outline: none; border-color: var(--ci-accent); }

/* ── Template apply bar ───────────────────────────────────────────────────── */
.ci-template-bar {
	background: #eef4ff;
	border: 1px solid #bdd3f5;
	border-radius: 8px;
	padding: 11px 16px;
	margin-bottom: 14px;
	display: flex;
	align-items: center;
	gap: 12px;
}

/* ── Criteria table ───────────────────────────────────────────────────────── */
.ci-criteria-table {
	width: 100%;
	border-collapse: collapse;
}
.ci-criteria-table th {
	font-size: 10px;
	font-weight: 600;
	color: var(--ci-text-4);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 8px 16px;
	text-align: left;
	background: var(--ci-surf-2);
	border-bottom: 1px solid var(--ci-border);
}
.ci-criteria-table td {
	padding: 11px 16px;
	font-size: 12px;
	color: var(--ci-text-2);
	border-bottom: 1px solid var(--ci-border-3);
	vertical-align: middle;
}
.ci-criteria-table tr:last-child td { border-bottom: none; }
.ci-criteria-table tr:nth-child(even) td { background: var(--ci-surf-3); }
.ci-criteria-table .crit-name { font-size: 13px; font-weight: 600; color: var(--ci-text-1); }
.ci-criteria-table .crit-desc { font-size: 11px; color: var(--ci-text-4); margin-top: 2px; }
.ci-criteria-table .crit-weight { font-weight: 700; color: var(--ci-text-1); }

/* ── Add criterion expander ───────────────────────────────────────────────── */
.ci-expander-btn {
	width: 100%;
	background: var(--ci-surface);
	border: 1px dashed var(--ci-border-input);
	border-radius: 6px;
	padding: 9px;
	font-size: 13px;
	color: var(--ci-text-3);
	cursor: pointer;
	font-family: inherit;
	margin-top: 10px;
	transition: background 0.12s;
}
.ci-expander-btn:hover { background: var(--ci-surf-2); }
.ci-expander-body {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-top: none;
	border-radius: 0 0 8px 8px;
	padding: 18px 20px;
	display: none;
}
.ci-expander-body.open { display: block; }

/* ── Add-offeror form ─────────────────────────────────────────────────────── */
.ci-add-offeror-row {
	display: flex;
	align-items: center;
	gap: 10px;
	background: var(--ci-surf-2);
	border: 1px dashed var(--ci-border-input);
	border-radius: 8px;
	padding: 12px 16px;
	margin-top: 6px;
}

/* ── Diagnostics ──────────────────────────────────────────────────────────── */
.ci-diag-file {
	background: var(--ci-surface);
	border: 1px solid var(--ci-border);
	border-radius: 8px;
	padding: 16px 20px;
	margin-bottom: 14px;
}
.ci-diag-file.quality-ok     { border-left: 4px solid #059669; }
.ci-diag-file.quality-garbled { border-left: 4px solid #dc2626; }
.ci-diag-file.quality-sparse  { border-left: 4px solid #d97706; }
.ci-diag-file.quality-empty   { border-left: 4px solid #9ca3af; }
.ci-diag-row { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; margin-bottom: 8px; }
.ci-quality-ok      { color: #059669; font-weight: 700; font-size: 12px; }
.ci-quality-garbled { color: #dc2626; font-weight: 700; font-size: 12px; }
.ci-quality-sparse  { color: #d97706; font-weight: 700; font-size: 12px; }
.ci-quality-empty   { color: var(--ci-text-4); font-weight: 700; font-size: 12px; }
.ci-pre {
	background: var(--ci-surf-3);
	padding: 10px;
	font-size: 11px;
	overflow: auto;
	max-height: 120px;
	white-space: pre-wrap;
	border: 1px solid var(--ci-border);
	border-radius: 4px;
	margin: 8px 0;
}
.ci-tool-table { max-width: 480px; border-collapse: collapse; margin-bottom: 20px; }
.ci-tool-table td { padding: 7px 14px; font-size: 13px; border-bottom: 1px solid var(--ci-border-2); }
.ci-tool-table tr:last-child td { border-bottom: none; }

/* ── Dashboard empty state ────────────────────────────────────────────────── */
.ci-empty {
	text-align: center;
	padding: 48px 24px;
	color: var(--ci-text-4);
}
.ci-empty h2 { font-size: 16px; color: var(--ci-text-3); margin-bottom: 8px; }
.ci-empty p  { font-size: 13px; margin-bottom: 18px; }

/* ── Utility ──────────────────────────────────────────────────────────────── */
.ci-muted  { color: var(--ci-text-4); font-size: 11px; }
.ci-link   { color: var(--ci-accent); text-decoration: none; font-weight: 500; }
.ci-link:hover { text-decoration: underline; }
.ci-mono   { font-family: monospace; font-size: 11px; background: var(--ci-border-2); padding: 2px 6px; border-radius: 3px; }
.ci-section-label {
	font-size: 11px;
	font-weight: 700;
	color: var(--ci-text-4);
	text-transform: uppercase;
	letter-spacing: 0.07em;
	margin: 0 0 14px;
}
.ci-divider { height: 1px; background: var(--ci-border-2); margin: 20px 0; }
.ci-flex    { display: flex; align-items: center; gap: 10px; }
.ci-flex-1  { flex: 1; }
.ci-text-right { text-align: right; }

/* ── Improvement suggestions panel ───────────────────────────────────────── */
.ci-suggestions-area {
	display: none;
	border-top: 1px solid var(--ci-border-2);
	background: var(--ci-surf-2);
	border-radius: 0 0 8px 8px;
	overflow: visible;
	min-height: 0;
}
.ci-suggestions-area.open {
	display: block;
	animation: fadein .2s ease;
}
.ci-suggestions-loading {
	padding: 16px 20px;
	font-size: 13px;
	color: var(--ci-text-3);
	font-style: italic;
}
.ci-suggestions-error {
	padding: 14px 20px;
	font-size: 13px;
	color: #dc2626;
	background: #fff5f5;
}
.ci-suggestions-list {
	padding: 18px 20px 28px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	overflow: visible;
}
.ci-sug-item {
	display: flex;
	gap: 12px;
	align-items: flex-start;
}
.ci-suggestions-list .ci-sug-num {
	width: 24px;
	height: 24px;
	background: #0c2340;
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-top: 1px;
}
.ci-suggestions-list .ci-sug-text {
	font-size: 13px;
	color: var(--ci-text-2);
	line-height: 1.65;
	flex: 1;
}
.ci-suggest-btn:hover {
	background: #1794c1 !important;
	color: #fff !important;
	transition: background .15s, color .15s;
}

/* Ensure suggestions content never clips */
.ci-suggestions-md {
	padding: 18px 20px 28px;
	overflow: visible;
	width: 100%;
}

/* ── Criterion collapse toggle ───────────────────────────────────────── */
.ci-criterion-toggle:hover { background: rgba(0,0,0,.02); }
.ci-criterion-toggle:hover .ci-twisty { color: var(--ci-text-3) !important; }
.ci-criterion-body { display: block; }

/* ── Rationale formatted content ────────────────────────────────────────── */
.ci-result-rationale p { margin: 0 0 6px; }
.ci-result-rationale p:last-child { margin-bottom: 0; }
.ci-result-rationale ul, .ci-result-rationale ol { margin: 4px 0 4px 16px; padding: 0; }
.ci-result-rationale li { margin: 2px 0; line-height: 1.5; }
.ci-result-rationale strong { color: var(--ci-text-1); }
.ci-result-rationale h4, .ci-result-rationale h5 { font-size: 12px; font-weight: 700; color: var(--ci-text-1); margin: 8px 0 4px; }


/* ══════════════════════════════════════════════════════════════════════════
   CI DARA — Dark mode component overrides
   ══════════════════════════════════════════════════════════════════════════ */

body.ci-dark .ci-btn-primary                           { background: #1794c1; }
body.ci-dark .ci-btn-secondary                         { color: var(--ci-text-2); }
body.ci-dark .ci-criterion-num                         { background: #1794c1; }
body.ci-dark .ci-suggestions-list .ci-sug-num          { background: #1794c1; }
body.ci-dark .ci-tab:hover                             { color: var(--ci-text-1); text-decoration: none; }
body.ci-dark .ci-tab.active                            { color: var(--ci-text-1); border-bottom-color: var(--ci-accent); }
body.ci-dark .ci-form-input:focus                      { border-color: var(--ci-accent); box-shadow: 0 0 0 2px rgba(56,178,218,.15); }
body.ci-dark .ci-form-grid dd input:focus,
body.ci-dark .ci-form-grid dd select:focus,
body.ci-dark .ci-form-grid dd textarea:focus           { border-color: var(--ci-accent); }
body.ci-dark .ci-radio-option:has(input:checked)       { border-color: var(--ci-accent); }
body.ci-dark .ci-radio-option input[type=radio]        { accent-color: var(--ci-accent); }
body.ci-dark .ci-provider-card.active                  { border-color: var(--ci-accent); }
body.ci-dark .ci-suggest-btn:hover                     { background: var(--ci-accent) !important; }
body.ci-dark .ci-criterion-toggle:hover                { background: rgba(255,255,255,.03); }
body.ci-dark .ci-result-rationale strong               { color: var(--ci-text-1); }
body.ci-dark .ci-result-rationale h4,
body.ci-dark .ci-result-rationale h5                   { color: var(--ci-text-1); }

/* ── Theme toggle button ──────────────────────────────────────────────────── */
#ci-theme-toggle {
	position: fixed;
	bottom: 24px;
	right: 24px;
	z-index: 9999;
	width: 36px;
	height: 36px;
	border-radius: 8px;
	border: 1px solid var(--ci-border);
	background: var(--ci-surface);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--ci-text-3);
	box-shadow: 0 2px 8px rgba(0,0,0,.15);
	padding: 0;
	transition: background .15s, border-color .15s, color .15s;
}
#ci-theme-toggle:hover {
	background: var(--ci-surf-2);
	color: var(--ci-text-1);
}
#ci-theme-toggle .ci-icon-moon,
#ci-theme-toggle .ci-icon-sun {
	display: flex;
	align-items: center;
	justify-content: center;
}
body.ci-dark #ci-theme-toggle .ci-icon-moon { display: none !important; }
body.ci-dark #ci-theme-toggle .ci-icon-sun  { display: flex !important; }
