.one-system-portal {
	color: #17202a;
	font-family: inherit;
}
.one-system-panel {
	background: #ffffff;
	border: 1px solid #dce3ea;
	border-radius: 8px;
	box-shadow: 0 8px 24px rgba(18, 28, 45, 0.08);
	margin: 16px 0;
	padding: 18px;
}
.one-system-panel h2 {
	font-size: 22px;
	margin: 0 0 12px;
}
.one-system-panel input {
	max-width: 100%;
	width: 520px;
}
.one-system-panel progress {
	height: 12px;
	width: 100%;
}
.one-system-elementor {
	box-sizing: border-box;
}
.one-system-element-title {
	font-size: 24px;
	margin: 0 0 14px;
}
.one-system-stat-grid {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	margin: 12px 0;
}
.one-system-stat-card {
	background: #eef3f8;
	border: 1px solid #d4dde7;
	border-radius: 6px;
	padding: 12px;
}
.one-system-stat-card span {
	display: block;
	font-size: 12px;
	opacity: 0.78;
}
.one-system-stat-card strong {
	display: block;
	font-size: 18px;
	margin-top: 5px;
}
.one-system-alert {
	background: #fff8e6;
	border: 1px solid #f1d58d;
	border-radius: 6px;
	color: #5f4614;
	padding: 10px 12px;
}
.one-system-table {
	border-collapse: collapse;
	margin-top: 12px;
	width: 100%;
}
.one-system-table th,
.one-system-table td {
	border-bottom: 1px solid #dce3ea;
	padding: 9px 8px;
	text-align: left;
}
.one-system-notice-list {
	display: grid;
	gap: 10px;
}
.one-system-notice {
	border: 1px solid #dce3ea;
	border-radius: 6px;
	padding: 12px;
}
.one-system-button,
.one-system-portal button,
.one-system-portal input[type="submit"] {
	background: #116b4f;
	border: 0;
	border-radius: 6px;
	color: #fff;
	cursor: pointer;
	padding: 10px 14px;
}
.one-system-course-progress {
	display: flex;
	gap: 8px;
	margin: 12px 0;
}
.one-system-course-progress span {
	align-items: center;
	background: #eef3f8;
	border: 1px solid #d4dde7;
	border-radius: 999px;
	display: inline-flex;
	font-size: 12px;
	height: 28px;
	justify-content: center;
	width: 28px;
}
.one-system-course-progress .is-complete {
	background: #116b4f;
	border-color: #116b4f;
	color: #fff;
}
.one-system-empty {
	border: 1px solid #dce3ea;
	border-radius: 8px;
	padding: 16px;
}
.one-system-matrix {
	display: grid;
	gap: 6px;
	grid-template-columns: repeat(var(--matrix-width, 12), minmax(64px, 1fr));
	overflow-x: auto;
}
.one-system-matrix span {
	background: #eef3f8;
	border: 1px solid #d4dde7;
	border-radius: 6px;
	font-size: 12px;
	min-height: 48px;
	padding: 8px;
	text-align: center;
}
@media (prefers-color-scheme: dark) {
	.one-system-portal {
		color: #edf3f8;
	}
	.one-system-panel,
	.one-system-empty {
		background: #11151b;
		border-color: #27303a;
	}
	.one-system-matrix span {
		background: #1b232d;
		border-color: #344252;
	}
	.one-system-stat-card,
	.one-system-notice {
		background: #1b232d;
		border-color: #344252;
	}
	.one-system-alert {
		background: #2a2415;
		border-color: #6a5420;
		color: #f6e3ad;
	}
	.one-system-table th,
	.one-system-table td {
		border-color: #27303a;
	}
}
