/**
 * Masteriyo Course Carousel Styles
 * Version: 3.0.0
 */

/* =========================================================
   CSS VARIABLES (Fallbacks)
   ========================================================= */

.front-course-carousel {
	/* Fallback values if not defined globally */
	--c-white: #fff;
	--c-black: #000;
	--r-xs: 10px;
	--r-sm: 12px;
	--r-md: 14px;
	--r-pill: 999px;
	--fcc-left: 0px;
}

/* =========================================================
   CAROUSEL CONTAINER
   ========================================================= */

.front-course-carousel {
	position: relative;
	isolation: isolate;
	background: var(--c-white) !important;
	overflow: visible !important;
	width: 100%;
}

.front-course-carousel:focus {
	outline: 2px solid #0073aa;
	outline-offset: 2px;
}

/* =========================================================
   VIEWPORT & TRACK
   ========================================================= */

.front-course-carousel .fcc-viewport {
	overflow: hidden !important;
	position: relative;
	width: 100%;
	min-height: 320px;
	touch-action: pan-y;
	user-select: none;
}

/* Ensure links and buttons are clickable */
.front-course-carousel a,
.front-course-carousel button {
	pointer-events: auto;
	cursor: pointer;
	position: relative;
	z-index: 10;
}

.front-course-carousel .fcc-track {
	display: flex !important;
	flex-wrap: nowrap !important;
	position: relative !important;
	left: var(--fcc-left, 0px) !important;
	transition: left 380ms ease;
	will-change: left;
}

.fcc-track.fcc-no-transition {
	transition: none !important;
}

/* =========================================================
   SLIDES
   ========================================================= */

.front-course-carousel .fcc-slide {
	flex: 0 0 100% !important;
	width: 100%;
	min-width: 100%;
	box-sizing: border-box;
}

/* =========================================================
   LAYOUT
   ========================================================= */

.front-course-carousel .masteriyo-course-item--wrapper {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 60px !important;
	max-width: 1200px !important;
	margin: 0 auto !important;
	padding: 80px 20px !important;
	background: var(--c-white) !important;
	border-radius: var(--r-sm) !important;
	box-shadow: none !important;
	border: none;
	transition: box-shadow 0.3s ease;
	height: auto;
}

/* =========================================================
   IMAGE (Portrait 3:4)
   ========================================================= */

.front-course-carousel .masteriyo-course--img-wrap {
	flex: 0 0 46% !important;
	position: relative;
	overflow: hidden;
	background: #f9f9f9;
}

.front-course-carousel .masteriyo-course--img-wrap > a {
	display: block;
	height: 100%;
	line-height: 0;
}

.front-course-carousel .masteriyo-feature-img {
	position: relative;
	width: 100%;
	aspect-ratio: 3/4 !important;
	border-radius: var(--r-md) !important;
	overflow: hidden !important;
}

.front-course-carousel .masteriyo-feature-img img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	object-position: center !important;
	border-radius: inherit !important;
	display: block;
	background-color: #f9f9f9;
	max-width: none !important;
	max-height: none !important;
}

.front-course-carousel .masteriyo-feature-img img:hover {
	transform: scale(1.03);
	transition: transform .3s ease-in-out;
}

/* =========================================================
   CONTENT
   ========================================================= */

.front-course-carousel .masteriyo-course--content {
	flex: 1 1 54% !important;
	display: flex;
	flex-direction: column;
}

.front-course-carousel .masteriyo-course--content__wrapper {
	flex: 1;
	display: flex;
	flex-direction: column;
	max-width: 640px;
	text-align: left;
}

.front-course-carousel .masteriyo-course--content__title {
	font-size: 1.25rem;
	margin: 0 0 12px 0;
	line-height: 1.4;
}

.front-course-carousel .masteriyo-course--content__title a {
	font-family: Montserrat, sans-serif !important;
	font-size: 20px !important;
	font-weight: 500 !important;
	line-height: 1.4 !important;
	color: var(--c-black) !important;
	text-decoration: none !important;
	display: inline-block;
	margin: 0 0 16px !important;
	transition: color 0.2s ease;
}

.front-course-carousel .masteriyo-course--content__title a:hover {
	color: #0073aa;
}

/* =========================================================
   INSTRUCTOR INFO
   ========================================================= */

.front-course-carousel .fcc-instructor {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	margin: 10px 0 18px !important;
	font-size: 0.9rem;
	color: #666;
}

.front-course-carousel .fcc-instructor-avatar {
	width: 50px !important;
	height: 50px !important;
	border-radius: 50% !important;
}

.front-course-carousel .fcc-instructor-name {
	font-family: Montserrat, sans-serif !important;
	font-size: 16px !important;
	font-weight: 500 !important;
	color: #3a3f45 !important;
}

/* =========================================================
   DESCRIPTION
   ========================================================= */

.front-course-carousel .fcc-desc {
	flex: 1;
	font-family: Montserrat, sans-serif !important;
	font-size: 14px !important;
	font-weight: 400 !important;
	line-height: 1.8 !important;
	color: #4a4f55 !important;
	margin-bottom: 24px !important;
	max-width: 56ch;
}

.front-course-carousel .fcc-desc p {
	margin: 0 0 12px !important;
}

.front-course-carousel .fcc-desc p:last-child {
	margin-bottom: 0 !important;
}

/* =========================================================
   FOOTER / BUTTON (CTA)
   ========================================================= */

.front-course-carousel .masteriyo-course-card-footer {
	display: flex !important;
	justify-content: flex-end !important;
	align-items: center !important;
	width: 100%;
	margin-top: 28px !important;
	padding-top: 0;
	border-top: none;
}

.front-course-carousel .masteriyo-enroll-btn {
	display: inline-block;
	background: var(--c-black) !important;
	color: var(--c-white) !important;
	border-radius: var(--r-xs) !important;
	padding: 14px 32px !important;
	font-family: Montserrat, sans-serif !important;
	font-size: 16px !important;
	font-weight: 500 !important;
	text-decoration: none !important;
	text-align: center;
	box-sizing: border-box;
	transition: background .25s ease, transform .25s ease;
}

.front-course-carousel .masteriyo-enroll-btn:hover {
	background: #222 !important;
	color: var(--c-white) !important;
	transform: translateY(-2px);
}

/* =========================================================
   NAVIGATION ARROWS
   ========================================================= */

/* Hide default Swiper/Masteriyo arrows */
.front-course-carousel .swiper-button-prev,
.front-course-carousel .swiper-button-next,
.front-course-carousel .masteriyo-swiper-button-prev,
.front-course-carousel .masteriyo-swiper-button-next,
.front-course-carousel::before,
.front-course-carousel::after {
	display: none !important;
}

/* Custom arrows */
.front-course-carousel .fcc-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1000;
	width: 44px;
	height: 44px;
	border: 0;
	border-radius: var(--r-pill);
	background: var(--c-white);
	box-shadow: 0 2px 8px rgba(0, 0, 0, .12);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	opacity: 1;
	pointer-events: auto;
	transition: all 0.3s ease;
}

.front-course-carousel .fcc-arrow:hover {
	background: #fff;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	transform: translateY(-50%) scale(1.05);
}

.front-course-carousel .fcc-arrow:focus {
	outline: 2px solid #0073aa;
	outline-offset: 2px;
}

.front-course-carousel .fcc-arrow:active {
	transform: translateY(-50%) scale(0.95);
}

.front-course-carousel .fcc-arrow svg {
	display: block;
	width: 20px;
	height: 20px;
	stroke: var(--c-black);
	stroke-width: 2;
	color: #333;
}

/* Default arrow offsets (desktop baseline) */
.front-course-carousel .fcc-prev {
	left: -56px !important;
}

.front-course-carousel .fcc-next {
	right: -56px !important;
}

/* =========================================================
   DEBUG MODE
   ========================================================= */

.fcc-debug {
	background: #fff3cd;
	border: 1px solid #ffc107;
	padding: 15px;
	margin-bottom: 20px;
	border-radius: 4px;
	font-family: monospace;
	font-size: 0.9rem;
	overflow-x: auto;
}

/* =========================================================
   LOADING STATE
   ========================================================= */

.fcc-loading {
	opacity: 0.6;
	pointer-events: none;
}

/* =========================================================
   SCREEN READER ONLY
   ========================================================= */

.fcc-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border-width: 0;
}

/* =========================================================
   RESPONSIVE DESIGN
   ========================================================= */

/* Wide desktops (≥ 1280px) */
@media (min-width: 1280px) {
	.front-course-carousel .fcc-prev {
		left: -72px !important;
	}

	.front-course-carousel .fcc-next {
		right: -72px !important;
	}
}

/* Desktop (≥ 901px): carousel columns */
@media (min-width: 901px) {
	.front-course-carousel .masteriyo-course--img-wrap {
		flex: 0 0 38% !important;
	}

	.front-course-carousel .masteriyo-course--content {
		flex: 1 1 62% !important;
	}
}

/* Mobile and small tablets (≤ 900px): carousel stack */
@media (max-width: 900px) {
	.front-course-carousel .masteriyo-enroll-btn {
		width: 100%;
		text-align: center;
	}

	.front-course-carousel .masteriyo-course-item--wrapper {
		flex-direction: column !important;
		text-align: center !important;
		padding: 40px 20px !important;
		gap: 32px !important;
	}

	.front-course-carousel .masteriyo-course--img-wrap,
	.front-course-carousel .masteriyo-course--content {
		flex: 0 0 100% !important;
	}

	.front-course-carousel .masteriyo-course-highlights {
		text-align: left !important;
		margin-left: auto !important;
		margin-right: auto !important;
	}

	/* Bring arrows slightly in when very small */
	.front-course-carousel .fcc-prev {
		left: 8px !important;
	}

	.front-course-carousel .fcc-next {
		right: 8px !important;
	}
}

@media (max-width: 768px) {
	.front-course-carousel .fcc-arrow {
		width: 40px;
		height: 40px;
	}

	.front-course-carousel .masteriyo-course--content {
		padding: 15px;
	}

	.front-course-carousel .masteriyo-course--content__title {
		font-size: 1.1rem;
	}
}

/* =========================================================
   HIGH CONTRAST MODE SUPPORT
   ========================================================= */

@media (prefers-contrast: high) {
	.front-course-carousel .fcc-arrow {
		border-width: 2px;
	}

	.front-course-carousel .masteriyo-course-item--wrapper {
		border-width: 2px;
	}
}

/* =========================================================
   REDUCED MOTION SUPPORT
   ========================================================= */

@media (prefers-reduced-motion: reduce) {
	.fcc-track {
		transition: none !important;
	}

	.front-course-carousel .fcc-arrow,
	.front-course-carousel .masteriyo-feature-img img,
	.front-course-carousel .masteriyo-enroll-btn {
		transition: none !important;
	}
}

/* =========================================================
   PRINT STYLES
   ========================================================= */

@media print {
	.front-course-carousel .fcc-arrow {
		display: none;
	}

	.fcc-track {
		display: block !important;
		position: static !important;
		left: 0 !important;
	}

	.fcc-slide {
		page-break-inside: avoid;
		break-inside: avoid;
	}
}
