.skorspm-student-dashboard,
.skorspm-subject-dashboard {
	--sd-heading: var(--sk-unified-heading, #0f2f63);
	--sd-link: var(--sk-unified-link, #1552c0);
	--sd-link-hover: var(--sk-unified-link-hover, #0a3f95);
	--sd-on-primary: var(--sk-unified-on-primary, #ffffff);
	--sd-student-hero-start: var(--sk-unified-student-hero-start, #1552c0);
	--sd-student-hero-start-rgb: var(--sk-unified-student-hero-start-rgb, 21, 82, 192);
	--sd-student-hero-end: var(--sk-unified-student-hero-end, #00a28a);
	--sd-student-hero-end-rgb: var(--sk-unified-student-hero-end-rgb, 0, 162, 138);
	--sd-student-card-bg: var(--sk-unified-student-card-bg, #f8fbff);
	--sd-student-card-border: var(--sk-unified-student-card-border, #ccddf7);
	--sd-student-card-hover-border: var(--sk-unified-student-card-hover-border, #8ab1ef);
	--sd-student-button-text: var(--sk-unified-student-button-text, #1552c0);
	--sd-student-button-bg: var(--sk-unified-student-button-bg, #ffffff);
	--sd-student-button-border: var(--sk-unified-student-button-border, #1552c0);
	--sd-student-button-hover-bg: var(--sk-unified-student-button-hover-bg, #e5efff);
	--sd-student-button-hover-border: var(--sk-unified-student-button-hover-border, #0a3f95);
	--sd-student-badge-bg: var(--sk-unified-student-badge-bg, #eaf2ff);
	--sd-student-badge-border: var(--sk-unified-student-badge-border, #c2d8ff);
	--sd-student-badge-text: var(--sk-unified-student-badge-text, #244b85);
	--sd-student-video-overlay-bg: var(--sk-unified-student-video-overlay-bg, #052766);
	--sd-student-video-overlay-bg-rgb: var(--sk-unified-student-video-overlay-bg-rgb, 5, 39, 102);
	--sd-student-video-overlay-text: var(--sk-unified-student-video-overlay-text, #ffffff);
	--sd-fq-header-color: var(--sk-ui-fq-header-color, var(--sd-heading));
	--sd-fq-subheader-color: var(--sk-ui-fq-subheader-color, #425771);
	--sd-fq-header-font: var(--sk-ui-fq-header-font, var(--sk-unified-font-heading, "Poppins", "Trebuchet MS", sans-serif));
	--sd-fq-subheader-font: var(--sk-ui-fq-subheader-font, var(--sk-unified-font-body, "Nunito Sans", "Trebuchet MS", "Helvetica Neue", sans-serif));
	--sd-fq-header-size: var(--sk-ui-fq-header-size, 1.14rem);
	--sd-fq-subheader-size: var(--sk-ui-fq-subheader-size, 0.92rem);
	--sd-fq-button-bg: var(--sk-ui-fq-button-bg, var(--sd-student-button-bg));
	--sd-fq-button-border: var(--sk-ui-fq-button-border, var(--sd-student-button-border));
	--sd-fq-button-text: var(--sk-ui-fq-button-text, var(--sd-student-button-text));
	--sd-fq-button-hover-bg: var(--sk-ui-fq-button-hover-bg, var(--sd-student-button-hover-bg));
	--sd-fq-button-hover-border: var(--sk-ui-fq-button-hover-border, var(--sd-student-button-hover-border));
	--sd-fq-button-hover-text: var(--sk-ui-fq-button-hover-text, var(--sd-fq-button-text));
	--sd-fq-button-shadow-rgb: var(--sk-ui-fq-button-shadow-rgb, 21, 82, 192);
	--sd-fq-container-bg: var(--sk-ui-fq-container-bg, #ffffff);
	--sd-fq-container-border: var(--sk-ui-fq-container-border, #ccdef8);
	--sd-fq-badge-bg: var(--sk-ui-fq-badge-bg, var(--sd-student-badge-bg));
	--sd-fq-badge-border: var(--sk-ui-fq-badge-border, var(--sd-student-badge-border));
	--sd-fq-badge-text: var(--sk-ui-fq-badge-text, var(--sd-student-badge-text));
	max-width: 1100px;
	margin: 28px auto;
	padding: 0 5px 18px;
	display: grid;
	gap: 16px;
	width: 100%;
	box-sizing: border-box;
	background:
		radial-gradient(circle at 10% -10%, rgba(var(--sd-student-hero-start-rgb), 0.15), transparent 38%),
		radial-gradient(circle at 100% 0%, rgba(var(--sd-student-hero-end-rgb), 0.12), transparent 30%),
		linear-gradient(180deg, #f7fbff 0%, #f2f7ff 55%, #eef6f8 100%);
	border-radius: 18px;
}

.skorspm-student-dashboard,
.skorspm-student-dashboard *,
.skorspm-student-dashboard *::before,
.skorspm-student-dashboard *::after,
.skorspm-subject-dashboard,
.skorspm-subject-dashboard *,
.skorspm-subject-dashboard *::before,
.skorspm-subject-dashboard *::after {
	box-sizing: border-box;
	min-width: 0;
}

.skorspm-student-dashboard img,
.skorspm-student-dashboard iframe,
.skorspm-student-dashboard svg,
.skorspm-subject-dashboard img,
.skorspm-subject-dashboard iframe,
.skorspm-subject-dashboard svg {
	max-width: 100%;
}

.skorspm-student-dashboard__card,
.skorspm-subject-dashboard__section,
.skorspm-student-dashboard--notice,
.skorspm-subject-dashboard--notice {
	position: relative;
	overflow: hidden;
	background: linear-gradient(180deg, #ffffff 0%, var(--sd-student-card-bg) 100%);
	border: 1px solid var(--sd-student-card-border);
	border-radius: 16px;
	padding: 18px;
	box-shadow: 0 10px 24px rgba(15, 61, 145, 0.08);
}

.skorspm-student-dashboard__card::before,
.skorspm-subject-dashboard__section::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 4px;
	background: linear-gradient(90deg, var(--sd-student-hero-start) 0%, var(--sd-student-hero-end) 100%);
}

.skorspm-student-dashboard__card h2,
.skorspm-subject-dashboard__section h3,
.skorspm-subject-dashboard h2 {
	margin: 0 0 8px;
	line-height: 1.2;
	font-size: clamp(1.45rem, 1.2rem + 1.2vw, 2.2rem);
	letter-spacing: -0.02em;
	color: var(--sd-heading);
}

.skorspm-student-dashboard__card h2.skorspm-student-dashboard__subscribed-title {
	font-size: 0.98rem;
}

.skorspm-student-dashboard__subtext,
.skorspm-subject-dashboard__subtext {
	margin: 0 0 12px;
	font-size: 1rem;
	color: #425771;
}

.skorspm-quiz-section > h2,
.skorspm-flashcard-section > h2 {
	font-family: var(--sd-fq-header-font);
	font-size: var(--sd-fq-header-size);
	color: var(--sd-fq-header-color);
}

.skorspm-quiz-section > .skorspm-subject-dashboard__subtext,
.skorspm-flashcard-section__subheader {
	margin: 0 0 12px;
	font-family: var(--sd-fq-subheader-font);
	font-size: var(--sd-fq-subheader-size);
	color: var(--sd-fq-subheader-color);
}

.skorspm-student-dashboard__welcome-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}

.skorspm-student-dashboard__welcome-item {
	border: 1px solid #c7d8f2;
	border-radius: 12px;
	padding: 10px 12px;
	background: #f6fbff;
	min-width: 0;
}

.skorspm-student-dashboard__welcome-item--parent-email {
	display: none;
}

.skorspm-student-dashboard__welcome-label {
	display: block;
	margin: 0 0 4px;
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 700;
	color: #6f8197;
}

.skorspm-student-dashboard__welcome-value {
	display: block;
	font-size: 0.98rem;
	line-height: 1.35;
	color: #173b71;
	overflow-wrap: anywhere;
}

.skorspm-student-dashboard__avatar-form {
	margin-top: 12px;
}

.skorspm-student-dashboard__avatar-row {
	display: flex;
	align-items: center;
	gap: 12px;
}

.skorspm-student-dashboard__avatar-thumbnail-wrap {
	order: 1;
	flex: 0 0 auto;
	width: 100px;
	height: 100px;
	border-radius: 50%;
	border: 2px solid #9bc0ea;
	background: #ffffff;
	overflow: hidden;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.skorspm-student-dashboard__avatar-thumbnail {
	display: block;
	width: 100px;
	height: 100px;
	object-fit: cover;
}

.skorspm-student-dashboard__exp-summary {
	order: 3;
	flex: 0 0 auto;
	margin-left: auto;
	min-width: 150px;
	padding: 10px 12px;
	border: 1px solid #c7d8f2;
	border-radius: 12px;
	background: #f6fbff;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	text-align: center;
}

.skorspm-student-dashboard__rank-image {
	display: block;
	width: 70px;
	height: 70px;
	object-fit: contain;
}

.skorspm-student-dashboard__rank-fallback {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 70px;
	height: 70px;
	padding: 6px;
	border-radius: 999px;
	border: 1px solid var(--sd-student-badge-border);
	background: var(--sd-student-badge-bg);
	color: var(--sd-student-badge-text);
	font-size: 0.72rem;
	font-weight: 700;
	line-height: 1.2;
}

.skorspm-student-dashboard__rank-text {
	margin: 0;
	font-size: 0.82rem;
	font-weight: 700;
	color: #173b71;
}

.skorspm-student-dashboard__exp-text {
	margin: 0;
	font-size: 0.88rem;
	color: #35516b;
}

.skorspm-student-dashboard__exp-text strong {
	font-weight: 800;
	color: #0f2f63;
}

.skorspm-student-dashboard__avatar-controls {
	order: 2;
	flex: 1 1 auto;
	min-width: 0;
}

.skorspm-student-dashboard__avatar-controls label {
	display: block;
	margin: 0;
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #6f8197;
}

.skorspm-student-dashboard__avatar-controls input[type='file'] {
	display: block;
	width: 100%;
	max-width: 360px;
	margin: 8px 0 0;
	font-size: 0.86rem;
	color: #173b71;
}

.skorspm-student-dashboard__avatar-controls button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 8px;
	padding: 9px 14px;
	border-radius: 10px;
	border: 1px solid var(--sd-student-button-border);
	background: var(--sd-student-button-bg);
	color: var(--sd-student-button-text);
	font-weight: 700;
	font-size: 0.9rem;
	cursor: pointer;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.skorspm-student-dashboard__avatar-controls button:hover,
.skorspm-student-dashboard__avatar-controls button:focus {
	background: var(--sd-student-button-hover-bg);
	border-color: var(--sd-student-button-hover-border);
	box-shadow: 0 6px 14px rgba(21, 82, 192, 0.2);
	transform: translateY(-1px);
}

.skorspm-student-dashboard__avatar-controls button:focus-visible {
	outline: 3px solid rgba(39, 92, 173, 0.28);
	outline-offset: 1px;
}

.skorspm-student-dashboard__avatar-controls button:active {
	transform: translateY(0);
}

.skorspm-student-dashboard__nickname-form {
	margin-top: 12px;
}

.skorspm-student-dashboard__nickname-form label {
	display: block;
	margin: 0;
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #6f8197;
}

.skorspm-student-dashboard__nickname-row {
	display: flex;
	align-items: center;
	gap: 8px;
}

.skorspm-student-dashboard__nickname-row input[type='text'] {
	flex: 1 1 auto;
	min-width: 0;
	padding: 9px 11px;
	border-radius: 10px;
	border: 1px solid #b8cae8;
	background: #ffffff;
	color: #173b71;
}

.skorspm-student-dashboard__nickname-row input[type='text']:focus {
	outline: 2px solid rgba(39, 92, 173, 0.2);
	outline-offset: 1px;
	border-color: #5f89ca;
}

.skorspm-student-dashboard__nickname-row button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 9px 14px;
	border-radius: 10px;
	border: 1px solid var(--sd-student-button-border);
	background: var(--sd-student-button-bg);
	color: var(--sd-student-button-text);
	font-weight: 700;
	font-size: 0.9rem;
	cursor: pointer;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.skorspm-student-dashboard__nickname-row button:hover,
.skorspm-student-dashboard__nickname-row button:focus {
	background: var(--sd-student-button-hover-bg);
	border-color: var(--sd-student-button-hover-border);
	box-shadow: 0 6px 14px rgba(21, 82, 192, 0.2);
	transform: translateY(-1px);
}

.skorspm-student-dashboard__nickname-row button:focus-visible {
	outline: 3px solid rgba(39, 92, 173, 0.28);
	outline-offset: 1px;
}

.skorspm-student-dashboard__nickname-row button:active {
	transform: translateY(0);
}

.skorspm-student-dashboard__notice {
	border-radius: 12px;
	padding: 12px 14px;
	border: 1px solid #f7b4b4;
	background: linear-gradient(180deg, #fff7f7 0%, #ffecec 100%);
	color: #8b1f1f;
}

.skorspm-student-dashboard__notice ul {
	margin: 0;
	padding-left: 18px;
}

.skorspm-student-dashboard__subject-grid {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.skorspm-subject-dashboard__subject-grid {
	display: grid;
	gap: 12px;
	grid-template-columns: 1fr;
}

.skorspm-student-dashboard__subject-card {
	padding: 0;
	border-radius: 10px;
	border: 1px solid var(--sd-student-card-border);
	background: var(--sd-student-card-bg);
	overflow: hidden;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.skorspm-subject-dashboard__subject-card {
	border: 1px solid #c8daf5;
	border-radius: 14px;
	padding: 13px;
	background: linear-gradient(145deg, #ffffff 0%, #f1f8ff 100%);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.skorspm-student-dashboard__subject-card:hover,
.skorspm-student-dashboard__subject-card:focus-within {
	border-color: var(--sd-student-card-hover-border);
	box-shadow: 0 6px 16px rgba(9, 33, 58, 0.1);
}

.skorspm-subject-dashboard__subject-card:hover {
	transform: translateY(-2px);
	border-color: var(--sd-student-card-hover-border);
	box-shadow: 0 12px 20px rgba(21, 82, 192, 0.14);
}

.skorspm-student-dashboard__subject-card:nth-child(2n) {
	background: var(--sd-student-card-bg);
	border-color: var(--sd-student-card-border);
}

.skorspm-subject-dashboard__subject-card:nth-child(2n) {
	background: linear-gradient(145deg, #ffffff 0%, #effcf9 100%);
	border-color: #c0eadf;
}

.skorspm-student-dashboard__subject-card h3 {
	margin: 0 0 8px;
	font-size: 0.98rem;
	letter-spacing: -0.01em;
}

.skorspm-subject-dashboard__subject-card h3 {
	margin: 0 0 8px;
	font-size: 1.2rem;
	letter-spacing: -0.01em;
}

.skorspm-subject-metric-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 6px;
}

.skorspm-subject-metric-item {
	display: flex;
	align-items: flex-start;
	gap: 8px;
}

.skorspm-subject-metric-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	color: #1f538b;
	flex: 0 0 18px;
	margin-top: 1px;
}

.skorspm-subject-metric-icon svg {
	display: block;
	width: 18px;
	height: 18px;
}

.skorspm-subject-metric-text {
	font-size: 0.86rem;
	line-height: 1.45;
	color: #35516b;
}

.skorspm-subject-metric-text strong {
	font-weight: 800;
	color: #173b71;
}

.skorspm-student-dashboard__subject-card p {
	margin: 0 0 4px;
	font-size: 0.86rem;
	color: #35516b;
}

.skorspm-subject-dashboard__subject-card p {
	margin: 0 0 4px;
	font-size: 0.96rem;
	color: #3f566f;
}

.skorspm-student-dashboard__subject-card p:last-child,
.skorspm-subject-dashboard__subject-card p:last-child {
	margin-bottom: 0;
}

.skorspm-student-dashboard__subject-card-link {
	display: block;
	height: 100%;
	padding: 12px;
	color: inherit;
	text-decoration: none;
	transition: background-color 0.18s ease;
}

.skorspm-student-dashboard__subject-card-link h3 {
	color: var(--sd-link);
}

.skorspm-student-dashboard__subject-card-link:hover,
.skorspm-student-dashboard__subject-card-link:focus-visible {
	background: #edf5ff;
	text-decoration: none;
}

.skorspm-student-dashboard__subject-card-link:hover h3,
.skorspm-student-dashboard__subject-card-link:focus-visible h3 {
	color: var(--sd-link-hover);
}

.skorspm-subject-dashboard__subject-card a,
.skorspm-student-dashboard__action-link {
	color: var(--sd-link);
	text-decoration: none;
	font-weight: 700;
}

.skorspm-subject-dashboard__subject-card a:hover,
.skorspm-subject-dashboard__subject-card a:focus,
.skorspm-student-dashboard__action-link:hover,
.skorspm-student-dashboard__action-link:focus {
	text-decoration: underline;
}

.skorspm-student-dashboard__quiz-groups {
	display: grid;
	gap: 12px;
}

.skorspm-student-dashboard__quiz-group {
	border: 1px solid #c7dcff;
	border-radius: 12px;
	padding: 12px;
	background: linear-gradient(180deg, #f9fcff 0%, #f2f7ff 100%);
}

.skorspm-student-dashboard__quiz-group h3 {
	margin: 0 0 8px;
}

.skorspm-student-dashboard__quiz-list,
.skorspm-subject-dashboard__quiz-list,
.skorspm-subject-dashboard__resource-list,
.skorspm-student-dashboard__history-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 10px;
}

.skorspm-student-dashboard__quiz-item,
.skorspm-subject-dashboard__quiz-item,
.skorspm-subject-dashboard__resource-item,
.skorspm-student-dashboard__progress-card,
.skorspm-student-dashboard__history-item,
.skorspm-subject-dashboard__video-card {
	border: 1px solid #ccdef8;
	border-radius: 12px;
	padding: 12px;
	background: #ffffff;
}

.skorspm-student-dashboard__quiz-item strong,
.skorspm-subject-dashboard__quiz-item strong,
.skorspm-subject-dashboard__resource-item strong {
	color: #0f2f63;
	font-size: 1.1rem;
}

.skorspm-student-dashboard__quiz-meta {
	display: block;
	margin-top: 5px;
	font-size: 0.92rem;
	color: #4d6278;
}

.skorspm-student-dashboard__quiz-meta--guard {
	color: #8b1f1f;
	font-weight: 700;
}

.skorspm-student-dashboard__action-link,
.skorspm-subject-dashboard__resource-actions a,
.skorspm-subject-dashboard__resource-actions .skorspm-subject-dashboard__action-disabled {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 8px;
	padding: 8px 14px;
	border-radius: 10px;
	border: 1px solid var(--sd-student-button-border);
	background: var(--sd-student-button-bg);
	color: var(--sd-student-button-text);
	font-weight: 700;
	font-size: 0.9rem;
	text-decoration: none;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.skorspm-student-dashboard__action-link:hover,
.skorspm-student-dashboard__action-link:focus,
.skorspm-subject-dashboard__resource-actions a:hover,
.skorspm-subject-dashboard__resource-actions a:focus {
	text-decoration: none;
	background: var(--sd-student-button-hover-bg);
	border-color: var(--sd-student-button-hover-border);
	box-shadow: 0 6px 14px rgba(21, 82, 192, 0.2);
	transform: translateY(-1px);
}

.skorspm-subject-dashboard__resource-actions .skorspm-subject-dashboard__action-disabled {
	opacity: 0.58;
	cursor: not-allowed;
	box-shadow: none;
	transform: none;
}

.skorspm-subject-dashboard__resource-meta {
	margin: 8px 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.skorspm-subject-dashboard__tag {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 999px;
	background: var(--sd-student-badge-bg);
	border: 1px solid var(--sd-student-badge-border);
	color: var(--sd-student-badge-text);
	font-size: 0.8rem;
	font-weight: 600;
}

.skorspm-subject-dashboard__resource-actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.skorspm-subject-dashboard__video-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
	margin: 0 0 10px;
}

.skorspm-subject-dashboard__video-heading {
	margin: 0;
}

.skorspm-subject-dashboard__video-search-form {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-left: auto;
	padding: 4px;
	border: 1px solid var(--sd-student-card-border);
	border-radius: 12px;
	background: linear-gradient(180deg, #ffffff 0%, var(--sd-student-card-bg) 100%);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.skorspm-subject-dashboard__video-search-input {
	appearance: none;
	-webkit-appearance: none;
	height: 38px;
	min-width: 220px;
	padding: 7px 11px;
	border: 1px solid var(--sd-student-badge-border);
	border-radius: 9px;
	background: #ffffff;
	color: #123564;
	font-size: 0.92rem;
	font-family: "Nunito Sans", "Trebuchet MS", "Helvetica Neue", sans-serif;
	box-shadow: inset 0 1px 2px rgba(15, 47, 99, 0.06);
}

.skorspm-subject-dashboard__video-search-input::placeholder {
	color: #5f7898;
	opacity: 1;
}

.skorspm-subject-dashboard__video-search-input:focus {
	outline: 2px solid #8fb3e6;
	outline-offset: 1px;
	border-color: #8fb3e6;
}

.skorspm-subject-dashboard__video-search-button {
	height: 38px;
	padding: 0 12px;
	border: 1px solid var(--sd-student-button-border);
	border-radius: 10px;
	background: var(--sd-student-button-bg);
	color: var(--sd-student-button-text);
	font-size: 0.9rem;
	font-weight: 700;
	cursor: pointer;
	white-space: nowrap;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.skorspm-subject-dashboard__video-search-button:hover,
.skorspm-subject-dashboard__video-search-button:focus-visible {
	background: var(--sd-student-button-hover-bg);
	border-color: var(--sd-student-button-hover-border);
	box-shadow: 0 6px 14px rgba(21, 82, 192, 0.2);
}

.skorspm-subject-dashboard__video-item {
	padding: 10px 12px;
}

.skorspm-subject-dashboard__video-row {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: nowrap;
}

.skorspm-subject-dashboard__video-actions {
	flex: 0 0 auto;
	margin: 0;
}

.skorspm-subject-dashboard__video-actions a.skorspm-subject-dashboard__video-watch-button {
	margin-top: 0;
	padding: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
	transform: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.skorspm-subject-dashboard__video-actions a.skorspm-subject-dashboard__video-watch-button:hover,
.skorspm-subject-dashboard__video-actions a.skorspm-subject-dashboard__video-watch-button:focus-visible {
	border: 0;
	background: transparent;
	box-shadow: none;
	transform: none;
	outline: 2px solid #9db9e7;
	outline-offset: 2px;
}

.skorspm-subject-dashboard__video-watch-button img {
	display: block;
	width: auto;
	max-width: none;
	height: 40px;
}

.skorspm-subject-dashboard__resource-item .skorspm-subject-dashboard__video-title {
	font-family: "Nunito Sans", "Trebuchet MS", "Helvetica Neue", sans-serif;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.35;
	color: #0f2f63;
	margin: 0;
	flex: 1 1 auto;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

body.skorspm-video-lightbox-open {
	overflow: hidden;
}

.skorspm-video-lightbox {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
}

.skorspm-video-lightbox[hidden] {
	display: none;
}

.skorspm-video-lightbox__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(5, 20, 46, 0.78);
	backdrop-filter: blur(2px);
}

.skorspm-video-lightbox__dialog {
	position: relative;
	width: min(960px, 100%);
	max-height: calc(100dvh - 32px);
	background: #071733;
	border: 1px solid #265394;
	border-radius: 14px;
	padding: 14px;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5);
}

.skorspm-video-lightbox__close {
	appearance: none;
	border: 1px solid #9dc0f2;
	background: #f6fbff;
	color: #123564;
	border-radius: 999px;
	padding: 6px 12px;
	font-size: 0.82rem;
	font-weight: 700;
	cursor: pointer;
	margin: 0 0 10px;
}

.skorspm-video-lightbox__close:hover,
.skorspm-video-lightbox__close:focus-visible {
	background: #e8f2ff;
	border-color: #7ba4dd;
}

.skorspm-video-lightbox__title {
	margin: 0 0 10px;
	color: #e6f0ff;
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1.35;
}

.skorspm-video-lightbox__frame-wrap {
	aspect-ratio: 16 / 9;
	width: 100%;
	background: #000000;
	border-radius: 10px;
	overflow: hidden;
}

.skorspm-video-lightbox__frame-wrap iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}

.skorspm-subject-dashboard__pdf-list {
	gap: 8px;
}

.skorspm-subject-dashboard__pdf-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 12px;
}

.skorspm-subject-dashboard__pdf-item .skorspm-subject-dashboard__pdf-title {
	margin: 0;
	flex: 1 1 auto;
	font-size: 0.95rem;
	line-height: 1.35;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.skorspm-subject-dashboard__pdf-actions {
	margin-left: auto;
	gap: 6px;
	flex-wrap: nowrap;
	align-items: center;
}

.skorspm-subject-dashboard__pdf-actions .skorspm-subject-dashboard__icon-action {
	margin-top: 0;
	padding: 6px;
	width: 34px;
	height: 34px;
	border-radius: 10px;
	border: 1px solid var(--sd-student-badge-border);
	background: #ffffff;
	color: #1f3f6b;
	box-shadow: none;
}

.skorspm-subject-dashboard__pdf-actions .skorspm-subject-dashboard__icon-action svg {
	display: block;
	width: 19px;
	height: 19px;
}

.skorspm-subject-dashboard__pdf-actions .skorspm-subject-dashboard__icon-action:hover,
.skorspm-subject-dashboard__pdf-actions .skorspm-subject-dashboard__icon-action:focus {
	background: var(--sd-student-badge-bg);
	border-color: var(--sd-student-button-border);
	color: var(--sd-link);
	box-shadow: none;
	transform: none;
}

.skorspm-student-dashboard__progress-grid {
	display: grid;
	gap: 10px;
}

.skorspm-student-dashboard__progress-card {
	background: linear-gradient(170deg, #ffffff 0%, #eff7ff 100%);
}

.skorspm-student-dashboard__progress-card strong {
	display: block;
	margin-bottom: 4px;
	color: #0f2f63;
}

.skorspm-student-dashboard__progress-card--trend-stat p {
	margin: 0 0 5px;
}

.skorspm-student-dashboard__progress-card--trend-stat p:last-child {
	margin-bottom: 0;
}

.skorspm-student-dashboard__progress-card--top-rank {
	display: flex;
	flex-direction: column;
	gap: 12px;
	min-width: 0;
}

.skorspm-student-dashboard__summary-chart {
	display: grid;
	gap: 14px;
}

.skorspm-student-dashboard__summary-chart-svg {
	display: block;
	width: 100%;
	height: auto;
	padding: 10px;
	border: 1px solid rgba(15, 47, 99, 0.1);
	border-radius: 14px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(238, 246, 255, 0.98) 100%);
}

.skorspm-student-dashboard__summary-chart-grid {
	stroke: rgba(15, 47, 99, 0.12);
	stroke-width: 1;
}

.skorspm-student-dashboard__summary-chart-axis {
	stroke: rgba(15, 47, 99, 0.32);
	stroke-width: 1.2;
}

.skorspm-student-dashboard__summary-chart-axis-label,
.skorspm-student-dashboard__summary-chart-caption {
	fill: #5a6f88;
	font-size: 12px;
	font-family: var(--sk-unified-font-body);
}

.skorspm-student-dashboard__summary-chart-line {
	fill: none;
	stroke-width: 3;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.skorspm-student-dashboard__summary-chart-point {
	stroke: #ffffff;
	stroke-width: 2;
}

.skorspm-student-dashboard__summary-legend {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 10px;
}

.skorspm-student-dashboard__summary-legend-item {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 12px;
	border: 1px solid #ccdef8;
	border-radius: 12px;
	background: linear-gradient(170deg, #ffffff 0%, #eff7ff 100%);
}

.skorspm-student-dashboard__summary-legend-swatch {
	flex: 0 0 auto;
	width: 12px;
	height: 12px;
	margin-top: 4px;
	border-radius: 999px;
	background: var(--skorspm-summary-line-color, #2563eb);
	border: 2px solid rgba(255, 255, 255, 0.88);
}

.skorspm-student-dashboard__summary-legend-copy strong {
	display: block;
	margin-bottom: 4px;
	color: #0f2f63;
}

.skorspm-student-dashboard__summary-legend-copy p {
	margin: 0 0 4px;
	color: #34495f;
}

.skorspm-student-dashboard__summary-legend-copy p:last-child {
	margin-bottom: 0;
}

.skorspm-student-dashboard__top-rank-marquee {
	position: relative;
	height: 200px;
	overflow: hidden;
	border: 1px solid rgba(15, 47, 99, 0.1);
	border-radius: 14px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(232, 243, 255, 0.96) 100%);
}

.skorspm-student-dashboard__top-rank-marquee:focus {
	outline: 2px solid var(--sd-link);
	outline-offset: 2px;
}

.skorspm-student-dashboard__top-rank-marquee--empty {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
}

.skorspm-student-dashboard__top-rank-marquee--static {
	overflow-y: auto;
}

.skorspm-student-dashboard__top-rank-track {
	display: flex;
	flex-direction: column;
	will-change: transform;
	animation: skorspm-student-top-rank-scroll 60s linear infinite;
}

.skorspm-student-dashboard__top-rank-track--static {
	animation: none;
	transform: none;
}

.skorspm-student-dashboard__top-rank-marquee:hover .skorspm-student-dashboard__top-rank-track,
.skorspm-student-dashboard__top-rank-marquee:focus .skorspm-student-dashboard__top-rank-track {
	animation-play-state: paused;
}

.skorspm-student-dashboard__top-rank-list {
	list-style: none;
	margin: 0;
	padding: 10px 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.skorspm-student-dashboard__top-rank-item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 0;
	border-bottom: 1px solid rgba(15, 47, 99, 0.08);
}

.skorspm-student-dashboard__top-rank-avatar {
	width: 40px;
	height: 40px;
	flex: 0 0 40px;
	border-radius: 999px;
	object-fit: cover;
	border: 1px solid rgba(15, 47, 99, 0.1);
	background: #ffffff;
}

.skorspm-student-dashboard__top-rank-meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 4px 8px;
	min-width: 0;
	overflow-wrap: anywhere;
	line-height: 1.25;
}

.skorspm-student-dashboard__top-rank-name {
	font-size: 12px;
	font-weight: 700;
	color: #0f2f63;
}

.skorspm-student-dashboard__top-rank-exp {
	display: inline-flex;
	align-items: baseline;
	gap: 2px;
	font-size: 10px;
	color: #1f4d89;
	white-space: nowrap;
}

.skorspm-student-dashboard__top-rank-exp strong {
	display: inline;
	margin: 0;
	font-weight: 700;
}

.skorspm-student-dashboard__top-rank-rank {
	font-size: 10px;
	color: #5c6f86;
}

.skorspm-student-dashboard__top-rank-empty,
.skorspm-student-dashboard__top-rank-quote {
	margin: 0;
}

.skorspm-student-dashboard__top-rank-empty {
	font-size: 12px;
	text-align: center;
	color: #47627f;
}

.skorspm-student-dashboard__top-rank-quote {
	font-size: 12px;
	padding: 10px 12px;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid rgba(15, 47, 99, 0.08);
	font-style: italic;
	line-height: 1.4;
	color: #33557d;
}

@keyframes skorspm-student-top-rank-scroll {
	from {
		transform: translateY(0);
	}

	to {
		transform: translateY(-50%);
	}
}

.skorspm-student-dashboard__history-item p {
	margin: 0 0 5px;
	color: #34495f;
}

.skorspm-student-dashboard__history-item p:last-child {
	margin-bottom: 0;
}

.skorspm-student-dashboard__history-list--recent-attempts {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.skorspm-student-dashboard__history-item--recent-attempt {
	--skorspm-attempt-correct-stop: 0%;
	position: relative;
	overflow: hidden;
	background: transparent;
	border-color: rgba(164, 201, 176, 0.95);
}

.skorspm-student-dashboard__history-item--recent-attempt::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	background:
		linear-gradient(
			90deg,
			rgba(232, 247, 236, 0.96) 0%,
			rgba(232, 247, 236, 0.96) var(--skorspm-attempt-correct-stop),
			rgba(252, 235, 235, 0.96) var(--skorspm-attempt-correct-stop),
			rgba(252, 235, 235, 0.96) 100%
		);
}

.skorspm-student-dashboard__history-item--recent-attempt > * {
	position: relative;
	z-index: 1;
}

.skorspm-student-dashboard__history-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 6px;
}

.skorspm-student-dashboard__history-title {
	display: block;
	color: #0f2f63;
	font-size: 1rem;
	line-height: 1.35;
}

.skorspm-student-dashboard__history-badge {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	padding: 4px 9px;
	border-radius: 999px;
	border: 1px solid var(--sd-student-badge-border);
	background: rgba(255, 255, 255, 0.82);
	color: var(--sd-student-badge-text);
	font-size: 0.74rem;
	font-weight: 700;
	line-height: 1.1;
	white-space: nowrap;
}

.skorspm-subject-dashboard__header-link {
	margin: 0 0 6px;
}

.skorspm-subject-dashboard__header-link a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-weight: 600;
	color: var(--sd-link);
}

.skorspm-subject-dashboard__video-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
}

.skorspm-subject-dashboard__video-player {
	aspect-ratio: 16 / 9;
	background: #0f172a;
	border-radius: 10px;
	overflow: hidden;
	margin-bottom: 10px;
}

.skorspm-subject-dashboard__video-player iframe {
	width: 100%;
	height: 100%;
}

.skorspm-subject-dashboard__video-load {
	width: 100%;
	height: 100%;
	border: 0;
	padding: 0;
	margin: 0;
	cursor: pointer;
	background: #000;
	position: relative;
}

.skorspm-subject-dashboard__video-load img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.skorspm-subject-dashboard__play-icon {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 58px;
	height: 58px;
	border-radius: 50%;
	background: rgba(var(--sd-student-video-overlay-bg-rgb), 0.8);
	color: var(--sd-student-video-overlay-text);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 26px;
	line-height: 1;
}

.skorspm-subject-dashboard__video-load-label {
	position: absolute;
	left: 8px;
	bottom: 8px;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 0.76rem;
	color: var(--sd-student-video-overlay-text);
	background: rgba(var(--sd-student-video-overlay-bg-rgb), 0.76);
}

.skorspm-subject-dashboard .page-numbers {
	margin: 10px 0 0;
	padding-left: 18px;
}

.skorspm-subject-dashboard .page-numbers .current {
	font-weight: 700;
	color: var(--sd-heading);
}

.skorspm-subject-dashboard__pagination {
	margin-top: 12px;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	flex-wrap: wrap;
}

.skorspm-subject-dashboard__pagination-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 12px;
	border-radius: 8px;
	border: 1px solid #c8daf3;
	background: #ffffff;
	color: #1a3765;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none;
}

.skorspm-subject-dashboard__pagination-link:hover,
.skorspm-subject-dashboard__pagination-link:focus-visible {
	background: #f2f7ff;
	border-color: #9db9e7;
	text-decoration: none;
}

.skorspm-subject-dashboard__pagination-link.is-disabled {
	opacity: 0.5;
	pointer-events: none;
}

.skorspm-subject-dashboard__pagination-status {
	font-size: 0.88rem;
	color: #4a6078;
	font-weight: 600;
}

.skorspm-subject-dashboard__pagination-pages {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}

.skorspm-subject-dashboard__pagination-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 34px;
	height: 34px;
	padding: 0 10px;
	border-radius: 8px;
	border: 1px solid #c8daf3;
	background: #ffffff;
	color: #1a3765;
	font-size: 0.88rem;
	font-weight: 600;
	text-decoration: none;
}

.skorspm-subject-dashboard__pagination-number:hover,
.skorspm-subject-dashboard__pagination-number:focus-visible {
	background: #f2f7ff;
	border-color: #9db9e7;
	text-decoration: none;
}

.skorspm-subject-dashboard__pagination-number.is-current {
	background: #eaf3ff;
	border-color: #90b1e4;
	color: #123564;
}

.skorspm-subject-dashboard__pagination-ellipsis {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18px;
	color: #4a6078;
	font-weight: 600;
}

.skorspm-student-dashboard__quiz-form--interactive {
	display: grid;
	gap: 14px;
}

.skorspm-quiz-runtime {
	display: grid;
	gap: 14px;
}

.skorspm-quiz-runtime__status-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
}

.skorspm-quiz-runtime__status-item {
	margin: 0;
	padding: 10px 12px;
	border: 1px solid var(--sd-fq-container-border);
	border-radius: 12px;
	background: var(--sd-fq-container-bg);
}

.skorspm-quiz-runtime__status-item span {
	display: block;
	font-size: var(--sd-fq-subheader-size);
	font-family: var(--sd-fq-subheader-font);
	color: var(--sd-fq-subheader-color);
}

.skorspm-quiz-runtime__status-item strong {
	display: block;
	margin-top: 2px;
	font-size: 1.05rem;
	font-family: var(--sd-fq-header-font);
	color: var(--sd-fq-header-color);
}

.skorspm-quiz-runtime__status-item--avg strong {
	font-variant-numeric: tabular-nums;
}

.skorspm-quiz-runtime__status-item.is-danger {
	border-color: #e28d8d;
	background: linear-gradient(180deg, #fff9f9 0%, #ffecec 100%);
}

.skorspm-quiz-runtime__status-item.is-danger span,
.skorspm-quiz-runtime__status-item strong.is-danger {
	color: #b42318;
}

.skorspm-quiz-runtime__status-item strong.is-danger {
	animation: skorspm-quiz-time-danger-pulse 0.85s ease-in-out infinite;
}

@keyframes skorspm-quiz-time-danger-pulse {
	0%,
	100% {
		opacity: 1;
	}
	50% {
		opacity: 0.64;
	}
}

.skorspm-quiz-runtime__progress {
	display: grid;
	gap: 6px;
}

.skorspm-quiz-runtime__progress-track {
	width: 100%;
	height: 10px;
	border-radius: 999px;
	background: var(--sd-fq-badge-bg);
	border: 1px solid var(--sd-fq-badge-border);
	overflow: hidden;
}

.skorspm-quiz-runtime__progress-fill {
	height: 100%;
	width: 0;
	border-radius: inherit;
	background: linear-gradient(90deg, var(--sd-student-hero-start) 0%, var(--sd-student-hero-end) 100%);
	transition: width 0.24s ease;
}

.skorspm-quiz-runtime__progress-text {
	margin: 0;
	font-size: var(--sd-fq-subheader-size);
	font-family: var(--sd-fq-subheader-font);
	color: var(--sd-fq-subheader-color);
}

.skorspm-quiz-runtime__milestone {
	margin: 2px 0 0;
	padding: 8px 10px;
	border: 1px solid #b7e0d5;
	border-radius: 10px;
	background: linear-gradient(180deg, #f2fff9 0%, #e7faf3 100%);
	color: #0f6a48;
	font-size: 0.9rem;
	font-weight: 700;
}

.skorspm-quiz-runtime__question-block {
	border: 1px solid var(--sd-fq-container-border);
	border-radius: 12px;
	padding: 12px;
	background: var(--sd-fq-container-bg);
}

.skorspm-quiz-runtime__question-order {
	margin: 0 0 6px;
	font-size: var(--sd-fq-subheader-size);
	font-family: var(--sd-fq-subheader-font);
	font-weight: 700;
	color: var(--sd-fq-badge-text);
}

.skorspm-quiz-runtime__question-text {
	margin: 0 0 12px;
	color: var(--sd-fq-header-color);
	font-size: var(--sd-fq-header-size);
	font-family: var(--sd-fq-header-font);
	line-height: 1.35;
	white-space: pre-line;
}

.skorspm-quiz-runtime__question-image {
	margin: 0 0 12px;
	border: 1px solid var(--sd-fq-container-border);
	border-radius: 10px;
	padding: 8px;
	background: var(--sd-fq-container-bg);
}

.skorspm-quiz-runtime__question-image img {
	display: block;
	width: 100%;
	height: auto;
	max-height: 420px;
	object-fit: contain;
	border-radius: 6px;
}

.skorspm-quiz-runtime__question-image:not([hidden]) + .skorspm-quiz-runtime__answer-grid {
	margin-top: 12px;
}

.skorspm-quiz-runtime__answer-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px;
}

.skorspm-quiz-runtime__answer-btn {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	width: 100%;
	text-align: left;
	border: 1px solid var(--sd-fq-container-border);
	border-radius: 12px;
	padding: 10px 12px;
	background: var(--sd-fq-container-bg);
	color: var(--sd-fq-header-color);
	font-weight: 600;
	font-family: var(--sd-fq-subheader-font);
	cursor: pointer;
	transition: transform 0.14s ease, box-shadow 0.14s ease, border-color 0.14s ease;
}

.skorspm-quiz-runtime__answer-btn:hover,
.skorspm-quiz-runtime__answer-btn:focus {
	transform: translateY(-1px);
	border-color: var(--sd-fq-button-hover-border);
	box-shadow: 0 6px 16px rgba(var(--sd-fq-button-shadow-rgb), 0.16);
}

.skorspm-quiz-runtime__answer-btn:disabled {
	cursor: default;
	box-shadow: none;
	transform: none;
}

.skorspm-quiz-runtime__answer-btn.is-selected {
	border-color: #6f95d8;
}

.skorspm-quiz-runtime__answer-btn.is-correct {
	border-color: #00a28a;
	background: linear-gradient(180deg, #f2fffb 0%, #e4fbf5 100%);
}

.skorspm-quiz-runtime__answer-btn.is-wrong {
	border-color: #da5e5e;
	background: linear-gradient(180deg, #fff8f8 0%, #ffefef 100%);
}

.skorspm-quiz-runtime__answer-key {
	display: inline-flex;
	width: 24px;
	height: 24px;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: var(--sd-fq-badge-bg);
	color: var(--sd-fq-badge-text);
	border: 1px solid var(--sd-fq-badge-border);
	font-size: 0.82rem;
	font-weight: 700;
	flex: 0 0 auto;
}

.skorspm-quiz-runtime__answer-text {
	display: block;
	line-height: 1.4;
	white-space: pre-line;
}

.skorspm-quiz-runtime__feedback {
	margin: 10px 0 0;
	font-size: 0.95rem;
	font-weight: 700;
}

.skorspm-quiz-runtime__feedback.is-success {
	color: #0a7b50;
}

.skorspm-quiz-runtime__feedback.is-error {
	color: #992f2f;
}

.skorspm-quiz-runtime__explanation {
	margin-top: 8px;
	padding: 10px 12px;
	border: 1px solid var(--sd-fq-container-border);
	border-radius: 10px;
	background: var(--sd-fq-badge-bg);
	color: var(--sd-fq-subheader-color);
	font-size: var(--sd-fq-subheader-size);
	font-family: var(--sd-fq-subheader-font);
	line-height: 1.45;
	white-space: pre-line;
}

.skorspm-quiz-runtime__actions {
	margin-top: 10px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.skorspm-quiz-runtime__action-btn,
.skorspm-quiz-runtime__submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 10px;
	border: 1px solid var(--sd-fq-button-border);
	background: var(--sd-fq-button-bg);
	color: var(--sd-fq-button-text);
	font-weight: 700;
	font-size: var(--sd-fq-subheader-size);
	font-family: var(--sd-fq-subheader-font);
	padding: 8px 14px;
	cursor: pointer;
	transition: transform 0.14s ease, box-shadow 0.14s ease, background 0.14s ease, border-color 0.14s ease;
}

.skorspm-quiz-runtime__action-btn:hover,
.skorspm-quiz-runtime__action-btn:focus,
.skorspm-quiz-runtime__submit:hover,
.skorspm-quiz-runtime__submit:focus {
	background: var(--sd-fq-button-hover-bg);
	border-color: var(--sd-fq-button-hover-border);
	color: var(--sd-fq-button-hover-text);
	box-shadow: 0 6px 14px rgba(var(--sd-fq-button-shadow-rgb), 0.18);
	transform: translateY(-1px);
}

.skorspm-quiz-runtime__submit-row {
	margin: 0;
}

.skorspm-quiz-runtime__submit[disabled] {
	opacity: 0.58;
	cursor: not-allowed;
	box-shadow: none;
	transform: none;
}

.skorspm-quiz-runtime__action-btn:disabled {
	opacity: 0.58;
	cursor: not-allowed;
	box-shadow: none;
	transform: none;
}

.skorspm-quiz-runtime__completion {
	border: 1px solid var(--sd-fq-container-border);
	border-radius: 12px;
	padding: 12px;
	background: var(--sd-fq-container-bg);
	color: var(--sd-fq-subheader-color);
}

.skorspm-quiz-runtime__completion p {
	margin: 0;
}

.skorspm-quiz-result-review {
	margin-top: 14px;
	padding-top: 12px;
	border-top: 1px solid #d6e4f8;
}

.skorspm-quiz-result-improvement {
	margin-top: 14px;
	padding: 12px;
	border: 1px solid #c8dcfa;
	border-radius: 12px;
	background: linear-gradient(180deg, #ffffff 0%, #f4f9ff 100%);
}

.skorspm-quiz-result-improvement h3 {
	margin: 0 0 8px;
	color: #0f2f63;
	font-size: 1.04rem;
}

.skorspm-quiz-result-improvement p {
	margin: 0 0 6px;
	color: #2c4764;
	line-height: 1.4;
}

.skorspm-quiz-result-improvement p:last-child {
	margin-bottom: 0;
}

.skorspm-quiz-result-review h3 {
	margin: 0 0 10px;
	color: #0f2f63;
	font-size: 1.08rem;
}

.skorspm-quiz-result-review__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 10px;
}

.skorspm-quiz-result-review__item {
	border: 1px solid #ccdef8;
	border-radius: 12px;
	padding: 12px;
	background: #ffffff;
}

.skorspm-quiz-result-review__item.is-correct {
	border-color: #a8dccf;
	background: linear-gradient(180deg, #ffffff 0%, #f2fff9 100%);
}

.skorspm-quiz-result-review__item.is-wrong {
	border-color: #eabcbc;
	background: linear-gradient(180deg, #ffffff 0%, #fff6f6 100%);
}

.skorspm-quiz-result-review__item p {
	margin: 0 0 6px;
	color: #2c4764;
	line-height: 1.45;
}

.skorspm-quiz-result-review__item p:last-child {
	margin-bottom: 0;
}

.skorspm-quiz-result-review__question {
	font-weight: 700;
	color: #123261;
	white-space: pre-line;
}

.skorspm-quiz-result-review__status {
	display: inline-flex;
	align-items: center;
	padding: 2px 10px;
	border-radius: 999px;
	font-size: 0.82rem;
	font-weight: 700;
	border: 1px solid #bfd4f5;
	background: #edf4ff;
	color: #15457f;
}

.skorspm-quiz-result-review__status.is-correct {
	border-color: #8ad0b8;
	background: #e9fff7;
	color: #0f6a48;
}

.skorspm-quiz-result-review__status.is-wrong {
	border-color: #e8a8a8;
	background: #fff0f0;
	color: #8b1f1f;
}

.skorspm-quiz-result-review__explanation {
	margin-top: 8px;
	padding: 10px;
	border-radius: 10px;
	border: 1px solid #d1e1f7;
	background: #f6fbff;
	color: #2e4b6c;
	font-size: 0.92rem;
	line-height: 1.45;
	white-space: pre-line;
}

.skorspm-quiz-result-actions {
	margin-top: 14px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.skorspm-quiz-result-actions .skorspm-student-dashboard__action-link {
	margin-top: 0;
}

.skorspm-quiz-result-actions__print {
	appearance: none;
}

@media print {
	body.skorspm-quiz-print-mode .skorspm-student-dashboard {
		max-width: none;
		margin: 0;
		padding: 0;
		background: #ffffff;
	}

	body.skorspm-quiz-print-mode .skorspm-student-dashboard > :not(.skorspm-quiz-result-card) {
		display: none !important;
	}

	body.skorspm-quiz-print-mode .skorspm-quiz-result-card {
		margin: 0;
		padding: 0;
		background: #ffffff;
		border: 0;
		box-shadow: none;
	}

	body.skorspm-quiz-print-mode .skorspm-quiz-result-actions {
		display: none !important;
	}

	body.skorspm-quiz-print-mode .skorspm-quiz-result-review__item {
		break-inside: avoid;
		page-break-inside: avoid;
	}
}

@media (max-width: 420px) {
	.skorspm-student-dashboard__welcome-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.skorspm-student-dashboard__avatar-row {
		flex-direction: column;
		align-items: flex-start;
	}

	.skorspm-student-dashboard__avatar-thumbnail-wrap {
		order: 2;
		margin-left: auto;
		margin-right: auto;
	}

	.skorspm-student-dashboard__exp-summary {
		order: 1;
		margin-left: auto;
		margin-right: auto;
		width: 100%;
		max-width: 240px;
	}

	.skorspm-student-dashboard__avatar-controls {
		order: 3;
		width: 100%;
	}

	.skorspm-student-dashboard__avatar-controls input[type='file'] {
		max-width: none;
	}

	.skorspm-student-dashboard__avatar-controls button {
		width: 100%;
	}

	.skorspm-student-dashboard__nickname-row {
		flex-direction: column;
		align-items: stretch;
	}

	.skorspm-student-dashboard__nickname-row button {
		width: 100%;
	}

	.skorspm-subject-dashboard__pdf-item {
		align-items: flex-start;
		gap: 10px;
	}

	.skorspm-subject-dashboard__pdf-item .skorspm-subject-dashboard__pdf-title {
		font-size: 0.95rem;
		line-height: 1.35;
		white-space: normal;
		overflow: hidden;
		text-overflow: initial;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
	}

	.skorspm-subject-dashboard__pdf-actions .skorspm-subject-dashboard__icon-action {
		padding: 0;
		width: 34px;
		height: 34px;
		border-radius: 9px;
	}

	.skorspm-subject-dashboard__pdf-actions .skorspm-subject-dashboard__icon-action svg {
		width: 20px;
		height: 20px;
	}

	.skorspm-subject-dashboard__video-toolbar {
		align-items: flex-start;
	}

	.skorspm-subject-dashboard__video-search-form {
		width: 100%;
		margin-left: 0;
		padding: 5px;
		gap: 6px;
	}

	.skorspm-subject-dashboard__video-search-input {
		min-width: 0;
		flex: 1 1 auto;
		height: 36px;
		font-size: 0.9rem;
	}

	.skorspm-subject-dashboard__video-search-button {
		height: 36px;
		padding: 0 11px;
		font-size: 0.85rem;
	}

	.skorspm-subject-dashboard__video-row {
		align-items: flex-start;
	}

	.skorspm-subject-dashboard__video-watch-button img {
		height: 40px;
	}

	.skorspm-subject-dashboard__resource-item .skorspm-subject-dashboard__video-title {
		font-size: 14px;
		white-space: normal;
		overflow: visible;
		text-overflow: clip;
		display: block;
		min-width: 0;
		overflow-wrap: anywhere;
		word-break: break-word;
		-webkit-line-clamp: unset;
		-webkit-box-orient: initial;
	}

	.skorspm-subject-dashboard__pagination--video {
		flex-wrap: nowrap;
		justify-content: flex-start;
		gap: 6px;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding-bottom: 2px;
	}

	.skorspm-subject-dashboard__pagination--video::-webkit-scrollbar {
		display: none;
	}

	.skorspm-subject-dashboard__pagination--video .skorspm-subject-dashboard__pagination-link {
		padding: 5px 9px;
		font-size: 0.8rem;
		white-space: nowrap;
	}

	.skorspm-subject-dashboard__pagination--video .skorspm-subject-dashboard__pagination-pages {
		flex-wrap: nowrap;
		gap: 4px;
	}

	.skorspm-subject-dashboard__pagination--video .skorspm-subject-dashboard__pagination-number {
		min-width: 30px;
		height: 30px;
		padding: 0 8px;
		font-size: 0.8rem;
	}

	.skorspm-subject-dashboard__pagination--video .skorspm-subject-dashboard__pagination-ellipsis {
		min-width: 14px;
	}

	.skorspm-video-lightbox {
		padding: 0;
	}

	.skorspm-video-lightbox__dialog {
		width: 100vw;
		height: 100dvh;
		max-height: 100dvh;
		border-radius: 0;
		border: 0;
		padding: 12px;
		display: flex;
		flex-direction: column;
	}

	.skorspm-video-lightbox__close {
		margin: 0 0 8px;
		align-self: flex-end;
	}

	.skorspm-video-lightbox__title {
		font-size: 0.9rem;
		margin-bottom: 8px;
	}

	.skorspm-video-lightbox__frame-wrap {
		aspect-ratio: auto;
		flex: 1 1 auto;
		min-height: 0;
	}
}

@media (min-width: 760px) {
	.skorspm-student-dashboard,
	.skorspm-subject-dashboard {
		padding: 0 5px 18px;
		gap: 18px;
	}

	.skorspm-subject-dashboard__subject-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.skorspm-student-dashboard__progress-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.skorspm-student-dashboard__progress-grid--trends {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.skorspm-student-dashboard__progress-card--top-rank {
		grid-column: 1 / -1;
	}

	.skorspm-subject-dashboard__video-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.skorspm-quiz-runtime__status-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.skorspm-quiz-runtime__answer-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 1024px) {
	.skorspm-student-dashboard__welcome-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.skorspm-student-dashboard__progress-grid--trends {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 2fr);
	}

	.skorspm-student-dashboard__progress-card--top-rank {
		grid-column: auto;
	}

	.skorspm-student-dashboard__progress-grid--summary {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.skorspm-student-dashboard__history-list--recent-attempts {
		display: flex;
		flex-direction: column;
	}
}

@media (max-width: 640px) {
	.skorspm-student-dashboard__history-header {
		flex-direction: column;
		align-items: flex-start;
	}
}

@media (prefers-reduced-motion: reduce) {
	.skorspm-student-dashboard__top-rank-marquee {
		overflow-y: auto;
	}

	.skorspm-student-dashboard__top-rank-track {
		animation: none;
		transform: none;
	}

	.skorspm-student-dashboard__top-rank-list[aria-hidden="true"] {
		display: none;
	}
}
