/**
 * Shared widgets — stat summaries, status chips, info strips.
 * Loaded on all app pages via includes/head.php.
 */

.osinv-widget-row {
	display: grid;
	gap: 0.85rem;
	min-width: 0;
}

.osinv-widget-row--stats {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.osinv-widget-row--status {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* ─── Stat widget (summary counts / amounts) ─────────────────── */
.osinv-stat-widget {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.95rem 1.05rem;
	border: 1px solid var(--border);
	border-radius: var(--radius);
	background: var(--surface);
	min-width: 0;
}

.osinv-stat-widget__icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: var(--radius-sm);
	background: var(--primary-ghost);
	color: var(--primary-mid);
	font-size: 0.9375rem;
}

.osinv-stat-widget__icon--success {
	background: var(--success-soft);
	color: var(--success);
}

.osinv-stat-widget__icon--warning {
	background: var(--warning-soft);
	color: var(--warning);
}

.osinv-stat-widget__icon--danger {
	background: var(--danger-soft);
	color: var(--danger);
}

.osinv-stat-widget__label {
	display: block;
	margin-bottom: 0.15rem;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--text-muted);
	line-height: 1.3;
}

.osinv-stat-widget__value {
	display: block;
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--text-dark);
	line-height: 1.2;
}

.osinv-stat-widget__hint {
	display: block;
	margin-top: 0.2rem;
	font-size: 11px;
	color: var(--text-muted);
	line-height: 1.35;
}

/* ─── Status widget (payment / document state) ───────────────── */
.osinv-status-widget {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	padding: 0.8rem 0.95rem;
	border: 1px solid var(--border);
	border-radius: var(--radius-sm);
	background: var(--surface);
	min-width: 0;
}

.osinv-status-widget__icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: var(--radius-xs);
	background: var(--bg);
	color: var(--text-muted);
	font-size: 0.875rem;
}

.osinv-status-widget__body {
	flex: 1;
	min-width: 0;
}

.osinv-status-widget__label {
	display: block;
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--text-muted);
	line-height: 1.3;
}

.osinv-status-widget__value {
	display: block;
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--text-dark);
	line-height: 1.2;
}

.osinv-status-widget--paid .osinv-status-widget__icon {
	background: var(--success-soft);
	color: var(--success);
}

.osinv-status-widget--pending .osinv-status-widget__icon {
	background: var(--warning-soft);
	color: var(--warning);
}

.osinv-status-widget--partial .osinv-status-widget__icon {
	background: var(--primary-ghost);
	color: var(--primary-mid);
}

.osinv-status-widget--overdue .osinv-status-widget__icon {
	background: var(--danger-soft);
	color: var(--danger);
}

.osinv-status-widget--draft .osinv-status-widget__icon {
	background: var(--bg);
	color: var(--text-muted);
}

/* ─── Info widget (compact notice strip) ─────────────────────── */
.osinv-info-widget {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	padding: 0.85rem 1rem;
	border: 1px solid var(--border);
	border-radius: var(--radius-sm);
	background: var(--surface);
	font-size: var(--ui-font-size);
	color: var(--text-mid);
	line-height: 1.45;
}

.osinv-info-widget__icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.75rem;
	height: 1.75rem;
	border-radius: var(--radius-xs);
	background: var(--primary-ghost);
	color: var(--primary-mid);
	font-size: 0.875rem;
}

.osinv-info-widget__title {
	display: block;
	margin-bottom: 0.15rem;
	font-size: 12px;
	font-weight: 700;
	color: var(--text-dark);
}

/* ─── List status pills (shared — use on tables, sendouts, integrations) ── */
.doc-list-status {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 4.5rem;
	padding: 0.15rem 0.55rem;
	border-radius: 20px;
	font-weight: 600;
	font-size: 12px;
	line-height: 1.4;
	white-space: nowrap;
}

.doc-list-status--draft {
	background: var(--bg);
	color: var(--text-muted);
}

.doc-list-status--issued {
	background: var(--primary-ghost);
	color: var(--primary-mid);
}

.doc-list-status--cancelled,
.doc-list-status--rejected {
	background: var(--danger-soft);
	color: var(--danger);
}

.doc-list-status--paid,
.doc-list-status--approved {
	background: var(--success-soft);
	color: var(--success);
}

.doc-list-status--pending {
	background: var(--warning-soft);
	color: var(--warning);
}

.doc-list-status--partial {
	background: var(--accent-soft);
	color: var(--primary-mid);
}

.doc-list-status--overdue {
	background: var(--danger-soft);
	color: var(--danger);
}

@media (max-width: 991.98px) {
	.osinv-widget-row--stats,
	.osinv-widget-row--status {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 575.98px) {
	.osinv-widget-row--stats,
	.osinv-widget-row--status {
		grid-template-columns: 1fr;
	}
}
