/**
 * ===================================
 * Orbit LMS — Public Frontend Styles
 * ===================================
 * Table of Contents
 * ===================================
 * 1.0  - Variables
 * 2.0  - Base / Wrap
 * 3.0  - Buttons
 * 4.0  - Course Archive Header & Filters
 * 5.0  - Course Archive Grid
 * 6.0  - Course Cards
 * 7.0  - Single Course Hero
 * 8.0  - Single Course Layout
 * 9.0  - Curriculum List
 * 10.0 - Instructor
 * 11.0 - Enrollment Sidebar Card
 * 12.0 - Student Dashboard
 * 13.0 - Pagination
 * 14.0 - Notice / Empty
 * 15.0 - Responsive
 * 16.0 - Dashboard Tabs & Account Form
 * 16.1 - Quiz Results Table
 * 17.0 - Auth Forms (Login / Register)
 * =================================== */

/* --- 1.0 Variables --- */
/* Variables on :root so they cascade into auth/dashboard wrappers outside .olms-wrap */
:root {
	--olms-primary: #6366f1;
	--olms-primary-dark: #4f46e5;
	--olms-primary-light: #818cf8;
	--olms-primary-50: #eef2ff;
	--olms-success: #10b981;
	--olms-success-light: #d1fae5;
	--olms-warning: #f59e0b;
	--olms-warning-light: #fef3c7;
	--olms-danger: #ef4444;
	--olms-error: #ef4444;
	--olms-gray-50: #f9fafb;
	--olms-gray-100: #f3f4f6;
	--olms-gray-200: #e5e7eb;
	--olms-gray-300: #d1d5db;
	--olms-gray-400: #9ca3af;
	--olms-gray-500: #6b7280;
	--olms-gray-600: #4b5563;
	--olms-gray-700: #374151;
	--olms-gray-800: #1f2937;
	--olms-gray-900: #111827;
	--olms-white: #ffffff;
	--olms-radius: 8px;
	--olms-radius-lg: 12px;
	--olms-shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
	--olms-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
	--olms-shadow-lg: 0 10px 25px -3px rgba(0, 0, 0, 0.1), 0 4px 10px -2px rgba(0, 0, 0, 0.05);
	--olms-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
/* --- /1.0 Variables --- */

/* --- 2.0 Base / Wrap --- */
.olms-wrap {
	font-family: var(--olms-font);
	color: var(--olms-gray-800);
	line-height: 1.6;
	max-width: 1200px;
	margin: 0 auto;
	padding: 2rem 1rem;
	box-sizing: border-box;
}

.olms-wrap *,
.olms-wrap *::before,
.olms-wrap *::after {
	box-sizing: border-box;
}
/* --- /2.0 Base / Wrap --- */

/* --- 3.0 Buttons --- */
.olms-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.625rem 1.25rem;
	font-family: var(--olms-font);
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.5;
	border-radius: var(--olms-radius);
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: background-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.olms-btn--primary {
	background: var(--olms-primary);
	color: var(--olms-white);
}

.olms-btn--primary:hover {
	background: var(--olms-primary-dark);
	transform: translateY(-1px);
	box-shadow: var(--olms-shadow-md);
	color: var(--olms-white);
}

.olms-btn--success {
	background: #16a34a;
	color: var(--olms-white);
}

.olms-btn--success:hover {
	background: #15803d;
	transform: translateY(-1px);
	box-shadow: var(--olms-shadow-md);
	color: var(--olms-white);
}

.olms-btn--sm {
	padding: 0.375rem 0.875rem;
	font-size: 0.8125rem;
}

.olms-btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
}
.olms-dashboard-public__card-actions {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-top: 0.5rem;
}
/* --- 3.1 Certificate Banner (Course Player Sidebar) --- */
.olms-player__certificate-banner {
	background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
	border: 1px solid #bbf7d0;
	border-radius: 8px;
	padding: 1.25rem;
	text-align: center;
	margin-top: 1rem;
}

.olms-player__certificate-icon {
	font-size: 2.5rem;
	margin-bottom: 0.5rem;
}

.olms-player__certificate-heading {
	font-size: 1.125rem;
	font-weight: 700;
	color: #166534;
	margin: 0 0 0.375rem;
}

.olms-player__certificate-text {
	font-size: 0.8125rem;
	color: #15803d;
	margin: 0 0 1rem;
	line-height: 1.4;
}

.olms-player__certificate-btn {
	display: block;
	width: 100%;
	text-align: center;
	padding: 0.625rem 1rem;
	font-size: 0.9375rem;
	font-weight: 600;
}

.olms-player__certificate-verify {
	display: inline-block;
	margin-top: 0.625rem;
	font-size: 0.75rem;
	color: #16a34a;
	text-decoration: none;
}

.olms-player__certificate-verify:hover {
	text-decoration: underline;
}
/* --- /3.1 Certificate Banner --- */

/* --- /3.0 Buttons --- */

/* --- 4.0 Course Archive Header & Filters --- */
.olms-archive__header {
	margin-bottom: 1.5rem;
}

.olms-archive__title {
	font-size: 1.875rem;
	font-weight: 700;
	color: var(--olms-gray-900);
	margin: 0 0 0.25rem;
}

.olms-archive__count {
	font-size: 0.875rem;
	color: var(--olms-gray-500);
	margin: 0;
}

.olms-archive__filters {
	margin-bottom: 2rem;
}

.olms-archive__filter-form {
	display: flex;
	gap: 0.75rem;
	align-items: center;
	flex-wrap: wrap;
	padding: 1rem 1.25rem;
	background: var(--olms-gray-50);
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius-lg);
}

.olms-archive__search-input {
	flex: 1;
	min-width: 200px;
	padding: 0.5rem 0.75rem;
	border: 1px solid var(--olms-gray-200);
	border-radius: 6px;
	font-size: 0.875rem;
	color: var(--olms-gray-800);
	background: var(--olms-white);
}

.olms-archive__search-input:focus {
	outline: none;
	border-color: var(--olms-primary);
	box-shadow: 0 0 0 1px var(--olms-primary-light);
}

.olms-archive__select {
	padding: 0.5rem 0.75rem;
	border: 1px solid var(--olms-gray-200);
	border-radius: 6px;
	font-size: 0.875rem;
	color: var(--olms-gray-800);
	background: var(--olms-white);
	min-width: 140px;
}

.olms-archive__filter-btn {
	padding: 0.5rem 1.25rem;
}

.olms-archive__empty {
	text-align: center;
	padding: 4rem 2rem;
	color: var(--olms-gray-500);
	background: var(--olms-gray-50);
	border-radius: var(--olms-radius-lg);
	border: 2px dashed var(--olms-gray-300);
}
/* --- /4.0 Course Archive Header & Filters --- */

/* --- 5.0 Course Archive Grid --- */
.olms-archive__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}
/* --- /5.0 Course Archive Grid --- */

/* --- 6.0 Course Cards --- */
.olms-course-card {
	background: var(--olms-white);
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius-lg);
	overflow: hidden;
	box-shadow: var(--olms-shadow);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	display: flex;
	flex-direction: column;
}

.olms-course-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--olms-shadow-md);
}

.olms-course-card__thumb {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: linear-gradient(135deg, var(--olms-primary), var(--olms-primary-dark));
}

.olms-course-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.olms-course-card__placeholder {
	width: 100%;
	height: 100%;
}

.olms-course-card__cat-badge {
	position: absolute;
	top: 0.75rem;
	left: 0.75rem;
	padding: 0.125rem 0.625rem;
	background: rgba(0, 0, 0, 0.6);
	color: var(--olms-white);
	font-size: 0.6875rem;
	font-weight: 500;
	border-radius: 999px;
	backdrop-filter: blur(4px);
}

.olms-course-card__diff-badge {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	padding: 0.125rem 0.625rem;
	font-size: 0.6875rem;
	font-weight: 600;
	border-radius: 999px;
}

.olms-course-card__diff-badge--beginner {
	background: var(--olms-success-light);
	color: #059669;
}

.olms-course-card__diff-badge--intermediate {
	background: var(--olms-warning-light);
	color: #d97706;
}

.olms-course-card__diff-badge--advanced {
	background: #fee2e2;
	color: #dc2626;
}

.olms-course-card__body {
	padding: 1rem 1.25rem;
	flex: 1;
}

.olms-course-card__title {
	font-size: 1rem;
	font-weight: 600;
	margin: 0 0 0.25rem;
	line-height: 1.4;
}

.olms-course-card__title a {
	color: var(--olms-gray-900);
	text-decoration: none;
}

.olms-course-card__title a:hover {
	color: var(--olms-primary);
}

.olms-course-card__instructor {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
	margin: 0 0 0.5rem;
}

.olms-course-card__excerpt {
	font-size: 0.8125rem;
	color: var(--olms-gray-600);
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.olms-course-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.75rem 1.25rem;
	border-top: 1px solid var(--olms-gray-200);
	background: var(--olms-gray-50);
}

.olms-course-card__price-free {
	background: var(--olms-success-light);
	color: #059669;
	padding: 0.125rem 0.625rem;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 600;
}

.olms-course-card__price-amount {
	font-size: 1rem;
	font-weight: 700;
	color: var(--olms-gray-900);
}

.olms-course-card__students {
	font-size: 0.75rem;
	color: var(--olms-gray-500);
}
/* --- /6.0 Course Cards --- */

/* --- 7.0 Single Course Hero --- */
.olms-single-course__hero {
	position: relative;
	background-size: cover;
	background-position: center;
	background-color: var(--olms-primary-dark);
	border-radius: var(--olms-radius-lg);
	overflow: hidden;
	margin-bottom: 2rem;
	min-height: 280px;
	display: flex;
	align-items: flex-end;
}

.olms-single-course__hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.2) 100%);
}

.olms-single-course__hero-content {
	position: relative;
	z-index: 1;
	padding: 2.5rem;
	color: var(--olms-white);
	width: 100%;
}

.olms-single-course__badge {
	display: inline-block;
	padding: 0.125rem 0.75rem;
	background: rgba(255, 255, 255, 0.2);
	color: var(--olms-white);
	font-size: 0.75rem;
	font-weight: 500;
	border-radius: 999px;
	margin-bottom: 0.75rem;
	backdrop-filter: blur(4px);
}

.olms-single-course__title {
	font-size: 2rem;
	font-weight: 700;
	margin: 0 0 1rem;
	line-height: 1.2;
}

.olms-single-course__meta {
	display: flex;
	gap: 1.5rem;
	flex-wrap: wrap;
	align-items: center;
	font-size: 0.875rem;
	opacity: 0.9;
}

.olms-single-course__meta-item {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
}

.olms-single-course__avatar {
	border-radius: 999px;
	width: 24px;
	height: 24px;
}
/* --- /7.0 Single Course Hero --- */

/* --- 8.0 Single Course Layout --- */
.olms-single-course__layout {
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: 2rem;
	align-items: start;
}

.olms-single-course__section {
	margin-bottom: 2rem;
}

.olms-single-course__section-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--olms-gray-900);
	margin: 0 0 1rem;
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.olms-single-course__lesson-count {
	font-size: 0.8125rem;
	font-weight: 400;
	color: var(--olms-gray-500);
}

.olms-single-course__description {
	font-size: 0.9375rem;
	line-height: 1.7;
	color: var(--olms-gray-700);
}

.olms-single-course__learn {
	font-size: 0.9375rem;
	color: var(--olms-gray-700);
}
/* --- /8.0 Single Course Layout --- */

/* --- 9.0 Curriculum List --- */
.olms-curriculum__item {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1rem;
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	margin-bottom: 0.5rem;
	background: var(--olms-white);
	transition: background-color 0.15s ease;
}

.olms-curriculum__item:hover {
	background: var(--olms-gray-50);
}

.olms-curriculum__item--locked {
	opacity: 0.7;
}

.olms-curriculum__num {
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--olms-gray-100);
	color: var(--olms-gray-600);
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 600;
	flex-shrink: 0;
}

.olms-curriculum__icon {
	font-size: 0.875rem;
	flex-shrink: 0;
}

.olms-curriculum__info {
	flex: 1;
	min-width: 0;
}

.olms-curriculum__lesson-title {
	display: block;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--olms-gray-800);
}

.olms-curriculum__duration {
	font-size: 0.75rem;
	color: var(--olms-gray-500);
}

.olms-curriculum__lock {
	flex-shrink: 0;
	font-size: 0.875rem;
}

.olms-curriculum__preview-tag {
	font-size: 0.6875rem;
	font-weight: 500;
	color: var(--olms-primary);
	background: var(--olms-primary-50);
	padding: 0.0625rem 0.5rem;
	border-radius: 999px;
}
/* --- /9.0 Curriculum List --- */

/* --- 10.0 Instructor --- */
.olms-instructor {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
}

.olms-instructor__avatar {
	border-radius: 999px;
	width: 64px;
	height: 64px;
	flex-shrink: 0;
}

.olms-instructor__name {
	font-size: 1rem;
	font-weight: 600;
	color: var(--olms-gray-900);
	margin: 0 0 0.25rem;
}

.olms-instructor__bio {
	font-size: 0.875rem;
	color: var(--olms-gray-600);
	margin: 0;
}
/* --- /10.0 Instructor --- */

/* --- 11.0 Enrollment Sidebar Card --- */
.olms-enroll-card {
	background: var(--olms-white);
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius-lg);
	box-shadow: var(--olms-shadow);
	padding: 1.5rem;
	position: sticky;
	top: 5rem;
}

.olms-enroll-card__price {
	text-align: center;
	margin-bottom: 1.25rem;
}

.olms-enroll-card__price-free {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--olms-success);
}

.olms-enroll-card__price-current {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--olms-gray-900);
}

.olms-enroll-card__price-original {
	font-size: 1rem;
	color: var(--olms-gray-400);
	text-decoration: line-through;
	margin-right: 0.5rem;
}

.olms-enroll-card__btn {
	width: 100%;
	padding: 0.75rem 1.5rem;
	font-size: 1rem;
	font-weight: 600;
	margin-bottom: 1.25rem;
}

.olms-enroll-card__note {
	margin: -0.5rem 0 1.25rem;
	font-size: 0.8125rem;
	color: var(--olms-gray-600);
	line-height: 1.5;
	text-align: center;
}

.olms-enroll-card__includes {
	list-style: none;
	padding: 0;
	margin: 0;
}

.olms-enroll-card__includes li {
	padding: 0.5rem 0;
	font-size: 0.8125rem;
	color: var(--olms-gray-600);
	border-bottom: 1px solid var(--olms-gray-100);
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.olms-enroll-card__includes li::before {
	content: "\2713";
	color: var(--olms-success);
	font-weight: 700;
	font-size: 0.75rem;
}

.olms-enroll-card__includes li:last-child {
	border-bottom: none;
}
/* --- /11.0 Enrollment Sidebar Card --- */

/* --- 12.0 Student Dashboard --- */
.olms-dashboard-public__title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--olms-gray-900);
	margin: 0 0 1.5rem;
}

.olms-dashboard-public__empty {
	text-align: center;
	padding: 3rem 2rem;
	background: var(--olms-gray-50);
	border-radius: var(--olms-radius-lg);
	border: 2px dashed var(--olms-gray-300);
}

.olms-dashboard-public__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

.olms-dashboard-public__card {
	background: var(--olms-white);
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius-lg);
	overflow: hidden;
	box-shadow: var(--olms-shadow);
}

.olms-dashboard-public__thumb {
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

.olms-dashboard-public__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.olms-dashboard-public__card-body {
	padding: 1rem 1.25rem;
}

.olms-dashboard-public__card-title {
	font-size: 0.9375rem;
	font-weight: 600;
	margin: 0 0 0.75rem;
}

.olms-dashboard-public__card-title a {
	color: var(--olms-gray-900);
	text-decoration: none;
}

.olms-dashboard-public__progress {
	margin-bottom: 0.75rem;
}

.olms-dashboard-public__progress-bar {
	height: 6px;
	background: var(--olms-gray-200);
	border-radius: 999px;
	overflow: hidden;
	margin-bottom: 0.25rem;
}

.olms-dashboard-public__progress-fill {
	height: 100%;
	background: var(--olms-primary);
	border-radius: 999px;
	transition: width 0.3s ease;
}

.olms-dashboard-public__progress-text {
	font-size: 0.75rem;
	color: var(--olms-gray-500);
}
/* --- /12.0 Student Dashboard --- */

/* --- 13.0 Pagination --- */
.olms-archive__pagination {
	margin-top: 2rem;
	text-align: center;
}

.olms-archive__pagination ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: inline-flex;
	gap: 0.25rem;
}

.olms-archive__pagination li {
	display: inline-block;
}

.olms-archive__pagination a,
.olms-archive__pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 0.5rem;
	border: 1px solid var(--olms-gray-200);
	border-radius: 6px;
	font-size: 0.875rem;
	color: var(--olms-gray-700);
	text-decoration: none;
	transition: all 0.15s ease;
}

.olms-archive__pagination a:hover {
	background: var(--olms-gray-50);
	border-color: var(--olms-gray-300);
}

.olms-archive__pagination .current {
	background: var(--olms-primary);
	border-color: var(--olms-primary);
	color: var(--olms-white);
}
/* --- /13.0 Pagination --- */

/* --- 14.0 Notice / Empty --- */
.olms-notice {
	text-align: center;
	padding: 3rem 2rem;
	background: var(--olms-gray-50);
	border-radius: var(--olms-radius-lg);
	border: 1px solid var(--olms-gray-200);
}
/* --- /14.0 Notice / Empty --- */

/* --- 15.0 Course Player --- */
.olms-player {
	display: grid;
	grid-template-columns: 1fr 340px;
	gap: 0;
	padding: 0;
	max-width: 100%;
}

.olms-player__main {
	padding: 2rem;
	min-width: 0;
}

.olms-player__topbar {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--olms-gray-200);
}

.olms-player__back {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
	text-decoration: none;
	transition: color 0.15s ease;
	white-space: nowrap;
}

.olms-player__back:hover {
	color: var(--olms-primary);
}

.olms-player__breadcrumb {
	font-size: 0.8125rem;
	color: var(--olms-gray-400);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.olms-player__lesson-header {
	margin-bottom: 2rem;
}

.olms-player__lesson-title {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--olms-gray-900);
	margin: 0 0 0.75rem;
	line-height: 1.25;
}

.olms-player__lesson-meta {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.olms-player__type-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0.125rem 0.625rem;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 500;
}

.olms-player__type-badge--text {
	background: var(--olms-gray-100);
	color: var(--olms-gray-600);
}

.olms-player__type-badge--video {
	background: #dbeafe;
	color: #2563eb;
}

.olms-player__type-badge--audio {
	background: #e0e7ff;
	color: #4338ca;
}

.olms-player__type-badge--document {
	background: var(--olms-warning-light);
	color: #d97706;
}

.olms-player__duration {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
}

.olms-player__position {
	font-size: 0.8125rem;
	color: var(--olms-gray-400);
}

/* Video embed */
.olms-player__video {
	margin-bottom: 2rem;
}

.olms-player__video-wrap {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	border-radius: var(--olms-radius-lg);
	background: var(--olms-gray-900);
}

.olms-player__video-wrap iframe,
.olms-player__video-wrap video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

/* Content text */
.olms-player__text {
	font-size: 0.9375rem;
	line-height: 1.8;
	color: var(--olms-gray-700);
}

.olms-player__text h2,
.olms-player__text h3 {
	color: var(--olms-gray-900);
	margin: 1.5rem 0 0.75rem;
}

.olms-player__text p {
	margin: 0 0 1rem;
}

.olms-player__text pre {
	background: var(--olms-gray-50);
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	padding: 1rem;
	overflow-x: auto;
	font-size: 0.8125rem;
}

/* Bottom navigation */
.olms-player__nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 2.5rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--olms-gray-200);
}

.olms-player__nav-btn {
	padding: 0.5rem 1rem;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--olms-gray-600);
	text-decoration: none;
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	background: var(--olms-white);
	transition: all 0.15s ease;
	white-space: nowrap;
}

.olms-player__nav-btn:hover {
	border-color: var(--olms-gray-300);
	background: var(--olms-gray-50);
	color: var(--olms-gray-800);
}

.olms-player__nav-btn--disabled {
	opacity: 0.4;
	pointer-events: none;
	cursor: default;
}

.olms-player__complete-btn {
	padding: 0.625rem 1.5rem;
	font-size: 0.9375rem;
}

.olms-player__complete-btn--done {
	background: var(--olms-success);
	border-color: var(--olms-success);
	opacity: 0.8;
}

.olms-player__complete-btn--locked {
	opacity: 0.6;
	cursor: not-allowed;
}

.olms-player__preview-notice {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
	font-weight: 500;
	padding: 0.5rem 1rem;
	background: var(--olms-gray-100);
	border-radius: var(--olms-radius);
}

/* Sidebar */
.olms-player__sidebar {
	background: var(--olms-gray-50);
	border-left: 1px solid var(--olms-gray-200);
	padding: 1.5rem;
	position: sticky;
	top: 0;
	max-height: 100vh;
	overflow-y: auto;
}

.olms-player__progress {
	margin-bottom: 1.5rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--olms-gray-200);
}

.olms-player__progress-bar {
	height: 8px;
	background: var(--olms-gray-200);
	border-radius: 999px;
	overflow: hidden;
	margin-bottom: 0.5rem;
}

.olms-player__progress-fill {
	height: 100%;
	background: var(--olms-primary);
	border-radius: 999px;
	transition: width 0.5s ease;
}

.olms-player__progress-text {
	font-size: 0.75rem;
	color: var(--olms-gray-500);
	font-weight: 500;
}

.olms-player__curriculum-title {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--olms-gray-800);
	margin: 0 0 0.75rem;
}

.olms-player__lesson-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.olms-player__lesson-item {
	border-radius: var(--olms-radius);
	margin-bottom: 0.25rem;
	transition: background-color 0.15s ease;
}

.olms-player__lesson-item--current {
	background: var(--olms-primary-50);
}

.olms-player__lesson-link {
	display: flex;
	align-items: center;
	gap: 0.625rem;
	padding: 0.625rem 0.75rem;
	text-decoration: none;
	color: var(--olms-gray-700);
	border-radius: var(--olms-radius);
	transition: background-color 0.1s ease;
}

a.olms-player__lesson-link:hover {
	background: var(--olms-gray-100);
}

.olms-player__lesson-link--locked {
	opacity: 0.5;
	cursor: default;
}

.olms-player__lesson-item--current .olms-player__lesson-link {
	color: var(--olms-primary-dark);
	font-weight: 500;
}

.olms-player__lesson-num {
	width: 24px;
	height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--olms-gray-200);
	color: var(--olms-gray-600);
	border-radius: 999px;
	font-size: 0.6875rem;
	font-weight: 600;
	flex-shrink: 0;
}

.olms-player__lesson-item--current .olms-player__lesson-num {
	background: var(--olms-primary);
	color: var(--olms-white);
}

.olms-player__lesson-item--completed .olms-player__lesson-num {
	background: var(--olms-success-light);
	color: #059669;
}

.olms-player__lesson-item--quiz .olms-player__lesson-num {
	background: #ede9fe;
	color: #6d28d9;
	font-size: 14px;
}

.olms-player__lesson-item--quiz.olms-player__lesson-item--completed .olms-player__lesson-num {
	background: var(--olms-success-light);
	color: #059669;
}

.olms-player__status-icon--attempted {
	color: #d97706;
}

.olms-player__lesson-info {
	flex: 1;
	min-width: 0;
}

.olms-player__lesson-name {
	display: block;
	font-size: 0.8125rem;
	line-height: 1.3;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.olms-player__lesson-dur {
	display: block;
	font-size: 0.6875rem;
	color: var(--olms-gray-400);
	margin-top: 1px;
}

.olms-player__lesson-status {
	flex-shrink: 0;
}

.olms-player__status-icon {
	font-size: 0.75rem;
}

.olms-player__status-icon--done {
	color: #059669;
	font-weight: 700;
}

.olms-player__status-icon--playing {
	color: var(--olms-primary);
}

.olms-player__status-icon--locked {
	font-size: 0.625rem;
}
.olms-player__quiz-cta {
	margin-top: 2rem;
	padding: 1.25rem;
	background: var(--olms-primary-50);
	border: 1px solid var(--olms-primary-light);
	border-radius: var(--olms-radius-lg);
	text-align: center;
}

.olms-player__quiz-cta .olms-btn {
	font-size: 1rem;
	padding: 0.75rem 2rem;
}

.olms-curriculum__lesson-title--link {
	color: var(--olms-gray-800);
	text-decoration: none;
	transition: color 0.15s ease;
}

.olms-curriculum__lesson-title--link:hover {
	color: var(--olms-primary);
}
/* --- /15.0 Course Player --- */

/* --- 16.0 Quiz Player --- */
.olms-quiz {
	max-width: 800px;
	margin: 0 auto;
}

/* Start screen */
.olms-quiz__back-link {
	display: inline-block;
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
	text-decoration: none;
	margin-bottom: 1rem;
}

.olms-quiz__back-link:hover {
	color: var(--olms-primary);
}

.olms-quiz__title {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--olms-gray-900);
	margin: 0 0 1rem;
}

.olms-quiz__instructions {
	font-size: 0.9375rem;
	color: var(--olms-gray-600);
	margin-bottom: 2rem;
	line-height: 1.7;
}

.olms-quiz__info-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: 1rem;
	margin-bottom: 2rem;
}

.olms-quiz__info-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 1rem;
	background: var(--olms-gray-50);
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	text-align: center;
}

.olms-quiz__info-value {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--olms-gray-900);
}

.olms-quiz__info-label {
	font-size: 0.75rem;
	color: var(--olms-gray-500);
	margin-top: 0.25rem;
}

.olms-quiz__start-btn {
	padding: 0.875rem 2.5rem;
	font-size: 1rem;
	font-weight: 600;
}

.olms-quiz__max-reached {
	padding: 1rem 1.5rem;
	background: #fee2e2;
	border-radius: var(--olms-radius);
	color: #dc2626;
	font-size: 0.875rem;
}

/* Active quiz header */
.olms-quiz__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1rem 0;
	margin-bottom: 1.5rem;
	border-bottom: 1px solid var(--olms-gray-200);
	flex-wrap: wrap;
}

.olms-quiz__header-title {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--olms-gray-700);
}

.olms-quiz__counter {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
}

.olms-quiz__timer {
	font-size: 1rem;
	font-weight: 700;
	color: var(--olms-gray-800);
	background: var(--olms-gray-100);
	padding: 0.25rem 0.75rem;
	border-radius: var(--olms-radius);
	font-variant-numeric: tabular-nums;
}

.olms-quiz__timer--warning {
	background: #fee2e2;
	color: #dc2626;
}

/* Question */
.olms-quiz__q-num {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--olms-gray-400);
	margin-bottom: 0.5rem;
}

.olms-quiz__q-text {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--olms-gray-900);
	margin-bottom: 1.5rem;
	line-height: 1.5;
}

.olms-quiz__q-hint {
	margin-top: 1rem;
	padding: 0.75rem 1rem;
	background: var(--olms-warning-light);
	border-radius: var(--olms-radius);
	font-size: 0.8125rem;
	color: #92400e;
}

/* MCQ options */
.olms-quiz__options {
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

.olms-quiz__option-card {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	width: 100%;
	padding: 0.875rem 1rem;
	border: 2px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	background: var(--olms-white);
	cursor: pointer;
	text-align: left;
	font-size: 0.9375rem;
	color: var(--olms-gray-700);
	transition: border-color 0.15s ease, background-color 0.15s ease;
}

.olms-quiz__option-card:hover {
	border-color: var(--olms-primary-light);
	background: var(--olms-primary-50);
}

.olms-quiz__option-card--selected {
	border-color: var(--olms-primary);
	background: var(--olms-primary-50);
	color: var(--olms-primary-dark);
}

.olms-quiz__option-letter {
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: var(--olms-gray-100);
	color: var(--olms-gray-600);
	font-size: 0.75rem;
	font-weight: 700;
	flex-shrink: 0;
}

.olms-quiz__option-card--selected .olms-quiz__option-letter {
	background: var(--olms-primary);
	color: var(--olms-white);
}

.olms-quiz__option-text {
	flex: 1;
}

/* True/False */
.olms-quiz__tf-options {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

.olms-quiz__tf-btn {
	padding: 1.25rem;
	border: 2px solid var(--olms-gray-200);
	border-radius: var(--olms-radius-lg);
	background: var(--olms-white);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--olms-gray-600);
	cursor: pointer;
	text-align: center;
	transition: all 0.15s ease;
}

.olms-quiz__tf-btn:hover {
	border-color: var(--olms-primary-light);
}

.olms-quiz__tf-btn--selected {
	border-color: var(--olms-primary);
	background: var(--olms-primary-50);
	color: var(--olms-primary-dark);
}

/* Fill blank */
.olms-quiz__fill-area {
	max-width: 500px;
}

.olms-quiz__fill-input {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 2px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	font-size: 1rem;
	color: var(--olms-gray-800);
	background: var(--olms-white);
}

.olms-quiz__fill-input:focus {
	outline: none;
	border-color: var(--olms-primary);
	box-shadow: 0 0 0 1px var(--olms-primary-light);
}

.olms-quiz__q-text--fill {
	line-height: 2.2;
}

.olms-quiz__fill-inline {
	display: inline-block;
	min-width: 140px;
	margin: 0 4px;
	padding: 4px 10px;
	border: none;
	border-bottom: 2px solid var(--olms-primary);
	background: transparent;
	font: inherit;
	color: var(--olms-primary);
	text-align: center;
}

.olms-quiz__fill-inline:focus {
	outline: none;
	border-bottom-color: var(--olms-primary-dark, var(--olms-primary));
	background: var(--olms-primary-light, rgba(99, 102, 241, 0.08));
}

/* Matching */
.olms-quiz__matching-area {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.olms-quiz__matching-hint {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
	margin: 0 0 0.5rem;
}

.olms-quiz__match-pair {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.olms-quiz__match-term {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--olms-gray-700);
	min-width: 80px;
}

.olms-quiz__match-select {
	flex: 1;
	padding: 0.5rem 0.75rem;
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	font-size: 0.875rem;
	background: var(--olms-white);
}

/* Navigation bar */
.olms-quiz__nav-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--olms-gray-200);
}

.olms-quiz__nav-btn {
	padding: 0.5rem 1rem;
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	background: var(--olms-white);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--olms-gray-600);
	cursor: pointer;
	transition: all 0.15s ease;
}

.olms-quiz__nav-btn:hover:not(:disabled) {
	background: var(--olms-gray-50);
	border-color: var(--olms-gray-300);
}

.olms-quiz__nav-btn:disabled {
	opacity: 0.4;
	cursor: default;
}

/* Dots */
.olms-quiz__dots {
	display: flex;
	gap: 0.375rem;
	flex-wrap: wrap;
	justify-content: center;
}

.olms-quiz__dot {
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--olms-gray-200);
	border-radius: 999px;
	background: var(--olms-white);
	font-size: 0.6875rem;
	font-weight: 500;
	color: var(--olms-gray-500);
	cursor: pointer;
	transition: all 0.15s ease;
}

.olms-quiz__dot--current {
	border-color: var(--olms-primary);
	color: var(--olms-primary);
	box-shadow: 0 0 0 2px var(--olms-primary-50);
}

.olms-quiz__dot--answered {
	background: var(--olms-primary);
	border-color: var(--olms-primary);
	color: var(--olms-white);
}

/* Submit */
.olms-quiz__submit-area {
	text-align: center;
	margin-top: 1.5rem;
}

.olms-quiz__submit-btn {
	padding: 0.75rem 2rem;
	font-size: 1rem;
}

/* Results */
.olms-quiz__results {
	text-align: center;
}

.olms-quiz__score-area {
	margin-bottom: 2rem;
}

.olms-quiz__score-circle {
	width: 160px;
	height: 160px;
	border-radius: 50%;
	background: conic-gradient( var(--olms-primary) calc( var(--score) * 3.6deg ), var(--olms-gray-200) 0 );
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1.5rem;
}

.olms-quiz__score-inner {
	width: 130px;
	height: 130px;
	border-radius: 50%;
	background: var(--olms-white);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.olms-quiz__score-pct {
	font-size: 2rem;
	font-weight: 700;
	color: var(--olms-gray-900);
}

.olms-quiz__score-status--pass {
	font-size: 0.875rem;
	font-weight: 600;
	color: #059669;
}

.olms-quiz__score-status--fail {
	font-size: 0.875rem;
	font-weight: 600;
	color: #dc2626;
}

.olms-quiz__result-stats {
	display: flex;
	justify-content: center;
	gap: 2rem;
	margin-bottom: 2rem;
}

.olms-quiz__result-stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.25rem;
}

.olms-quiz__result-stat strong {
	font-size: 1.125rem;
	color: var(--olms-gray-900);
}

.olms-quiz__result-stat span {
	font-size: 0.75rem;
	color: var(--olms-gray-500);
}

.olms-quiz__results-actions {
	display: flex;
	gap: 0.75rem;
	justify-content: center;
	margin-top: 2rem;
}

/* Review */
.olms-quiz__review {
	text-align: left;
	margin-top: 2rem;
}

.olms-quiz__review-title {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--olms-gray-900);
	margin: 0 0 1rem;
}

.olms-quiz__review-item {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 1rem;
	border: 1px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	margin-bottom: 0.5rem;
	border-left: 3px solid var(--olms-gray-300);
}

.olms-quiz__review-item--correct {
	border-left-color: #059669;
}

.olms-quiz__review-item--wrong {
	border-left-color: #dc2626;
}

.olms-quiz__review-indicator {
	width: 24px;
	height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 700;
	flex-shrink: 0;
}

.olms-quiz__review-item--correct .olms-quiz__review-indicator {
	background: var(--olms-success-light);
	color: #059669;
}

.olms-quiz__review-item--wrong .olms-quiz__review-indicator {
	background: #fee2e2;
	color: #dc2626;
}

.olms-quiz__review-content {
	flex: 1;
	min-width: 0;
}

.olms-quiz__review-q {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--olms-gray-800);
	margin: 0 0 0.5rem;
}

.olms-quiz__review-answer {
	font-size: 0.8125rem;
	color: var(--olms-gray-600);
	margin: 0 0 0.25rem;
}

.olms-quiz__review-correct {
	font-size: 0.8125rem;
	color: #059669;
	margin: 0 0 0.25rem;
}

.olms-quiz__review-explanation {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
	font-style: italic;
	margin: 0.5rem 0 0;
}

.olms-quiz__review-points {
	flex-shrink: 0;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--olms-gray-500);
}
/* --- /16.0 Quiz Player --- */

/* --- 17.0 Responsive --- */
@media (max-width: 1024px) {
	.olms-single-course__layout {
		grid-template-columns: 1fr;
	}

	.olms-enroll-card {
		position: static;
	}

	.olms-player {
		grid-template-columns: 1fr;
	}

	.olms-player__sidebar {
		position: static;
		max-height: none;
		border-left: none;
		border-top: 1px solid var(--olms-gray-200);
	}
}

@media (max-width: 768px) {
	.olms-archive__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.olms-dashboard-public__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.olms-single-course__title {
		font-size: 1.5rem;
	}

	.olms-single-course__hero-content {
		padding: 1.5rem;
	}

	.olms-player__main {
		padding: 1.25rem;
	}

	.olms-player__lesson-title {
		font-size: 1.375rem;
	}

	.olms-player__nav {
		flex-wrap: wrap;
		justify-content: center;
	}

	.olms-player__nav-btn--prev,
	.olms-player__nav-btn--next {
		order: 2;
	}

	.olms-player__complete-btn {
		order: 1;
		width: 100%;
	}
}

@media (max-width: 480px) {
	.olms-archive__grid {
		grid-template-columns: 1fr;
	}

	.olms-dashboard-public__grid {
		grid-template-columns: 1fr;
	}

	.olms-archive__filter-form {
		flex-direction: column;
	}

	.olms-archive__search-input,
	.olms-archive__select {
		width: 100%;
	}

	.olms-single-course__meta {
		flex-direction: column;
		gap: 0.5rem;
	}

	.olms-quiz__info-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.olms-quiz__tf-options {
		grid-template-columns: 1fr;
	}

	.olms-quiz__nav-bar {
		flex-wrap: wrap;
		justify-content: center;
	}

	.olms-quiz__dots {
		order: 3;
		width: 100%;
	}

	.olms-quiz__result-stats {
		flex-direction: column;
		gap: 0.75rem;
	}
}
/* --- /17.0 Responsive --- */

/* --- 16.0 Dashboard Tabs & Account Form --- */

/* ---- Dashboard header ---- */
.olms-dashboard-public__header {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	margin-bottom: 2rem;
	padding: 1.5rem;
	background: linear-gradient(135deg, #eef2ff 0%, #f0fdf4 100%);
	border-radius: var(--olms-radius-lg);
	border: 1px solid var(--olms-gray-200);
}

.olms-dashboard-public__avatar {
	flex-shrink: 0;
}

.olms-dashboard-public__avatar-img {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	display: block;
	border: 3px solid #fff;
	box-shadow: 0 2px 8px rgba(99, 102, 241, 0.2);
}

.olms-dashboard-public__heading {
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--olms-gray-900);
	margin: 0 0 0.3rem;
	line-height: 1.3;
}

.olms-dashboard-public__stats {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
	margin: 0;
}

/* ---- Tab navigation ---- */
.olms-dashboard-public__tabs {
	display: flex;
	border-bottom: 2px solid var(--olms-gray-200);
	margin-bottom: 2rem;
	gap: 0.25rem;
}

.olms-dashboard-public__tab {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.75rem 1.25rem;
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--olms-gray-500);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	border-radius: var(--olms-radius) var(--olms-radius) 0 0;
	transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}

.olms-dashboard-public__tab:hover {
	color: var(--olms-primary);
	background: var(--olms-primary-50);
}

.olms-dashboard-public__tab--active {
	color: var(--olms-primary);
	border-bottom-color: var(--olms-primary);
	font-weight: 600;
	background: var(--olms-primary-50);
}

.olms-dashboard-public__tab-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.25rem;
	height: 1.25rem;
	padding: 0 0.3rem;
	font-size: 0.6875rem;
	font-weight: 700;
	background: var(--olms-primary);
	color: #fff;
	border-radius: 999px;
}

/* ---- Tab panel ---- */
.olms-dashboard-public__panel {
	animation: olmsTabFadeIn 0.18s ease;
}

@keyframes olmsTabFadeIn {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ---- Completed badge ---- */
.olms-dashboard-public__badge {
	display: inline-block;
	padding: 0.2rem 0.6rem;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	border-radius: var(--olms-radius);
	margin-bottom: 0.5rem;
}

.olms-dashboard-public__badge--completed {
	background: #d1fae5;
	color: #065f46;
}

.olms-dashboard-public__completed-date {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
	margin: 0 0 0.75rem;
}

.olms-dashboard-public__progress-fill--complete {
	background: var(--olms-success);
}

/* ---- Inline notices ---- */
.olms-notice {
	display: flex;
	align-items: flex-start;
	gap: 0.625rem;
	padding: 0.875rem 1.125rem;
	border-radius: var(--olms-radius);
	font-size: 0.9375rem;
	margin-bottom: 1.5rem;
	line-height: 1.5;
}

.olms-notice ul {
	margin: 0;
	padding-left: 1.25rem;
}

.olms-notice--success {
	background: #ecfdf5;
	color: #065f46;
	border: 1px solid #6ee7b7;
}

.olms-notice--error {
	background: #fef2f2;
	color: #991b1b;
	border: 1px solid #fca5a5;
}

/* ---- Quiz Results Table ---- */
.olms-quiz-results {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.olms-quiz-results__table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
}

.olms-quiz-results__th {
	text-align: left;
	padding: 0.75rem 1rem;
	font-weight: 600;
	color: var(--olms-text-muted, #64748b);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-bottom: 2px solid var(--olms-border, #e2e8f0);
	white-space: nowrap;
}

.olms-quiz-results__th--center {
	text-align: center;
}

.olms-quiz-results__row {
	transition: background 0.15s ease;
}

.olms-quiz-results__row:hover {
	background: var(--olms-bg-hover, #f8fafc);
}

.olms-quiz-results__td {
	padding: 0.875rem 1rem;
	border-bottom: 1px solid var(--olms-border, #e2e8f0);
	vertical-align: middle;
}

.olms-quiz-results__td--center {
	text-align: center;
}

.olms-quiz-results__quiz-title {
	font-weight: 500;
	color: var(--olms-text, #1e293b);
	display: block;
}

.olms-quiz-results__attempt-num {
	font-size: 0.75rem;
	color: var(--olms-text-muted, #64748b);
	display: block;
	margin-top: 0.125rem;
}

.olms-quiz-results__score {
	font-weight: 700;
	font-size: 0.95rem;
}

.olms-quiz-results__score--pass {
	color: var(--olms-success, #059669);
}

.olms-quiz-results__score--fail {
	color: var(--olms-danger, #dc2626);
}

.olms-quiz-results__badge {
	display: inline-block;
	padding: 0.2rem 0.625rem;
	border-radius: 9999px;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.02em;
}

.olms-quiz-results__badge--pass {
	background: #ecfdf5;
	color: #065f46;
}

.olms-quiz-results__badge--fail {
	background: #fef2f2;
	color: #991b1b;
}

.olms-quiz-results__pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	padding: 1.25rem 0;
}

.olms-quiz-results__page-link {
	color: var(--olms-primary);
	text-decoration: none;
	font-weight: 500;
	font-size: 0.875rem;
}

.olms-quiz-results__page-link:hover {
	text-decoration: underline;
}

.olms-quiz-results__page-info {
	font-size: 0.875rem;
	color: var(--olms-text-muted, #64748b);
}

/* Responsive: stack table on mobile */
@media (max-width: 768px) {
	.olms-quiz-results__table,
	.olms-quiz-results__table thead,
	.olms-quiz-results__table tbody,
	.olms-quiz-results__table tr,
	.olms-quiz-results__table th,
	.olms-quiz-results__table td {
		display: block;
	}

	.olms-quiz-results__table thead {
		position: absolute;
		width: 1px;
		height: 1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
	}

	.olms-quiz-results__row {
		margin-bottom: 1rem;
		border: 1px solid var(--olms-border, #e2e8f0);
		border-radius: 0.5rem;
		padding: 0.5rem 0;
	}

	.olms-quiz-results__td {
		padding: 0.5rem 1rem;
		border-bottom: none;
		text-align: right;
	}

	.olms-quiz-results__td--center {
		text-align: right;
	}

	.olms-quiz-results__td::before {
		content: attr(data-label);
		float: left;
		font-weight: 600;
		color: var(--olms-text-muted, #64748b);
		font-size: 0.8rem;
		text-transform: uppercase;
	}
}
/* --- /Quiz Results Table --- */

/* ---- Account form ---- */
.olms-account-form {
	max-width: 580px;
}

.olms-account-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
	margin-bottom: 0;
}

.olms-account-form__group {
	margin-bottom: 1.25rem;
}

.olms-account-form__label {
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--olms-gray-700);
	margin-bottom: 0.4rem;
}

.olms-account-form__required {
	color: var(--olms-error);
	margin-left: 0.15em;
}

.olms-account-form__input {
	width: 100%;
	padding: 0.625rem 0.875rem;
	font-size: 0.9375rem;
	font-family: var(--olms-font);
	border: 1.5px solid var(--olms-gray-300);
	border-radius: var(--olms-radius);
	color: var(--olms-gray-900);
	background: #fff;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	box-sizing: border-box;
	appearance: none;
}

.olms-account-form__input:hover {
	border-color: var(--olms-gray-400);
}

.olms-account-form__input:focus {
	outline: none;
	border-color: var(--olms-primary);
	box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}

.olms-account-form__section-heading {
	font-size: 1rem;
	font-weight: 700;
	color: var(--olms-gray-900);
	padding-top: 1.25rem;
	margin: 0.25rem 0 0.25rem;
	border-top: 1px solid var(--olms-gray-200);
}

.olms-account-form__hint {
	font-size: 0.8125rem;
	color: var(--olms-gray-500);
	display: block;
	margin: 0.3rem 0 0.75rem;
}

@media (max-width: 600px) {
	.olms-dashboard-public__header {
		flex-direction: column;
		text-align: center;
	}

	.olms-dashboard-public__tabs {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	.olms-dashboard-public__tab {
		white-space: nowrap;
		padding: 0.625rem 1rem;
		font-size: 0.875rem;
	}

	.olms-account-form__row {
		grid-template-columns: 1fr;
	}
}
/* --- /16.0 Dashboard Tabs & Account Form --- */

/* --- 17.0 Auth Forms (Login / Register) --- */

/* ---- Page-level wrapper: subtle gradient bg ---- */
.olms-auth-wrap {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	min-height: 60vh;
	padding: 3rem 1.25rem 4rem;
	font-family: var(--olms-font);
	background: linear-gradient(160deg, #f0f4ff 0%, #f8fafc 60%, #f0fdf4 100%);
}

/* ---- Card ---- */
.olms-auth-box {
	width: 100%;
	max-width: 460px;
	background: #fff;
	border: 1px solid var(--olms-gray-200);
	border-radius: 16px;
	padding: 2.5rem 2.5rem 2rem;
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.07), 0 10px 30px -5px rgba(99, 102, 241, 0.1);
}

/* ---- Heading with accent bar ---- */
.olms-auth-box__heading {
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--olms-gray-900);
	text-align: center;
	margin: 0 0 1.75rem;
	letter-spacing: -0.02em;
}

.olms-auth-box__heading::after {
	content: "";
	display: block;
	width: 2.5rem;
	height: 3px;
	background: linear-gradient(90deg, var(--olms-primary), var(--olms-primary-light));
	border-radius: 999px;
	margin: 0.5rem auto 0;
}

/* ---- Form groups ---- */
.olms-auth-form__group {
	margin-bottom: 1.25rem;
}

.olms-auth-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.875rem;
	margin-bottom: 1.25rem;
}

/* Remove double margin when a group directly follows a row */
.olms-auth-form__row > .olms-auth-form__group {
	margin-bottom: 0;
}

.olms-auth-form__row--inline {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 1.5rem;
}

/* ---- Labels ---- */
.olms-auth-form__label {
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--olms-gray-700);
	margin-bottom: 0.4rem;
	letter-spacing: 0.01em;
}

.olms-auth-form__required {
	color: var(--olms-error);
	margin-left: 0.15em;
}

/* ---- Input wrapper (for password toggle) ---- */
.olms-auth-form__input-wrap {
	position: relative;
	display: block;
}

/* ---- Inputs ---- */
.olms-auth-form__input {
	width: 100%;
	padding: 0.6875rem 1rem;
	font-size: 0.9375rem;
	font-family: var(--olms-font);
	color: var(--olms-gray-900);
	background: var(--olms-gray-50);
	border: 1.5px solid var(--olms-gray-200);
	border-radius: var(--olms-radius);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
	transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
	box-sizing: border-box;
	appearance: none;
	-webkit-appearance: none;
}

.olms-auth-form__input::placeholder {
	color: var(--olms-gray-400);
}

.olms-auth-form__input:hover {
	background: #fff;
	border-color: var(--olms-gray-300);
}

.olms-auth-form__input:focus {
	outline: none;
	background: #fff;
	border-color: var(--olms-primary);
	box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}

.olms-auth-form__input-wrap .olms-auth-form__input {
	padding-right: 2.875rem;
}

/* ---- Password toggle button ---- */
.olms-auth-form__toggle-pass {
	position: absolute;
	right: 0.75rem;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.25rem;
	color: var(--olms-gray-400);
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color 0.15s ease;
}

.olms-auth-form__toggle-pass:hover {
	color: var(--olms-primary);
}

.olms-auth-form__toggle-pass-icon {
	display: block;
	width: 18px;
	height: 18px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
}

/* ---- Hint text ---- */
.olms-auth-form__hint {
	font-size: 0.8rem;
	color: var(--olms-gray-500);
	display: block;
	margin-top: 0.35rem;
}

/* ---- Remember me row ---- */
.olms-auth-form__checkbox-label {
	display: flex;
	align-items: center;
	gap: 0.45rem;
	font-size: 0.875rem;
	color: var(--olms-gray-700);
	cursor: pointer;
	user-select: none;
}

.olms-auth-form__checkbox {
	width: 1rem;
	height: 1rem;
	accent-color: var(--olms-primary);
	cursor: pointer;
	flex-shrink: 0;
}

/* ---- Links ---- */
.olms-auth-form__link {
	font-size: 0.875rem;
	color: var(--olms-primary);
	text-decoration: none;
	font-weight: 500;
	transition: color 0.15s ease;
}

.olms-auth-form__link:hover {
	color: var(--olms-primary-dark);
	text-decoration: underline;
}

/* ---- Submit button ---- */
.olms-btn--full {
	width: 100%;
	justify-content: center;
	padding: 0.75rem 1.5rem;
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	border-radius: var(--olms-radius);
	margin-top: 0.5rem;
	background: linear-gradient(135deg, var(--olms-primary) 0%, var(--olms-primary-dark) 100%);
	color: #fff;
	border: none;
	cursor: pointer;
	box-shadow: 0 2px 8px rgba(99, 102, 241, 0.35);
	transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
}

.olms-btn--full:hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 14px rgba(99, 102, 241, 0.45);
	opacity: 0.95;
	color: #fff;
}

.olms-btn--full:active {
	transform: translateY(0);
	box-shadow: 0 2px 6px rgba(99, 102, 241, 0.3);
}

/* ---- Footer "Already have an account?" ---- */
.olms-auth-box__footer {
	text-align: center;
	font-size: 0.9rem;
	color: var(--olms-gray-500);
	margin: 1.5rem 0 0;
	padding-top: 1.25rem;
	border-top: 1px solid var(--olms-gray-100);
}

.olms-auth-box__footer .olms-auth-form__link {
	font-size: 0.9rem;
}

/* ---- Terms line ---- */
.olms-auth-box__terms {
	text-align: center;
	font-size: 0.8rem;
	color: var(--olms-gray-400);
	margin: 0.75rem 0 0;
}

.olms-auth-box__terms .olms-auth-form__link {
	font-size: 0.8rem;
}

/* ---- Responsive ---- */
@media (max-width: 520px) {
	.olms-auth-wrap {
		padding: 1.5rem 0.75rem 3rem;
		background: #fff;
	}

	.olms-auth-box {
		padding: 2rem 1.5rem 1.5rem;
		border-radius: var(--olms-radius-lg);
		box-shadow: none;
		border: none;
		border-top: 3px solid var(--olms-primary);
	}

	.olms-auth-form__row {
		grid-template-columns: 1fr;
		gap: 0;
	}
}

/* ===================================
 * Course Completion Modal
 * =================================== */

.olms-completion-modal {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
}

.olms-completion-modal[hidden] {
	display: none;
}

.olms-completion-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, 0.65);
	backdrop-filter: blur(3px);
	animation: olmsFadeIn 0.25s ease-out;
}

.olms-completion-modal__dialog {
	position: relative;
	background: #fff;
	border-radius: 16px;
	padding: 48px 40px 36px;
	max-width: 480px;
	width: 100%;
	text-align: center;
	box-shadow: 0 25px 60px rgba(0, 0, 0, 0.35);
	animation: olmsPopIn 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.olms-completion-modal__close {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 32px;
	height: 32px;
	border: none;
	background: transparent;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	color: #64748b;
	border-radius: 6px;
}

.olms-completion-modal__close:hover {
	background: #f1f5f9;
	color: #0f172a;
}

.olms-completion-modal__icon {
	font-size: 64px;
	line-height: 1;
	margin-bottom: 16px;
	animation: olmsBounce 0.8s ease-out;
}

.olms-completion-modal__title {
	font-size: 28px;
	font-weight: 700;
	margin: 0 0 12px;
	color: #0f172a;
}

.olms-completion-modal__text {
	font-size: 16px;
	color: #475569;
	margin: 0 0 28px;
	line-height: 1.5;
}

.olms-completion-modal__actions {
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
}

body.olms-modal-open {
	overflow: hidden;
}

@keyframes olmsFadeIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@keyframes olmsPopIn {
	0%   { opacity: 0; transform: scale(0.85) translateY(10px); }
	100% { opacity: 1; transform: scale(1) translateY(0); }
}

@keyframes olmsBounce {
	0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
	40% { transform: translateY(-12px); }
	60% { transform: translateY(-6px); }
}
/* --- /17.0 Auth Forms (Login / Register) --- */