.ailms-catalog {
	max-width: 1200px;
	margin: 0 auto;
	padding: 20px;
}

.ailms-catalog-header h1 {
	margin-bottom: 16px;
}

.ailms-catalog-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 24px;
}

.ailms-catalog-filters input[type="search"] {
	flex: 1 1 220px;
	padding: 8px 10px;
}

.ailms-catalog-filters select {
	padding: 8px 10px;
}

.ailms-filter-submit {
	padding: 8px 16px;
	background: #2271b1;
	color: #fff;
	border: none;
	border-radius: 4px;
	cursor: pointer;
}

.ailms-course-grid {
	display: grid;
	grid-template-columns: repeat( auto-fill, minmax( 260px, 1fr ) );
	gap: 20px;
}

.ailms-course-card {
	display: block;
	border: 1px solid #dcdcde;
	border-radius: 6px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	background: #fff;
	transition: box-shadow 0.15s ease;
}

.ailms-course-card:hover {
	box-shadow: 0 2px 10px rgba( 0, 0, 0, 0.08 );
}

.ailms-course-card-thumb img {
	width: 100%;
	height: 150px;
	object-fit: cover;
	display: block;
}

.ailms-course-card-thumb-placeholder {
	width: 100%;
	height: 150px;
	background: #e9eaeb;
}

.ailms-course-card-body {
	padding: 12px 14px;
}

.ailms-course-card-title {
	margin: 0 0 6px;
	font-size: 16px;
}

.ailms-course-card-instructor {
	margin: 0 0 8px;
	color: #646970;
	font-size: 13px;
}

.ailms-course-card-level {
	display: inline-block;
	font-size: 11px;
	background: #f0f0f1;
	padding: 2px 8px;
	border-radius: 10px;
	margin-bottom: 8px;
}

.ailms-course-card-price {
	margin: 0;
	font-weight: 600;
}

.ailms-pagination {
	margin-top: 24px;
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}

.ailms-no-results {
	padding: 40px 0;
	text-align: center;
	color: #646970;
}

.ailms-course-hero {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
	margin-bottom: 32px;
}

.ailms-course-hero-media {
	flex: 1 1 360px;
}

.ailms-course-hero-media img,
.ailms-course-hero-placeholder {
	width: 100%;
	height: 280px;
	object-fit: cover;
	border-radius: 6px;
	background: #e9eaeb;
}

.ailms-course-hero-info {
	flex: 1 1 360px;
}

.ailms-course-hero-info h1 {
	margin: 8px 0;
}

.ailms-badge {
	display: inline-block;
	font-size: 12px;
	background: #f0f0f1;
	padding: 3px 10px;
	border-radius: 12px;
	margin-right: 6px;
}

.ailms-badge-level {
	background: #e7f2fa;
	color: #2271b1;
}

.ailms-badge-preview {
	background: #e6f6ec;
	color: #1a7a3d;
	margin-left: 8px;
}

.ailms-course-meta-row {
	display: flex;
	align-items: center;
	gap: 12px;
	color: #646970;
}

.ailms-course-layout {
	display: flex;
	gap: 32px;
	align-items: flex-start;
	flex-wrap: wrap;
}

.ailms-course-main {
	flex: 2 1 500px;
	min-width: 0;
}

.ailms-course-sidebar {
	flex: 1 1 260px;
	position: sticky;
	top: 32px;
}

.ailms-course-section {
	margin-bottom: 32px;
}

.ailms-checklist,
.ailms-bullet-list {
	padding-left: 20px;
}

.ailms-checklist li {
	list-style: '\2713  ';
	margin-bottom: 6px;
}

.ailms-curriculum-outline .ailms-outline-section {
	border: 1px solid #dcdcde;
	border-radius: 4px;
	margin-bottom: 10px;
}

.ailms-curriculum-outline summary {
	padding: 12px;
	cursor: pointer;
	font-weight: 600;
	background: #f6f7f7;
}

.ailms-curriculum-outline ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.ailms-outline-lesson {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 14px;
	border-top: 1px solid #f0f0f1;
}

.ailms-outline-lesson.is-locked {
	color: #787c82;
}

.ailms-outline-lesson .dashicons-lock {
	color: #b32d2e;
}

.ailms-outline-lesson .dashicons-unlock {
	color: #1a7a3d;
}

.ailms-outline-lesson-title {
	flex: 1;
}

.ailms-instructor-card {
	display: flex;
	gap: 14px;
	align-items: flex-start;
}

.ailms-instructor-name {
	font-weight: 600;
	margin: 0 0 4px;
}

.ailms-instructor-description {
	color: #646970;
	margin: 0;
}

.ailms-enroll-box {
	border: 1px solid #dcdcde;
	border-radius: 6px;
	padding: 20px;
}

.ailms-price {
	font-size: 24px;
	font-weight: 700;
	margin: 0 0 16px;
}

.ailms-button {
	display: block;
	width: 100%;
	text-align: center;
	padding: 12px;
	border-radius: 4px;
	text-decoration: none;
	border: none;
	font-weight: 600;
	cursor: pointer;
	box-sizing: border-box;
}

.ailms-button-primary {
	background: #2271b1;
	color: #fff;
}

.ailms-button-disabled {
	background: #dcdcde;
	color: #787c82;
	cursor: not-allowed;
}

.ailms-enrolled-notice {
	color: #1a7a3d;
}

@media ( max-width: 782px ) {
	.ailms-course-sidebar {
		position: static;
	}
}
