/* AstroWay /courses/ archive — Info Accent card style.
   Loaded only on stm-courses post type archive + taxonomy (lms.php aw_lms_enqueue_courses_archive_css). */

/* Own-scoped token set — self-contained, не depending на theme-wide vars
   that may not load on frontend (editor-style is admin-only). */
.aw-course-card {
	--awc-bg: #ffffff;
	--awc-text: #1f2937;
	--awc-text-muted: #6b7280;
	--awc-accent: #f5a623;
	--awc-accent-hover: #d8901a;
	--awc-primary: #1d1d1d;
	--awc-price: #1d1d1d;
	--awc-price-old: #9ca3af;
	--awc-border: rgba(0, 0, 0, 0.08);
	--awc-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
	--awc-shadow-hover: 0 16px 40px -12px rgba(15, 23, 42, 0.18);
	--awc-radius: 12px;
	--awc-image-radius: 8px;
	--awc-overlay-from: rgba(108, 92, 231, 0.92);
	--awc-overlay-to: rgba(167, 139, 250, 0.92);
	--awc-ribbon-from: #f5a623;
	--awc-ribbon-to: #e08e0b;
	--awc-progress-fill: linear-gradient(90deg, #f5a623, #f6b94c);
	--awc-progress-track: rgba(245, 166, 35, 0.18);
	--awc-star: #f5a623;
	--awc-star-empty: rgba(245, 166, 35, 0.25);
	--awc-anim: 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* ─── Grid wrapper ───────────────────────────────────────────────── */

.stm_lms_courses__archive_wrapper .stm_lms_courses__archive,
.stm_lms_courses__archive_wrapper .stm_lms_courses__grid {
	display: grid;
	/* minmax 280px → 360px max so 1 course in a narrow column doesn't stretch
	   to ridiculous width. Multi-column behavior preserved via auto-fill. */
	grid-template-columns: repeat(auto-fill, minmax(260px, 360px));
	justify-content: start;
	gap: 24px;
	margin: 0;
	padding: 0;
	list-style: none;
}

/* Featured-courses block stays its own grid above */
.stm_lms_courses__archive_wrapper .stm_lms_courses__grid.featured-courses {
	margin-bottom: 32px;
}

/* ─── Card ───────────────────────────────────────────────────────── */

.aw-course-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--awc-bg);
	border: 1px solid var(--awc-border);
	border-radius: var(--awc-radius);
	box-shadow: var(--awc-shadow);
	overflow: hidden;
	transition: transform var(--awc-anim), box-shadow var(--awc-anim);
	color: var(--awc-text);
}

.aw-course-card:hover,
.aw-course-card:focus-within {
	transform: translateY(-4px);
	box-shadow: var(--awc-shadow-hover);
}

/* ─── Image with hover overlay ───────────────────────────────────── */

.aw-course-card__image {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: #f3f4f6;
	border-radius: var(--awc-image-radius) var(--awc-image-radius) 0 0;
	text-decoration: none;
}

.aw-course-card__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 400ms cubic-bezier(0.4, 0, 0.2, 1);
}

.aw-course-card__img--placeholder {
	background: linear-gradient(135deg, #e0e7ff, #f5f3ff);
}

.aw-course-card:hover .aw-course-card__img {
	transform: scale(1.05);
}

.aw-course-card__preview-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 4px;
	background: linear-gradient(135deg, var(--awc-overlay-from), var(--awc-overlay-to));
	color: #ffffff;
	opacity: 0;
	transform: translateY(100%);
	transition: opacity var(--awc-anim), transform var(--awc-anim);
	pointer-events: none;
}

.aw-course-card:hover .aw-course-card__preview-overlay,
.aw-course-card:focus-within .aw-course-card__preview-overlay {
	opacity: 1;
	transform: translateY(0);
}

.aw-course-card__preview-label {
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0.02em;
}

.aw-course-card__preview-trial {
	font-size: 12px;
	font-weight: 500;
	opacity: 0.92;
}

/* ─── Featured ribbon ───────────────────────────────────────────── */

.aw-course-card__ribbon {
	position: absolute;
	top: 12px;
	left: -32px;
	width: 132px;
	transform: rotate(-35deg);
	background: linear-gradient(135deg, var(--awc-ribbon-from), var(--awc-ribbon-to));
	color: #ffffff;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	text-align: center;
	padding: 4px 0;
	z-index: 2;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
	pointer-events: none;
}

/* ─── Body ──────────────────────────────────────────────────────── */

.aw-course-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: 18px 20px 20px;
	gap: 10px;
}

.aw-course-card__category {
	display: inline-block;
	align-self: flex-start;
	color: var(--awc-accent);
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	text-decoration: none;
	transition: color var(--awc-anim);
}

.aw-course-card__category:hover {
	color: var(--awc-accent-hover);
}

.aw-course-card__title {
	margin: 0;
	font-size: 18px;
	font-weight: 600;
	line-height: 1.35;
	letter-spacing: -0.005em;
}

/* Anchor получает class — theme's `.entry-content a:not([class],...)` skips
   it because :not([class]) excludes elements WITH class attr. So our rule
   wins by being the only one targeting `.aw-course-card__title-link`. */
.aw-course-card__title-link {
	color: var(--awc-text);
	text-decoration: none;
	transition: color var(--awc-anim);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.aw-course-card__title-link:hover {
	color: var(--awc-accent);
}

/* ─── Progress (logged-in enrolled) ─────────────────────────────── */

.aw-course-card__progress {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 2px;
}

.aw-course-card__progress-track {
	flex: 1;
	height: 6px;
	background: var(--awc-progress-track);
	border-radius: 999px;
	overflow: hidden;
}

.aw-course-card__progress-fill {
	height: 100%;
	background: var(--awc-progress-fill);
	border-radius: inherit;
	transition: width 600ms ease;
}

.aw-course-card__progress-label {
	font-size: 12px;
	font-weight: 600;
	color: var(--awc-accent);
	min-width: 36px;
	text-align: right;
}

/* ─── Meta row ──────────────────────────────────────────────────── */

.aw-course-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	font-size: 13px;
	color: var(--awc-text-muted);
	font-weight: 500;
}

.aw-course-card__meta-item {
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

.aw-course-card__meta-icon {
	font-size: 14px;
	line-height: 1;
}

/* ─── Divider ───────────────────────────────────────────────────── */

.aw-course-card__divider {
	height: 1px;
	background: var(--awc-border);
	margin: 4px 0;
}

/* ─── Footer (rating + price) ───────────────────────────────────── */

.aw-course-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-top: auto;
}

.aw-course-card__rating {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--awc-text-muted);
}

.aw-course-card__rating--empty {
	min-height: 18px;
	min-width: 18px;
}

/* Star bar — uses CSS-only stars via gradient masking with --rating var (0-100%) */
.aw-course-card__stars {
	display: inline-block;
	width: 84px;
	height: 14px;
	background: linear-gradient(
		90deg,
		var(--awc-star) var(--rating, 0%),
		var(--awc-star-empty) var(--rating, 0%)
	);
	-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 84 14'><g fill='black'><polygon points='7,1 8.6,5.1 13,5.4 9.6,8.2 10.6,12.6 7,10.3 3.4,12.6 4.4,8.2 1,5.4 5.4,5.1'/><polygon points='24,1 25.6,5.1 30,5.4 26.6,8.2 27.6,12.6 24,10.3 20.4,12.6 21.4,8.2 18,5.4 22.4,5.1'/><polygon points='42,1 43.6,5.1 48,5.4 44.6,8.2 45.6,12.6 42,10.3 38.4,12.6 39.4,8.2 36,5.4 40.4,5.1'/><polygon points='60,1 61.6,5.1 66,5.4 62.6,8.2 63.6,12.6 60,10.3 56.4,12.6 57.4,8.2 54,5.4 58.4,5.1'/><polygon points='77,1 78.6,5.1 83,5.4 79.6,8.2 80.6,12.6 77,10.3 73.4,12.6 74.4,8.2 71,5.4 75.4,5.1'/></g></svg>") no-repeat center / contain;
	        mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 84 14'><g fill='black'><polygon points='7,1 8.6,5.1 13,5.4 9.6,8.2 10.6,12.6 7,10.3 3.4,12.6 4.4,8.2 1,5.4 5.4,5.1'/><polygon points='24,1 25.6,5.1 30,5.4 26.6,8.2 27.6,12.6 24,10.3 20.4,12.6 21.4,8.2 18,5.4 22.4,5.1'/><polygon points='42,1 43.6,5.1 48,5.4 44.6,8.2 45.6,12.6 42,10.3 38.4,12.6 39.4,8.2 36,5.4 40.4,5.1'/><polygon points='60,1 61.6,5.1 66,5.4 62.6,8.2 63.6,12.6 60,10.3 56.4,12.6 57.4,8.2 54,5.4 58.4,5.1'/><polygon points='77,1 78.6,5.1 83,5.4 79.6,8.2 80.6,12.6 77,10.3 73.4,12.6 74.4,8.2 71,5.4 75.4,5.1'/></g></svg>") no-repeat center / contain;
}

.aw-course-card__rating-num {
	font-weight: 600;
	color: var(--awc-text);
}

.aw-course-card__price {
	display: inline-flex;
	align-items: baseline;
	gap: 8px;
	flex-wrap: nowrap;
}

.aw-course-card__price-current {
	font-size: 18px;
	font-weight: 700;
	color: var(--awc-price);
}

.aw-course-card__price-old {
	font-size: 13px;
	color: var(--awc-price-old);
	text-decoration: line-through;
}

.aw-course-card__price-free {
	font-size: 14px;
	font-weight: 600;
	color: #16a34a;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

/* ─── Coming-soon swap ──────────────────────────────────────────── */

.aw-course-card__coming-soon {
	margin-top: auto;
}

/* ─── Responsive ────────────────────────────────────────────────── */

@media (max-width: 1199px) {
	.stm_lms_courses__archive_wrapper .stm_lms_courses__archive,
	.stm_lms_courses__archive_wrapper .stm_lms_courses__grid {
		grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
		gap: 20px;
	}
}

@media (max-width: 767px) {
	.stm_lms_courses__archive_wrapper .stm_lms_courses__archive,
	.stm_lms_courses__archive_wrapper .stm_lms_courses__grid {
		grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
		gap: 16px;
	}

	.aw-course-card__body {
		padding: 16px 16px 18px;
		gap: 8px;
	}

	.aw-course-card__title {
		font-size: 16px;
	}

	.aw-course-card__price-current {
		font-size: 16px;
	}
}

@media (max-width: 479px) {
	.stm_lms_courses__archive_wrapper .stm_lms_courses__archive,
	.stm_lms_courses__archive_wrapper .stm_lms_courses__grid {
		grid-template-columns: 1fr;
		gap: 14px;
	}

	.aw-course-card__image {
		aspect-ratio: 16 / 10;
	}
}

/* ─── Reduced motion ────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
	.aw-course-card,
	.aw-course-card__img,
	.aw-course-card__preview-overlay,
	.aw-course-card__progress-fill {
		transition: none;
	}

	.aw-course-card:hover {
		transform: none;
	}

	.aw-course-card:hover .aw-course-card__img {
		transform: none;
	}
}
