/**
 * Courses Panel Styles
 *
 * Course carousel/grid panel with Swiper integration
 * Used on homepage and course listings for featured courses
 *
 * Dependencies: ssa-base, ssa-swiper
 * Extracted from: styles.css lines 620-704, responsive rules from multiple media queries
 */

/* ==========================================================================
   Base Styles
   ========================================================================== */

.courses-panel {
	background-color: var(--bg-1);
	padding-bottom: 100px;
}

.courses-panel .content {
	padding: 0 20px 0 var(--content-padding-x);
	max-width: 1280px;
}

.courses-panel .content h3 {
	color: var(--brand-main);
	font-size: 42px;
	letter-spacing: -1.5px;
	line-height: 46px;
	margin-bottom: var(--space-6);
}

.courses-panel .content p {
	font-size: 20px;
	margin-bottom: 66px;
}

.courses-panel .courses-container {
	padding-right: 30px;
}

.courses-panel .courses-container .course {
	background-color: var(--white);
	text-align: left;
}

.courses-panel .content .course {
	box-sizing: border-box;
	display: inline-block;
	padding: 28px 19px 16px 32px;
	border-radius: var(--radius-lg);
	box-shadow: 7px 7px 9px 0 var(--shadow-medium);
}

.courses-panel .content .course img,
.courses-panel .content .course .circle {
	display: inline-block;
	border-radius: var(--radius-full);
	height: 200px;
	width: 200px;
	margin: 0 auto 16px;
}

.courses-panel .content .course .course-content {
	padding: var(--space-0);
	width: 100%;
}

.courses-panel .content .course .course-content h3 {
	color: var(--black);
	font-size: 19px;
	line-height: 22px;
	margin-bottom: var(--space-2);
}

.courses-panel .content .course .course-content p {
	font-size: 14px;
	line-height: 18px;
	margin-bottom: 18px;
}

.courses-panel .content .buttons {
	text-align: center;
	width: 100%;
}

.courses-panel .content .button {
	background-color: var(--brand-main);
	color: var(--white);
	display: inline-block;
	margin: 0 12px 25px;
	line-height: 48px;
	text-align: center;
}

.courses-panel .content .button.outline {
	background: transparent;
	color: var(--brand-main);
}

/* ==========================================================================
   Responsive: Tablet and Up (768px+)
   ========================================================================== */

@media (min-width: 768px) {
	.courses-panel .courses-container {
		width: 100%;
	}

	.courses-panel .content .courses-container .swiper-wrapper .course {
		box-sizing: border-box;
		max-width: 23.125%;
		margin-bottom: 2.5%;
	}

	.courses-panel .courses-container .swiper-wrapper {
		flex-wrap: wrap;
		gap: 2.5%;
		justify-content: flex-start;
	}

	.courses-panel .courses-container .pagination-container {
		display: none;
	}
}

/* ==========================================================================
   Responsive: Wide (1280px and below)
   ========================================================================== */

@media (max-width: 1280px) {
	.courses-panel .content .courses-container .swiper-wrapper .course {
		max-width: 31.6666%;
	}
}

/* ==========================================================================
   Responsive: Tablet (768px and below)
   ========================================================================== */

@media (max-width: 768px) {
	.courses-panel .content .courses-container .swiper-wrapper .course {
		max-width: 48.75%;
	}

	.courses-panel .content .button {
		margin: 0 10% 25px;
		width: 80%;
	}

	/* stylelint-disable-next-line no-duplicate-selectors -- override for smaller mobile */
	.courses-panel .content .courses-container .swiper-wrapper .course {
		max-width: 100%;
	}
}

/* ==========================================================================
   Responsive: Mobile (480px and below)
   ========================================================================== */

@media (max-width: 480px) {
	.courses-panel .content {
		padding: 0 var(--content-padding-x) 0 var(--content-padding-x);
	}

	.courses-panel .content h3 {
		font-size: 34px;
		line-height: 42px;
	}
}
